@H_
673_27@
#include <st
dio.h>
#include <stdlib.h>
#include <
String.h>
#define LEN 2000
char str[LEN],another[LEN];
int ten[LEN];
int switchToTen(
);
void switchToAnother(int k,
int n);
int main()
{
int m,n,k;
while (scanf("%d %d",&m,&n)
!= EOF)
{
scanf("
%s",str
);
k = switchToTen(m
);
switchToAnother(k,n
);
}
return 0;
}
int switchToTen(int m)
{
int i,j,len,k,
c;
//初始化
len = strlen(str
);
k = 1;
memset(ten,sizeof(ten)
);
//转换为10进制数
for (i = 0; i < len; i ++)
{
for (j = 0; j < k; j ++)
{
ten[j] *= m;
}
if (str[i] >= '0' && str[i] <= '9')
{
ten
[0] += str[i] - '0';
}else if (str[i] >= 'A' && str[i] <= 'Z')
{
ten
[0] += str[i] - 'A' + 10;
}else if (str[i] >= 'a' && str[i] <= 'z')
{
ten
[0] += str[i] - 'a' + 10;
}
for (j = c = 0; j < k; j ++)
{
ten[j] +=
c;
if (ten[j] >= 10)
{
c = ten[j] / 10;
ten[j] %= 10;
}else
{
c = 0;
}
}
while (
C) {
ten[k ++] = c % 10;
c /= 10;
}
}
//翻转数组
int temp;
for (i = 0,j = k - 1; i <
j; i ++,j --)
{
temp = ten[i];
ten[i] = ten[j];
ten[j] = temp;
}
return k;
}
void switchToAnother(int k,
int n)
{
int sum,i,r,t,d;
sum = 1;
r = 0;
memset(another,sizeof(another)
);
while (sum)
{
sum = 0;
for (i = 0; i < k; i ++)
{
d = ten[i] / n;
sum += d;
if (i == k - 1)
{
t = ten[i] % n;
if (t >= 0 && t <=
9) {
another[r] = t + '0';
}else
{
another[r] = t - 10 + 'a';
}
r ++;
}else
{
ten[i + 1] += ten[i] % n * 10;
}
ten[i] = d;
}
}
//打印是
输出
for (i = r - 1; i >= 0; i --)
{
printf("%c",another[i]
);
}
printf("\n"
);
}
@H_
673_27@
#include<st
dio.h>
#include<
String.h>
#include<stdlib.h>
void D_B(
int);
void D_O(
int);
void D_X(
int);
void B_D(
int);
void B_O(
int);
void B_X(
int);
void O_B(
int);
void O_D(
int);
void O_X(
int);
void X_B(char r[],int k
);
void X_D(char r[],int k
);
void X_O(char r[],int k
);
void main()
{
int i,k
=0;
int q;
char r[10];
printf("+=============================================================+\n"
);
printf("| 欢 迎 使 用 进 制 转 换 程 序 |\n"
);
printf("+=============================================================+\n"
);
printf(" 注 : 本 版 本 只 做 正 整 数 的 进 制 转 换 ! !"
);
do
{
q
=0;
//fflush(stdin
);
printf("\n请选择需要被转换的进制:\n0、
退出\n1、二进制\n2、八进制\n3、十进制\n4、十六进制\n"
);
scanf("%d",&i
);
switch (i)
{
case 1: printf("\n请选择转换后的进制:\n0、
退出\n1、二进制\n2、八进制\n3、十进制\n4、十六进制\n"
);
scanf("%d",&j
);
switch(j)
{
case 1: printf("\n同进制之间不用转化!\n"
);
q=1;
break;
case 2: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
B_O(k
);
q=1;
break;
case 3: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
B_D(k
);
q=1;
break;
case 4: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
B_X(k
);
q=1;
break;
case 0:
printf("谢谢使用!!"
);
}
break;
case 2: printf("\n请选择转换后的进制:\n0、
退出\n1、二进制\n2、八进制\n3、十进制\n4、十六进制\n"
);
scanf("%d",&j
);
switch(j)
{
case 2: printf("\n同进制之间不用转化!\n"
);
q=1;
break;
case 1: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
O_B(k
);
q=1;
break;
case 3: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
O_D(k
);
q=1;
break;
case 4: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
O_X(k
);
q=1;
break;
case 0:
printf("谢谢使用!!"
);
}
break;
case 3: printf("\n请选择转换后的进制:\n0、
退出\n1、二进制\n2、八进制\n3、十进制\n4、十六进制\n"
);
scanf("%d",&j
);
switch(j)
{
case 3: printf("\n同进制之间不用转化!\n"
);
q=1;
break;
case 1: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
D_B(k
);
q=1;
break;
case 2: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
D_O(k
);
q=1;
break;
case 4: printf("\n请输入您想要转化的数:"
);
scanf("%d",&k
);
D_X(k
);
q=1;
break;
case 0:
printf("谢谢使用!!"
);
}
break;
case 4: printf("\n请选择转换后的进制:\n0、
退出\n1、二进制\n2、八进制\n3、十进制\n4、十六进制\n"
);
scanf("%d",&j
);
switch(j)
{
case 4: printf("\n同进制之间不用转化!\n"
);
q=1;
break;
case 1: printf("\n请输入您想要转化的数:"
);
fflush(stdin
);
gets(r
);
for(k
=0;;k++)
{
if(r[k]=='\0')
break;
}
X_B(r,k
);
q=1;
break;
case 2: printf("\n请输入您想要转化的数:"
);
fflush(stdin
);
gets(r
);
for(k
=0;;k++)
{
if(r[k]=='\0')
break;
}
X_O(r,k
);
q=1;
break;
case 3: printf("\n请输入您想要转化的数:"
);
fflush(stdin
);
gets(r
);
for(k
=0;;k++)
{
if(r[k]=='\0')
break;
}
X_D(r,k
);
q=1;
break;
case 0:
printf("谢谢使用!!"
);
}
break;
case 0: printf("\n谢谢使用!\n"
);
}
}while(q==1
);
}
///////以下为: 二进制转换为十进制,八进制,十六进制.
void B_D(
int a)
{
int i,s
=0;
int result
=0;
for(i=1;a!
=0;i*=2)
{
if(a%10>1)
{
s=1;
break;
}
else
{
result+=(a%10)*i;
a=a/10;
}
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
printf("\n转换后的数为:%d\n",result
);
}
void B_O(
int a)
{
int i,s
=0;
int p[
30];
int result
=0;
for(i=1;a!
=0;i*=2)
{
if(a%10>1)
{
s=1;
break;
}
else
{
result+=(a%10)*i;
a=a/10;
}
}
for(j
=0;result!
=0;j++)
{
p[j]=result%8;
result=result/8;
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
{
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%d",p[k]
);
}
printf("\n"
);
}
}
void B_X(
int a)
{
int i,s
=0;
char p[
30];
int result
=0;
for(i=1;a!
=0;i*=2)
{
if(a%10>1)
{
s=1;
break;
}
else
{
result+=(a%10)*i;
a=a/10;
}
}
for(j
=0;result!
=0;j++)
{
p[j]=result%16;
result=result/16;
if (p[j]>10)
{
switch(p[j])
{
case 10: p[j]='A';
break;
case 11: p[j]='B';
break;
case 12: p[j]='C';
break;
case 13: p[j]='D';
break;
case 14: p[j]='E';
break;
case 15: p[j]='F';
break;
}
}
else p[j]+=48;
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
{
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%c",p[k]
);
}
printf("\n"
);
}
}
///////以下为: 八进制转换为二进制,十进制,十六进制.
void O_B(
int a)
{
int i,s
=0;
int result
=0;
int p[
30];
for(i=1;a!
=0;i*=8)
{if(a%10>7)
{
s=1;
break;
}
else
{
result+=(a%10)*i;
a=a/10;
}
}
for(j
=0;result!
=0;j++)
{
p[j]=result%2;
result=result/2;
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
{
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%d",p[k]
);
}
printf("\n"
);
}
}
void O_D(
int a)
{
int i,s
=0;
int result
=0;
for(i=1;a!
=0;i*=8)
{
if(a%10>7)
{
s=1;
break;
}
else
{
result+=(a%10)*i;
a=a/10;
}
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
{
printf("\n转换后的数为:%d\n",result
);
}
}
void O_X(
int a)
{
int i,s
=0;
char p[
30];
int result
=0;
for(i=1;a!
=0;i*=8)
{
if(a%10>7)
{
s=1;
break;
}
else
{
result+=(a%10)*i;
a=a/10;
}
}
for(j
=0;result!
=0;j++)
{
p[j]=result%16;
result=result/16;
if(p[j]<10)
p[j]+=48;
else
{
switch(p[j])
{
case 10: p[j]='A';
break;
case 11: p[j]='B';
break;
case 12: p[j]='C';
break;
case 13: p[j]='D';
break;
case 14: p[j]='E';
break;
case 15: p[j]='F';
break;
}
}
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
{
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%c",p[k]
);
}
printf("\n"
);
}
}
///////以下为: 十六进制转换为十进制,二进制,八进制.
void X_D(char a[],int k)
{
int i,s
=0;
int result
=0;
int b[
50];
for(i
=0;i<k;i++)
{
if(a[i]<='9'&&a[i]>='1')
{ b[i]=a[i]-48;
}
else
{
switch(a[i])
{
case 'A': b[i]=10;
break;
case 'B': b[i]=11;
break;
case 'C': b[i]=12;
break;
case 'D': b[i]=13;
break;
case 'E': b[i]=14;
break;
case 'F': b[i]=1
5;
break;
case 'a': b[i]=10;
break;
case 'b': b[i]=11;
break;
case 'c': b[i]=12;
break;
case 'd': b[i]=13;
break;
case 'e': b[i]=14;
break;
case 'f': b[i]=1
5;
break;
default: s=1;
}
}
}
for(i=1,j=k-1;j>
=0;j--,i*=16)
{
result+=b[j]*i;
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
{
printf("\n转换后的数为:%d",result
);
}
}
void X_B(char a[],s
=0;
int result
=0;
int b[
50];
int p[
30];
for(i
=0;i<k;i++)
{
if(a[i]<='9'&&a[i]>='1')
b[i]=a[i]-48;
else
{
switch(a[i])
{
case 'A': b[i]=10;
break;
case 'B': b[i]=11;
break;
case 'C': b[i]=12;
break;
case 'D': b[i]=13;
break;
case 'E': b[i]=14;
break;
case 'F': b[i]=1
5;
break;
case 'a': b[i]=10;
break;
case 'b': b[i]=11;
break;
case 'c': b[i]=12;
break;
case 'd': b[i]=13;
break;
case 'e': b[i]=14;
break;
case 'f': b[i]=1
5;
break;
default: s=1;
}
}
}
for(j=k-1,i=1;j>
=0;j--,i*=16)
{
result+=b[j]*i;
}
for(j
=0;result!
=0;j++)
{
p[j]=result%2;
result=result/2;
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
{
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%d",p[k]
);
}
printf("\n"
);
}
}
void X_O(char a[],s
=0;
int result
=0;
int b[
30];
int p[
30];
for(i
=0;i<k;i++)
{
if(a[i]<='9'&&a[i]>='1')
b[i]=a[i]-48;
else
{
switch(a[i])
{
case 'A': b[i]=10;
break;
case 'B': b[i]=11;
break;
case 'C': b[i]=12;
break;
case 'D': b[i]=13;
break;
case 'E': b[i]=14;
break;
case 'F': b[i]=1
5;
break;
case 'a': b[i]=10;
break;
case 'b': b[i]=11;
break;
case 'c': b[i]=12;
break;
case 'd': b[i]=13;
break;
case 'e': b[i]=14;
break;
case 'f': b[i]=1
5;
break;
default: s=1;
}
}
}
for(j=k-1,i*=16)
{
result+=b[j]*i;
}
for(j
=0;result!
=0;j++)
{
p[j]=result%8;
result=result/8;
}
if(s==1)
printf("您的输入有误!请重新输入\n"
);
else
{
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%d",p[k]
);
}
printf("\n"
);
}
}
///////以下为: 十进制转换为二进制,十六进制.
void D_B(
int a)
{
int j,k;
int p[
30];
for(j
=0;a!
=0;j++)
{
p[j]=a%2;
a=a/2;
}
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%d",p[k]
);
}
printf("\n"
);
}
void D_O(
int a)
{
int j,k;
int p[
30];
for(j
=0;a!
=0;j++)
{
p[j]=a%8;
a=a/8;
}
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%d",p[k]
);
}
printf("\n"
);
}
void D_X(
int a)
{
int j,k;
int p[
30];
for(j
=0;a!
=0;j++)
{
p[j]=a%16;
a=a/16;
if(p[j]<10)
p[j]+=48;
else
{
switch(p[j])
{
case 10: p[j]='A';
break;
case 11: p[j]='B';
break;
case 12: p[j]='C';
break;
case 13: p[j]='D';
break;
case 14: p[j]='E';
break;
case 15: p[j]='F';
break;
}
}
}
printf("\n转换后的数为:"
);
for(k=j-1;k>
=0;k--)
{
printf("%c",p[k]
);
}
printf("\n"
);
}