[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

批处理脚本实现C语言趣味编程百例010:进制转换

要求用BAT脚本实现:数制转换将任一整数转换为二进制形式

加分:1个技术分或者10个PB

*问题分析与算法设计
将十进制整数转换为二进制的方法很多,这里介绍的实现方法利用了C语言能够对位进行操作的特点。对于C语言来说,一个整数在计算机内就是以二进制的形式存储的,所以没有必要再将一个整数经过一系列的运算转换为二进制形式,只要将整数在内存中的二进制表示输出即可。

*程序说明与注释
  1. #include<stdio.h>
  2. void printb(int,int);
  3. int main()
  4. {
  5. int x;printf("Input number:");
  6. scanf("%d",&x);
  7. printf("number of decimal form:%d\n",x);
  8. printf(" it's binary form:");
  9. printb(x,sizeof(int)*8); /*x:整数 sizeof(int):int型在内存中所占的字节数
  10. sizeof(int)*8:int型对应的位数*/
  11. putchar('\n');
  12. }
  13. void printb(int x,int n)
  14. {
  15. if(n>0)
  16. {
  17. putchar('0'+((unsigned)(x&(1<<(n-1)))>>(n-1))); /*输出第n位*/
  18. printb(x,n-1); /*归调用,输出x的后n-1位*/
  19. }
  20. }
复制代码
*运行结果
输入:8
输出:
number of decimal form:8
it's bunary form:0000000000001000
输入:-8
输出:number of decimal form:-8
it's binary form:1111111111111000
输入:32767
输出:number of decimal form:32767
it's binary form:0111111111111111
输入:-32768
输出:number of decimal form:-32768
it's binary form:1000000000000000
输入:128
输出:number of decimal form:128
it's binary form:0000000010000000

*问题的进一步讨论
充分利用C语言可以对位进行操作的特点,可以编写许多其它高级语言不便于编写甚至根本无法编写的程序。位操作是C语言的一大特点,在深入学习C语言的过程中应力求很好掌握。
程序中使用的位运算方法不是最佳的,也可以不用递归操作,大家可以自行对程序进行优化。

*思考题
将任意正整数转换为四进制或八进制数

返回列表