标题:本人小白,求教一个华为机试的题目,用C++编程。
只看楼主
南哥syn
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2014-4-2
结帖率:0
已结贴  问题点数:20 回复次数:9 
本人小白,求教一个华为机试的题目,用C++编程。
输入一个0到255的十进制数,把它转化为8位二进制数,再将二进制数反转(最低位与最高位换、次低位与次高位换、依次类推),把反转后的二进制数再转化为十进制数并把该十进制数输出。
搜索更多相关主题的帖子: 二进制 十进制 华为 
2014-04-02 21:42
fl8962
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:14
帖 子:539
专家分:2471
注 册:2012-10-17
得分:7 
#include<iostream>
#include<string>
using namespace std;
int f(int j)
{
    int i;
     int sum=1;
    for(i=0;i<j;++i)
      sum=sum*2;
      return sum;
}
int main()
{
    int i,sum=0;
    cin>>i;
    int a[8];
     for(int j=0;j<8;++j)
       {
         a[j]=i/f(7-j);
         i=i%f(7-j);
        }
      for(int j=0;j!=4;j++)
       {
          i=a[j];
          a[j]=a[7-j];
          a[7-j]=i;
       }
       for(int j=0;j!=8;j++)
        {  
           sum=sum+(a[j]*f(7-j));
         }
        cout<<sum<<endl;
        return 0;
}

[ 本帖最后由 fl8962 于 2014-4-3 00:59 编辑 ]

想抽苏烟了。
2014-04-02 22:22
fl8962
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:14
帖 子:539
专家分:2471
注 册:2012-10-17
得分:0 
#include<iostream>
#include<string>
using namespace std;
int f(int j)
{
    int i;
     int sum=1;
    for(i=0;i<j;++i)
      sum=sum*2;
      return sum;
}
int main()
{
    int i,sum=0;
    cin>>i;
    int a[8];
     for(int j=0;j<8;++j)
       {
         a[j]=i/f(7-j);
         i=i%f(7-j);
        }
      for(int j=0;j!=4;j++)
       {
          i=a[j];
          a[j]=a[7-j];
          a[7-j]=i;
       }
       for(int j=0;j!=8;j++)
        {  
           sum=sum+(a[j]*f(7-j);
         }
        cout<<sum<<endl;
        return 0;
}

[ 本帖最后由 fl8962 于 2014-4-2 23:06 编辑 ]

想抽苏烟了。
2014-04-02 22:22
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:7 
程序代码:
#include <stdio.h>

unsigned char reverse8( unsigned char c )
{
    c = ( c & 0x55 ) << 1 | ( c & 0xAA ) >> 1;
    c = ( c & 0x33 ) << 2 | ( c & 0xCC ) >> 2;
    c = ( c & 0x0F ) << 4 | ( c & 0xF0 ) >> 4;
    return c;
}

int main()
{
    int n;
    scanf( "%d", &n );
    printf( "%d", (int)reverse8((unsigned char)n) );

    return 0;
}
2014-04-03 09:37
jcw08120110
Rank: 8Rank: 8
来 自:南京
等 级:蝙蝠侠
帖 子:272
专家分:742
注 册:2009-6-8
得分:7 
回复 4楼 rjsp
现在很少见到这种古老的运算方法了,真是好看!!~

君生我未生 我生君以老
2014-04-03 11:09
南哥syn
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2014-4-2
得分:0 
回复 2楼 fl8962
我用你的程序 编译了下 有一个错误啊
2014-04-03 15:43
南哥syn
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2014-4-2
得分:0 
回复 3楼 fl8962
  有个错误
2014-04-03 16:46
fl8962
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:14
帖 子:539
专家分:2471
注 册:2012-10-17
得分:0 
回复 7楼 南哥syn
第一个,第二个有点错误。或者你看r版的更好

想抽苏烟了。
2014-04-03 23:14
南哥syn
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2014-4-2
得分:0 
回复 8楼 fl8962
你写的那个  哪里有问题呢
2014-04-05 22:41
fl8962
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:14
帖 子:539
专家分:2471
注 册:2012-10-17
得分:0 
回复 9楼 南哥syn
第一个没有任何问题, 我测试过了。

想抽苏烟了。
2014-04-08 05:10



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-429593-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.304277 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved