Archived
1
0
Fork 0
This repository has been archived on 2022-06-20. You can view files and clone it, but cannot push or open issues or pull requests.
mipt_clang/numbers/any.c
nihonium b541e00bad any
2022-02-20 17:32:35 +03:00

60 lines
999 B
C

#include <stdio.h>
#include <math.h>
#include <string.h>
int to_dec(char *s, int n);
void to_n(int x, int n, char *res);
void print_reverse(char *s);
int main() {
int n, k;
char A[1000];
char res[1000] = "";
scanf("%d\n%s\n%d", &n, A, &k);
if ((strlen(A) == 1) && (A[0] == '0')) {
printf("0\n");
return 0;
}
n = to_dec(A, n);
to_n(n, k, res);
print_reverse(res);
return 0;
}
void to_n(int x, int n, char *res) {
int a, b;
int i;
a = x;
for (i = 0; a > 0; ++i) {
b = a % n;
a = (int)(a / n);
if (b < 10) {
res[i] = '0' + b;
}
else {
res[i] = 'A' + b - 10;
}
}
res[i] = '\0';
}
int to_dec(char *s, int n) {
int len = strlen(s);
int res = 0;
for (int i = len - 1; i >= 0; --i) {
if (s[i] >= '0' && s[i] <= '9') {
res += (s[i] - '0') * pow(n, len-i-1);
}
else {
res += (s[i] - 'A' + 10) * pow(n, len-i-1);
}
}
return res;
}
void print_reverse(char *s) {
for (int i = strlen(s) - 1; i >= 0; --i) {
printf("%c", s[i]);
}
putchar('\n');
}