zoukankan      html  css  js  c++  java
  • P1100 高低位交换

    P1100 高低位交换

    题目描述

    给出一个小于2^32的正整数。这个数可以用一个32位的二进制数表示(不足32位用0补足)。我们称这个二进制数的前16位为“高位”,后16位为“低位”。将它的高低位交换,我们可以得到一个新的数。试问这个新的数是多少(用十进制表示)
    例如,数1314520用二进制表示为0000 0000 0001 0100 0000 1110 1101 1000(添加了11个前导0补足为32位),其中前16位为高位,即0000 0000 0001 0100;后16位为低位,即0000 1110 1101 1000。将它的高低位进行交换,我们得到了一个新的二进制数0000 1110 1101 1000 0000 0000 0001 0100。它即是十进制的249036820。

    输入

    一个小于2^32的正整数N

    输出

    高低位交换后的正整数

    样例输入

    1314520
    

    样例输出

    249036820


     分析:

    使用位运算即可轻松解决,题目描述中的二进制,高低位交换等都指向了移位运算符<<和>>

    右移运算符>>

    假设x=6,那么x的二进制为0110,x>>1表示x右移1位,即把最右边一位的0删掉,变为0112,此时x=210
    x>>=1等价于x=x>>1,跟x+=1等价于x=x+1是一个道理
    x/=2 等价于 x>>=1(x>0) 但要比除法效率高

    左移运算符<<

    与右移运算符正好相反,同理,对于正数来说,左移1相当于*2(但效率比乘法高

    代码

    提示:%u是十进制无符号整型数输入或输出

    #include <iostream>
    #include <cstdio>
    using namespace std;
    int main(){
        int n;
        scanf("%u",&n); 
        printf("%u",(n>>16)+(n<<16));
        return 0;
    }

  • 相关阅读:
    itoa
    sprintf用法 [转载]
    atoi 与 itoa的实现
    数组排序总结(冒泡,选择,插入,希尔)
    XML入门精解之文件格式定义(DTD)
    malloc()函数的工作机制 结构体的总结
    字符串指针与字符数组(ZT)
    sprintf函数你了解有多深!
    sprintf
    sql ldr 笔记
  • 原文地址:https://www.cnblogs.com/AK-IOI/p/12843845.html
Copyright © 2011-2022 走看看