lucproblem014.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 function that receives integers and returns the sum, average and standard deviation of these numbers. Call this function from main() and print the result in main()
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 <math.h>
// Function prototype: Using pointers for 'call by reference' to return 3 values.
void stats(double *, double *, double *);
int main()
{
double sum, average, standardDeviation;
// Passing addresses of variables to receive results from the function.
stats(&sum, &average, &standardDeviation);
printf("\n--- Stats ---"
"\nSum: %g"
"\nAverage: %g"
"\nStandard Deviation: %g",
sum, average, standardDeviation);
return 0;
}
// Function to calculate statistics on user-provided numbers.
void stats(double *sum, double *average, double *standardDeviation)
{
int n;
// Input Validation Loop for N
do
{
printf("How many numbers you want to give input: ");
if (scanf("%d", &n) == 1)
{
break;
}
else
{
printf("\nPlease enter a valid number.\n");
// Clearing input buffer to handle invalid input
while (getchar() != '\n' && !feof(stdin))
;
}
} while (1);
// Variable-Length Array (VLA) to store the input numbers.
double inputNumber[n];
int i = 0;
printf("\n--- Enter Numbers ---\n");
// Input Loop for numbers
while (i < n)
{
printf("Enter number %d: ", i + 1);
if (scanf("%lf", &inputNumber[i]) == 1)
{
// Clearing input buffer after successful read
while (getchar() != '\n')
;
i++;
}
else
{
printf("Invalid input. Only integers are allowed. Please try again.\n");
// Clearing input buffer to handle invalid input
while (getchar() != '\n' && !feof(stdin))
;
}
}
// 1. Sum Calculation
double tempSum = 0;
for (i = 0; i < n; i++)
tempSum += inputNumber[i];
// 2. Average (Mean) calculation
double tempAverage = tempSum / n;
// 3. Standard Deviation (Sample SD formula used)
double tempStandardDeviation = 0.0;
// Preventing division by zero if n is 1. SD is 0 for a single number.
if (n > 1)
{
double tempSumation = 0;
// calculating the sum of squared differences from the mean
for (i = 0; i < n; i++)
tempSumation += pow((inputNumber[i] - tempAverage), 2.0);
// Calculating sample standard deviation
tempStandardDeviation = sqrt(tempSumation / (n - 1));
}
// Assigning final values back to the variables in main().
*sum = tempSum;
*average = tempAverage;
*standardDeviation = tempStandardDeviation;
}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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97