assignment-p-12_v1.c ​
Metadata ​
- Author — Amit Dutta
- Last updated — 12 Dec 2025
- License — MIT License (See the LICENSE file for details)
Problem Statement ​
Problem Statement
Write a C program that takes multiple integers as command-line arguments and finds the maximum and minimum value among them.
Source Code ​
Printing the code
To print this file, open it on GitHub and click Raw before printing, or use the Download Raw button above and print directly from that page.
c
#include <stdio.h>
#include <stdlib.h>
// use atoi()
int main(int argc, char *argv[])
{
int current_val, max_val, min_val, i;
char *endptr;
long first_arg_val;
if (argc < 2)
{
printf("Usage: %s <integer1> <integer2> ...\n", argv[0]);
return 1;
}
first_arg_val = strtol(argv[1], &endptr, 10);
if (*endptr != '\0' || argv[1] == endptr)
{
printf("Error: Argument '%s' is not a valid integer.\n", argv[1]);
return 1;
}
max_val = (int)first_arg_val;
min_val = (int)first_arg_val;
for (i = 2; i < argc; i++)
{
long val = strtol(argv[i], &endptr, 10);
if (*endptr != '\0' || argv[i] == endptr)
{
printf("Error: Argument '%s' is not a valid integer.\n", argv[i]);
return 1;
}
current_val = (int)val;
if (current_val > max_val)
{
max_val = current_val;
}
if (current_val < min_val)
{
min_val = current_val;
}
}
printf("The maximum value is: %d\n", max_val);
printf("The minimum value is: %d\n", min_val);
return 0;
}1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45