02進制轉換
寫一段程序完成二進制、八進制、十進制、十六進制之間的轉換。 16進制10-15用ABCDEF表示
輸入
三個數值:起始進制,轉換後的進制,需要被轉換的數。
輸出
轉換之後的數。
例如:
輸入10 2 17
輸出 10001
輸入 2 16 10001
輸出 11
這道題當時想的是用%o%d%X分別輸入和輸出八進制,十進制和十六進制,然後二進制單獨寫一下就好。但是不知道爲啥有三個用例死活過不去,後來就不偷懶了,直接寫了一發任意進制的轉換順便,不過16進制的輸入和輸出需要加一個if語句,來輸出字母。
//2,8,10,16
#include<stdio.h>
#include<string.h>
#define maxn 10005
char num[maxn];
int exchange0(int x)
{
int ans=0;
int length,k=1;
length = strlen(num);
while (length--)
{
if (num[length] >= 'A'&&num[length] <= 'E')
num[length] =num[length]- 'A' + 10;
else num[length] -= '0';
ans += k*num[length];
k *= x;
}
return ans;
}
void exchange1(int x,int a)//a是十進制數字,x是進制
{
int k=0,bit[100];
while (a)
{
bit[k++] = a%x;
a = a / x;
}
while (k--)
{
if (bit[k] >= 10 && bit[k] <= 15)
printf("%c", bit[k] - 10 + 'A');
else printf("%d", bit[k]);
}
printf("\n");
return;
}
int main()
{
int st, ans, ed;//wtf是將二進制先用十進制存
while (scanf("%d%d", &st, &ed) != EOF)
{
scanf("%s", num);
ans = exchange0(st);
exchange1(ed, ans);
}
}