十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
函数功能:将输入字符串 src循环右移n位 result为输出结果
成都创新互联主营兰考网站建设的网络公司,主营网站建设方案,app软件定制开发,兰考h5小程序制作搭建,兰考网站营销推广欢迎兰考等地区企业咨询
要求:以效率最高的方式实现
示例:
“abcde” --2-- "deabc"
"abcde"--8--"cdeab"
void right_shift_r(const char* src,char* result,unsigned int n)
{
unsigned int len = strlen(src);
int i=0;
for(i=0;ilen;i++)
{
result[i] = src[i+n]%len;
}
}
先说第一个问题:
比如用查表法将结果保存到变量i中,查表变量为x,则i=table[x],记住c语言里面数组是从0开始的,比如说上面的0x01就是table[0],0x02是table[1],以此类推。
再说第二个问题:
比如说从p1.0口发送出去,则可以写为
sbitout=p1^0;//定义out为p1.0口,这样今后好写程序
chari;
for(i=0;i8;i++)
{
out=data0x80;//因为高位在前,将它写成二进制就明白了
data=1;
}
上面的程序就能搞定了;
应该是所有的单片机都有cy位(不知道浮点dsp有没有);
c语言中左移和右移之后低位或高位自动补零,cy位也保持为零(视编译器而定,这个得看编译器手册),有些编译器提供了循环移位的函数;
还有什么不明白的补充问题就是
代码文本:
#include "stdio.h"
int myfun(int m,int n){//十进制循环右移
int tmp,i;
for(tmp=m,i=0;tmp;i++,tmp/=10);
if((n%=i)0) n+=i;
for(tmp=i-n,i=1;tmp;i*=10,tmp--);
for(tmp=n,n=1;tmp;n*=10,tmp--);
return m%n*i+m/n;
}
int main(int argc,char *argv[]){
int n,m;
printf("Please enter n m(int 0n,m1000000000)...\n");
scanf("%d%d",n,m);
printf("你输入的数是: %d\n",n);
printf("右移%d位后是: %d\n",m,myfun(n,m));
return 0;
}
当然不可以。
xx[i][j]+=(xx[i][j]4)等价于
xx[i][j]=xx[i][j]+(xx[i][j]4); 是右移4位,换算成二进制计算相当于乘以2的4次方。
默认只有算术右移。 要循环右移需要把最低位保存下来, 然后赋值到最左。
unsigned int func(unsigned int n)
{
unsigned int v=n1;
n=1;
if(v) n|=1(sizeof(unsigned int)-1);
return n;
}
C语言总并没有左移函数和右移函数。左移和右移是位运算符,仅仅适用于整数型的数据。