解题思路: 注意事项: 参考代码: #include<stdio.h> #include<math.h> void move(unsigned int value,int n) { unsigned int sum = 0; int num[32] = { 0 }, num1[32] = { 0 }, i = 0, j = 0; while (value) { num1[i] = value % 2; value = value / 2; //将value进行二进制转换,再逆序存储在数组中 i++; } for (i = 0; i < 32; i++) { j = i - n; if (j < 0) j += 32; //进行移位操作,如果相减之后的下表小于0,则加32; if (j >= 32) //如果大于等于32,则减去32; j -= 32; num[j] = num1[i]; } for (i = 0; i < 32; i++) { sum = sum + pow(2.0, i)*num[i]; } //输出结果 (注意:本解析中的数组均为逆序存储) printf("%u\n", sum); } int main() { unsigned int value; int n = 0; scanf("%u %d", &value,&n); //输入value ,n move(value, n); //调用移位函数 return 0; }
0.0分
1 人评分
奖学金 (C++代码)浏览:2005 |
C语言训练-最大数问题 (C语言代码)浏览:633 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:509 |
买不到的数目 (C++代码)浏览:865 |
WU-整数平均值 (C++代码)浏览:1240 |
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:672 |
C语言程序设计教程(第三版)课后习题9.4 (C语言代码)浏览:636 |
妹子杀手的故事 (C语言代码)浏览:1050 |
整数平均值 (C语言代码)浏览:782 |
C语言程序设计教程(第三版)课后习题6.2 (C语言代码)浏览:462 |