十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
问题在ArrayShift函数中的2个for循环中j的值都没有递增,可以在i++后面加个:
创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、网站建设、扎赉诺尔网络推广、小程序制作、扎赉诺尔网络营销、扎赉诺尔企业策划、扎赉诺尔品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联为所有大学生创业者提供扎赉诺尔建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com
,j++
或者
第一个for里改成:a[j++]=a[i];
第二个for里改成:a[i]=a[j++];
默认只有算术右移。 要循环右移需要把最低位保存下来, 然后赋值到最左。
unsigned int func(unsigned int n)
{
unsigned int v=n1;
n=1;
if(v) n|=1(sizeof(unsigned int)-1);
return n;
}
代码文本:
#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;
}
#include stdio.h
void move(int *a,int*b,int n)
{
for(int i=0,j=9;i!=10;++i,--j)
{
b[(a[j]+n)%10]=a[j];
}
printf("移动后:\n");
for(int k=0;k!=10;++k)
printf("%d ",b[k]);
}
int main()
{
int a[10]={0,1,2,3,4,5,6,7,8,9};
int b[10]={0};
int n;
printf("输入移动位置数:\n");
scanf("%d",n);
move(a,b,n);
return 0;
}
扩展资料:
数组使用规则:
1.可以只给部分元素赋初值。当{ }中值的个数少于元素个数时,只给前面部分元素赋值。例如:static int a[10]={0,1,2,3,4};表示只给a[0]~a[4]5个元素赋值,而后5个元素自动赋0值。
2.只能给元素逐个赋值,不能给数组整体赋值。例如给十个元素全部赋1值,只能写为:static int a[10]={1,1,1,1,1,1,1,1,1,1};而不能写为:static int a[10]=1;请注意:在C、C#语言中是这样,但并非在所有涉及数组的地方都这样,数据库是从1开始。
3.如不给可初始化的数组赋初值,则全部元素均为0值。
4.如给全部元素赋值,则在数组说明中, 可以不给出数组元素的个数。例如:static int a[5]={1,2,3,4,5};可写为:static int a[]={1,2,3,4,5};动态赋值可以在程序执行过程中,对数组作动态赋值。这时可用循环语句配合scanf函数逐个对数组元素赋值。
参考资料:
百度百科-数组
比如数组a[20]可以先 t=a[19]; for(i=18;i=0;i++); a[i+1]=a[i]; a[1]=t;都右移了一个,最后的到最前面了。
#include stdio.h
int data[10] ; 声明要移位的数组
void Init_data() 初始化数据内的数据。
{
int i;
for(i= 0;i 10;i++)
{
data[i] = i;
}
}
void move() 将数组的数据右移一位
{
int temp;
int i;
temp = data[9];
for (i = 9;i 0 ;i--)
{
data[i] = data[i-1];
}
data[0] = temp;
}
void main()
{
int i,n;
scanf("右移的位数%d",d);
for( i= 0;i n; i++)
{
move();
}
}