十进制 二进制互相转换代码


十进制转换为二进制代码

01 #include<iostream.h>
02  
03 char *ok(int n,char *b)
04 {
05     static int LEN=8*sizeof(int);
06     for(int i=LEN-1;i>=0;i--,n>>=1)
07         b[i]=(01&n)+'0';
08     b[LEN]='\0';
09     return b;
10 }
11  
12 void main()
13 {
14     int v[]={0,1,2,3,4,5,6,7,8,9};
15     char b[8*sizeof(int)+1];
16     int i=-1;
17     while(++i<10)
18         cout<<ok(v[i],b)<<endl;
19 }

二进制转为十进制

01 //C++ 二进制转为十进制,计算数组最后一个元素的下标值
02 #include<iostream>
03 using namespace std;
04  
05 //十进制转为二进制
06 char*__bit(int n,char*array,int size)
07 {
08     for(int i=size-1;i>=0;i--,n>>=1)
09         array[i]='0'+(1&n);
10     array[size]='\0';
11     return array;
12 }
13  
14 //二进制转为十进制(应用了查表法,本程序中的表是mask数组)
15 int __bit(char *array,int strlen,int *mask,int last_iterator)
16 {
17     int temp=0;
18     for(int i=strlen-1;i>=0;i--)
19         temp+=(1&(array[i]-'0'))*mask[last_iterator--];
20     return temp;
21 }
22  
23 void main()
24 {
25     //一个二进制数中:从右到左,第一位的权值是2的0次方=1,第二位是2的1次方=2,第三位是2的2次方=4,第四位是2的3次方=8,...
26     int mask[]={2048,1024,512,256,128,64,32,16,8,4,2,1};//这个数组有多少个元素就能求多少位的二进制为十进制,你可以将它向前扩展
27     int last_iterator=sizeof(mask)/4-1;//不管数组mask有多少个元素,这个语句可以计算出mask的最后一个元素的下标值
28     cout<<__bit("001",strlen("001"),mask,last_iterator)<<endl;
29     cout<<__bit("010",strlen("010"),mask,last_iterator)<<endl;
30     cout<<__bit("011",strlen("011"),mask,last_iterator)<<endl;
31     cout<<__bit("100",strlen("100"),mask,last_iterator)<<endl;
32     cout<<__bit("101",strlen("101"),mask,last_iterator)<<endl;
33     cout<<__bit("110",strlen("110"),mask,last_iterator)<<endl;
34 }
35  
36 /*--
37 1
38 2
39 3
40 4
41 5
42 6
43 Press any key to continue
44 --*/

转载于:https://my.oschina.net/ypimgt/blog/101304

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值