我本无心_


私信TA

用户名:huangbeiw

访问量:7214

签 名:

嗯嗯嗯嗯

等  级
排  名 1117
经  验 3073
参赛次数 0
文章发表 12
年  龄 22
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

解题思路:就是先将这个整数用二进制表示用一个数组(先初始化为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 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区