c语言左移一位
❶ c语言如何输入一个整数,将整数整体左移1位,且第一位移动到最后一位,输出.如输入“1234”,输出“2341”
#include <stdio.h>
int main(int argc, char** argv)
{
char stack[4];
int top = 0;
while (top < 4)
{
stack[top++] = getchar();
}
getchar(); // 读取回车
while (top > 0)
{
putchar(stack[--top]);
}
putchar(‘\n’);
return 0;
}上面这个是直接把输入的4个字符串倒序输出,跟整数不整数没有关系,你们老师的意思可能是这个:#include <stdio.h>
int main(int argc, char** argv)
{
int integer;
int ret;
scanf(“%d”, &integer);
while (integer != 0)
{
ret = ret * 10 + integer % 10;
integer = integer / 10;
}
printf(“%d\n”, ret);
return 0;
}
❷ C语言按位左移运算规则
C语言中按位左移的运算符为<<,其规则如下:
对于操作a<<n,
1 按照二进制值每位向高位(书写上是向左)移动n位;
2 最高位(最左边的)n位舍去;
3 最低位(最右边)填加n个0.
简单起见,用char型举例如下:
例一
0x12 << 3 =>
B00010010 << 3 =>
B10010 000(这里最高位的三个0被舍去,其它依次左移,最低位补三个0) =>
0x90
即0x12 << 3 = 0x90
例二
0x9E << 2 =>
B10011110 << 2 =>
B01111000 (最高位10舍去,最低位补两个0)=>
0x78
可以编写如下程序验证:
#include<stdio.h>
voidcheck(chara,intn)
{
printf("0x%hhx<<%d=0x%hhx ",a,n,a<<n);
}
intmain()
{
check(0x12,3);
check(0x9e,2);
return0;
}
其运行结果为
0x12<<3=0x90
0x9e<<2=0x78
可以看到与我们计算结果是相符的。
❸ 如何用c语言实现循环左移
循环左移时,用从左边移出的位填充字的右端,而循环右移时,用从右边移出的位填充字的左侧。这种情况在系统程序中时有使用,在一些控制程序中用得也不少。设有数据说明:
a=01111011,循环左移2位 正确结果: 11101101
过程:
b=a>>(8-2) 用来得到正常左移丢失的位和循环移位后其正确位置 b=00000001;
a=a<<2;左移 a=11101100
a=a|b; a=11101101
如果不是用中间变量 a=(a>>(8-2))|(a<<2)
总长度N(8 16 32)
循环左移n: (a>>(N-n))|(a>>n)
循环右移n: (a<<(N-n))|(a>>n)
C语言的位运算功能是其区别于其他大多数高级程序设计语言的特色之一,用它可以方便实现一些特殊功能,灵活掌握是用C程序编写系统程序的基础。
(3)c语言左移一位扩展阅读:
C语言高效编程技巧:
一:以空间换时间
计算机程序中最大的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考虑程序的效率问题
二:数学方法解决问题
数学是计算机之母,没有数学的依据和基础,就没有计算机发展,所以在编写程序的时候,采用一些数学方法会对程序的执行效率有数量级的提高。
三:使用位操作
实现高效的C语言编写的第三招----使用位操作,减少除法和取模的运算。
在计算机程序中,数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作。一般的位操作是用来控制硬件的,或者做数据变换使用,但是,灵活的位操作可以有效提高程序运行的效率。
❹ c语言左移和右移怎么算
左移一位就是*2;
右移一位就是/2;(忽略小数);
❺ c语言中位运算的左位移右位移都是什么意思
假设0010
左移就是把二进制数向左移动,右边补0,0的二进制全是0,左移之后右边再补0。
0010<<2 就是1000 实际是做的*4。
1000>>2 计算 0010 实际做的是/4。
❻ C语言中移位运算
右移对符号位的处理和左移不同,对于有符号整数来说,比如int类型,右移会保持符号位不变,例如:10100110 >>5(假设字长为8位),则得到的是 11111101。
总之,在C中,左移是逻辑/算术左移(两者完全相同),右移是算术右移,会保持符号位不变.实际应用中可以根据情况用左/右移做快速的乘/除运算,这样会比循环效率高很多.
所以,short a=0xf245,即a=1111001001000101,经过右移后,b=a>>8;b=1111111111110010,即b=0xfff2。注意是有符号右移为算术右移!!!
❼ c语言数组左移
a数组某个下标的元素左移8位,再和0X00ff或运算,把结果赋值给c数组同下边的元素
❽ c语言左移问题
但左移概念是左边去掉n个二进制位,右边补n个零,但这是指原来的二进制数是“机器数”。就是如果使用unsigned char 来存储这个数的话,就是这样的。
例如:0001 0010(十进制为18)左移4位,
得到的应该是0010 0000(十进制32),但是18*16≡32(模256)
当左移左边不去零,右边单纯补零的时候得到0001 0010 0000,这时候得到的恰好是
288=18*16,但这只是单纯往左移了(“丢失”了移出的4位)
如果仍是存储在unsigned char 中的话,就仍是0010 0000(十进制32)
用左移的时候194<<4,是1100 0010 0000,若仍是存储在unsigned char 中的话,就仍是0010 0000,这就是溢出了。