c 语言转换成php语言,c语言如何实现任意进制间的转换

C语言实现任意进制间的转换可以以十进制为基准,先将需要转换的数字转换成十进制然后再将其转换成目标进制数,这样就实现了任意进制间的转换。

在C语言中我们可以实现任意进制的转换,接下来在文章中将分享如何实现C语言中的进制转化,具有一定的参考价值,希望对大家有所帮助

52c58b7b51c615732955eeee743442ec.png

【推荐课程:C语言教程】

实现任意进制间的转换思路:

以十进制数为基准,先将需要转换的数转换成十进制数,再将其转换成目标进制数

首先将涉及大于十进制的转换的数挑出来,利用ASCALL码将字符转换成整型或将整型转换成字符

以取余的方式,将十进制数转换成其他进制数,再按照按权展开的方式,将其他进制数转换成十进制数

541a2a2ed947e54012b8421a6517be5d.png

代码如下:#include

#include

#include

#include

#include

#define N 50

//进制转换

char * Ten_MoreThanTen(int, int); //10进制数转换成10以上进制数的函数

int MoreThanTen_Ten(int, char []); //10以上进制数转换成10进制数的函数

int Ten_LessThanTen(int, int); //10进制数转换成10以内进制数的函数

int LessThanTen_Ten(int, int); //10以内进制数转换成10进制数的函数

char array[N] = "\0"; //全局变量,用于存储转换后并且倒置了的数据

int LessThanTen_Ten(int before, int num) //10以内转换10,参数brfore为初始进制,num为初始数值

{

double result = 0.0; //转换成10进制后的结果

int i = 0;

for(i = 0; num != 0; i++) //利用for循环实现按权展开相加

{

result += pow(before, i) * (num % 10);

num /= 10;

}

return (int)result; //返回值为转换后的结果

}

int Ten_LessThanTen(int after, int num) //10转换10以内,参数after为转换后的进制,num为10进制数值

{

double result = 0.0; //double类型因为pow函数的返回值为double类型

int i = 0;

for(i = 0; num != 0; i++) //利用for循环实现连续取余

{

result += (num % after) * pow(10, i);

num /= after;

}

return (int)result;

}

int MoreThanTen_Ten(int before, char num[]) //10以上转换10

{

int i = 0;

double result = 0.0;

int length = strlen(num);

for(i = length - 1; i >= 0; i--)

{

//利用ASCALL码将所有元素转换成对应的整型

if('A' <= num[i] && num[i] <= 'Z')

result += pow(before, length - i - 1) * (num[i] - 55);

else if('a' <= num[i] && num[i] <= 'z')

result += pow(before, length - i - 1) * (num[i] - 87);

else if('0' <= num[i] && num[i] <= '9')

result += pow(before, length - i - 1) * (num[i] - 48);

}

return (int)result;

}

char * Ten_MoreThanTen(int after, int num) //10转换10以上

{

int i = 0;

int j = 0;

int tmp = 0; //存储每次余数的中间变量

char tmp_array[N] = "\0"; //转换后未倒置的数组

for(i = 0; num > 0; i++)

{

tmp = num % after;

if(tmp < 10) //对大于等于10的余数进行字母转换

tmp_array[i] = tmp + '0';

else

tmp_array[i] = tmp + 'A' - 10;

num /= after;

}

for(j = 0; i > 0; i--, j++) //倒置

{

array[j] = tmp_array[i - 1];

array[j + 1] = '\0';

}

return array; //输出转换后存储数据的字符串地址

}

int main()

{

int before = 0; //转换前的进制数

int after = 0; //转换后的进制数

int num1 = 0; //要转换的十进制以内的数

char array_num1[N] = "\0"; //要转换的十进制以上的数

int num2 = 0; //转换之后的数

char *str_num2; //转换之后的数的地址

int tmp_num1 = 0; //判断输入是否合法时代替num1的中间变量

int i = 0;

int m = 0; //计数器

while(1) //整个while语句用于录入以及判断输入是否合法

{

printf("初始进制:");

scanf("%d", &before);

printf("目标进制:");

scanf("%d", &after);

printf("初始数值:");

if(before > 10) //通过对初始进制判断,决定

scanf("%s", array_num1);

else

scanf("%d", &num1);

for(i = 0, tmp_num1 = num1; tmp_num1 != 0; i++)

{

if((tmp_num1 % 10) <= before && tmp_num1 % 10 >= 0 && tmp_num1 % 10 <= 9)

m++;

tmp_num1 /= 10;

}

if(m == i) //判断输入的数据每一位是否都小于等于进制数

break;

else

{

m = 0; //对计数器m重新初始化

fflush(stdin); //清空缓存区

printf("输入有误!请重新输入:\n");

}

}

//将进制转换的四种情况分别表示

if(before <= 10 && after <= 10)

{

num2 = Ten_LessThanTen(after, LessThanTen_Ten(before, num1));

printf("\n%d进制的%d对应的%d进制数为:%d\n", before, num1, after, num2);

}

else if(before > 10 && after <= 10)

{

num2 = Ten_LessThanTen(after, MoreThanTen_Ten(before, array_num1));

printf("\n%d进制的%s对应的%d进制数为:%d\n", before, array_num1, after, num2);

}

else if(before <= 10 && after > 10)

{

str_num2 = Ten_MoreThanTen(after, LessThanTen_Ten(before, num1));

printf("\n%d进制的%d对应的%d进制数为:%s\n", before, num1, after, str_num2);

}

else if(before > 10 && after > 10)

{

str_num2 = Ten_MoreThanTen(after, MoreThanTen_Ten(before, array_num1));

printf("\n%d进制的%s对应的%d进制数为:%s\n", before, array_num1, after, str_num2);

}

system("pause");

return 0;

}

运行结果:

24e58225d7b32a36b30efa82222ee4ae.png

总结:以上就是本篇文章的全部内容,希望对大家有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值