设为首页 加入收藏

TOP

C数制转换
2014-11-11 18:00:05 来源: 作者: 【 】 浏览:32
Tags:转换

  *问题分析与算法设计


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


  *程序说明与注释


  #include


  void printb(int,int);


  int main()


  {


  int x;printf("Input number:");


  scanf("%d",&x);


  printf("number of decimal form:%d\n",x);


  printf(" it's binary form:");


  printb(x,sizeof(int)*8); /*x:整数 sizeof(int):int型在内存中所占的字节数


  sizeof(int)*8:int型对应的位数*/


  putchar('\n');


  }


  void printb(int x,int n)


  {


  if(n>0)


  {


  putchar('0'+((unsigned)(x&(1<<(n-1)))>>(n-1))); /*输出第n位*/


  printb(x,n-1); /*归调用,输出x的后n-1位*/


  }


  }


  *运行结果


  输入: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语言的过程中应力求很好掌握。


  程序中使用的位运算方法不是最佳的,也可以不用递归操作,大家可以自行对程序进行优化。


  编辑特别推荐:


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Win32平台下如何安装Openssl及其.. 下一篇C数字移动

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: