-
Notifications
You must be signed in to change notification settings - Fork 0
/
problem4.c
49 lines (38 loc) · 900 Bytes
/
problem4.c
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
#include <stdio.h>
#include <math.h>
int checkPalindrome(int x);
int reverseNumber(int x);
int main() {
int largestNumber = 0;
int x;
int i;
int j;
for(i = 999; i > 100; i--) {
for(j = 999; j > 100; j--) {
x = i * j;
if (checkPalindrome(x) == 1) {
if (x > largestNumber) {
largestNumber = x;
}
}
}
}
printf("%d", largestNumber);
}
int checkPalindrome(int x) {
if (x != reverseNumber(x)) {
return 0;
}
return 1;
}
int reverseNumber(int x) {
int buffer = 0;
int digit = 0;
int placements = floor(log10(x)) + 1;
int i;
for(i = 0; i < placements; i++) {
digit = (x - (floor(x / pow(10, i+1)) * pow(10, i+1) + digit)) / pow(10, i);
buffer += digit * pow(10, placements - (i+1));
}
return buffer;
}