C 任意进制转换程序

题目:编写一程序,实现任意10进制整数转换为任意进制的数

思路:利用数组存储各个位的值,再利用ascll码转换为字符。

程序:

#include<stdio.h>


void to_base_n(int n, int b);


int main()
{
int num, base;
printf("输入整数 和 要转换的进制(输入q退出):");
while (scanf("%d %d", &num, &base) == 2)
{
to_base_n(num, base);
printf("输入整数 和 要转换的进制(输入q退出):");
}
printf("bye!\n");
return 0;
}


void to_base_n(int n, int b)
{
char arr[32];
int i,j;
char temp;
if (n < 0)
{
arr[0] = '-';
n = -n;
}
else
{
arr[0] = ' ';
}
for (i = 1,j=0; n > 0; i++)
{
temp = n%b;
if (temp < 10)
{
arr[i] = temp + '0';
}
else
{
arr[i] = temp + '7';
}
n /= b;
j++;
}
printf("%d进制输出:",b);
putchar(arr[0]);
for (i = j; i >=1; i--)
putchar(arr[i]);
printf("\n");

}

结果:

输入整数 和 要转换的进制(输入q退出):123 2
2进制输出: 1111011
输入整数 和 要转换的进制(输入q退出):213 8
8进制输出: 325
输入整数 和 要转换的进制(输入q退出):213 16
16进制输出: D5
输入整数 和 要转换的进制(输入q退出):q
bye!
请按任意键继续. . .

发布了206 篇原创文章 · 获赞 18 · 访问量 7万+
展开阅读全文

进制转换任意进制的数字转换的算法,采用C语言怎么实现

01-23

Problem Description As we know , we always use the decimal system in our common life, even using the computer. If we want to calculate the value that 3 plus 9, we just import 3 and 9.after calculation of computer, we will get the result of 12. But after learning <<The Principle Of Computer>>,we know that the computer will do the calculation as the following steps: 1 computer change the 3 into binary formality like 11; 2 computer change the 9 into binary formality like 1001; 3 computer plus the two number and get the result 1100; 4 computer change the result into decimal formality like 12; 5 computer export the result; In the computer system there are other formalities to deal with the number such as hexadecimal. Now I will give several number with a kind of change method, for example, if I give you 1011(2), it means 1011 is a number in the binary system, and 123(10) means 123 if a number in the decimal system. Now I will give you some numbers with any kind of system, you guys should tell me the sum of the number in the decimal system. Input There will be several cases. The first line of each case contains one integers N, and N means there will be N numbers to import, then there will be N numbers at the next N lines, each line contains a number with such form : X1….Xn.(Y), and 0<=Xi<Y, 1<Y<=10. I promise you that the sum will not exceed the 100000000, and there will be at most 100 cases and the 0<N<=1000. Output There is only one line output case for each input case, which is the sum of all the number. The sum must be expressed using the decimal system. Sample Input 3 1(2) 2(3) 3(4) 4 11(10) 11(2) 11(3) 11(4) Sample Output 6 23 问答

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览