c语言位循环移
① c语言问题——循环移位
#include"stdio.h"
intmain(intargc,char*argv[]){
unsigned亩燃inta,n,t;
printf("Inputa&n(inta,n>=0)... ");
if(scanf("%d%d",&a,&n)!=2||a<0||扒激n<0||n>32){
printf("Inputerror,exit... ");
return春耐袜0;
}
t=a>>n;
printf("Theresultis%u ",(a<<=(32-n))|=t);
return0;
}
运行样例:
② C语言 循环移位
save=x&0x……那一行,判慎你这是多少个字节了?0x表示16进制,每两个字面字符就是一个字节,即8位,你自己数数你的。取最低衫耐为应该是与0x00000001,四个字节,刚好掘塌敬32位。
③ C语言编写循环移位函数
//#include"stdafx.h"//vc++6.0加上这一行.
#include"stdio.h"
intmain(void){
intn,m;
unsignedx=1<<(sizeof(int)*8-1);
printf("Pleaseenteranoctalinteger... n=");
雹余scanf("%o",&n);
for(x>氏肆喊>=1,m=0;x;x>>=2)
(m*=2)+=(x&n||0);
printf("%o ",m);
歼野return0;
}
④ C语言 数组的循环移动
要求满足错误:
要求只用一个数组的方式实现,一定要保证在输出结果时,输出的顺序和数组中数的顺序是一致的。
#include<stdio.h>
intmain(){
int搜历颂array[100];
intm,n,i,j,tmp,distance;
scanf("%d%d",&n,&m);
for(i=0;i<n;++i)//输入
scanf("%d",&array[i]);
distance=n烂亩-m;//尾部要替换过去的值之间地址相距n-m个元素.
for(i=distance;i<n;++i){//循环移动,每次移动一个。
tmp=array[i-distance];
array[i-distance]=array[i];
for(j=i;j>i-distance;--j){
array[j]=array[j-1];
}
array[i-distance+1]=tmp;
}
for(i=0;i<n;++i){//输出
printf("%d",array[i]);
if(i!=n世郑-1)
printf("");
}
printf(" ");
return0;
}
⑤ C语言中的循环移位计算
因为是按8进制输入的,8进制的24换成10进制就是20,换成2进制就是00010100(以1字节表示)。而00010100循环右移2位后就是00000101,即10进制孝棚冲的5,而5按8进制输出(输出和腔格式为%o),就是5。
00010100循环左移2位后是01010000,用10进制表示就是80,而80按8进制输出(输巧歼出格式为%o),就是120。
⑥ 如何用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程序编写系统程序的基础。
(6)c语言位循环移扩展阅读:
C语言高效编程技巧:
一:以空间换时间
计算机程序中最大的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考虑程序的效率问题
二:数学方法解决问题
数学是计算机之母,没有数学的依据和基础,就没有计算机发展,所以在编写程序的时候,采用一些数学方法会对程序的执行效率有数量级的提高。
三:使用位操作
实现高效的C语言编写的第三招----使用位操作,减少除法和取模的运算。
在计算机程序中,数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作。一般的位操作是用来控制硬件的,或者做数据变换使用,但是,灵活的位操作可以有效提高程序运行的效率。