update 3 to the right solution

This commit is contained in:
juan 2021-10-12 20:24:51 +08:00
parent 38a17714e4
commit dbff279288
No known key found for this signature in database
GPG key ID: 5C1E5093C74F1DC7
2 changed files with 23 additions and 43 deletions

View file

@ -1,27 +0,0 @@
// Try to use recursion to solve this problem.
#include <stdio.h>
// function prototypes.
unsigned long long int sum(unsigned long long int n);
int main(void) {
// Initialize variables and get input from user.
unsigned long long int num;
scanf("%lld", &num);
// Print values
printf("%lld\n", sum(num));
return 0;
}
unsigned long long int sum(unsigned long long int n) {
if (n == 1 || n == 2) { // Case 1: n is 1 or 2
return 0;
} else { // Case 2: n is not
return n * (n - 1) * (n - 2) + sum(n - 1);
}
}

View file

@ -1,24 +1,31 @@
// Try to use recursion to solve this problem.
#include <stdio.h> #include <stdio.h>
// function prototypes.
unsigned long long int sum(unsigned long long int n);
int main(void) { int main(void) {
// Initialize variables and get input
long long sum = 0;
long long n;
scanf("%lld", &n);
// if n is smaller than 3 // Initialize variables and get input from user.
if (n < 3) { unsigned long long int num;
printf("0\n"); scanf("%lld", &num);
// Calculate the sum of the numbers. (Can be optimized.)
unsigned long long int num1 = 0;
for (int i = 1; i <= num; i++) {
num1 += sum(i);
}
printf("%lld\n", num1);
return 0; return 0;
} }
// Iterate through all unsigned long long int sum(unsigned long long int n) {
for (long long i = 3; i <= n; i++) { if (n == 1 || n == 2) { // Case 1: n is 1 or 2
sum += i * (i - 1) * (i - 2);
}
// Print the result
printf("%lld\n", sum);
return 0; return 0;
} else { // Case 2: n is not
return n * (n - 1) * (n - 2) + sum(n - 1);
} }
}