解题思路:就是先将这个整数用二进制表示用一个数组(先初始化为0)存储,其实结果出来的二进制就是顺序反的,所以从右端开始就是num[4](假设用num[32]存储),至于第四位为什么下标是4而不是3,这个我真的不知道,我开始也是按3算的,但是我乘的时候把顺序搞反了,结果竟然恰好正确,然后提交就是错的,从第四位开始到第七位,注意这时候数码顺序是反的,所以第七位才是最高位,也就是num[7]
注意事项:
参考代码:
#include <stdio.h>
int main()
{
int n,i,result;
int num[32]={0};
scanf("%d",&n);
i=0;
do{
num[i++]=n%2;
n/=2;
}while(n>0);
result=num[4]+num[5]*2+num[6]*4+num[7]*8;
printf("%d\n",result);
}
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:566 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:1121 |
C语言程序设计教程(第三版)课后习题9.8 (Java代码)浏览:1640 |
C语言训练-求1+2!+3!+...+N!的和 (C语言代码)浏览:788 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:1162 |
众数问题 (C语言代码)浏览:830 |
【蟠桃记】 (C语言代码)浏览:1033 |
C语言程序设计教程(第三版)课后习题9.1 (C语言代码)浏览:681 |
K-进制数 (C语言描述,蓝桥杯)浏览:925 |
数对 (C语言代码)浏览:702 |