数组循环右移c语言函数 数组循环右移 c语言
编一个c程序:将一维数组中元素向右环移N位
#includestdlib.h
创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、网站设计、弋江网络推广、重庆小程序开发、弋江网络营销、弋江企业策划、弋江品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联公司为所有大学生创业者提供弋江建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com
void
rightmove(
int
x[],
int
length
);
int
main(void)
{
int
a[10]={1,2,3,4,5,6,7,8,9,0};
int
count,n,len=10;
//
右移位数n,len不应该这样得到,我懒得算
printf("Input
n:\n");
scanf("%d",n);
for(count=0;
countn%10;
count++)
{
rightmove(
a,
len);
}
for(
count=0;
countlen;
count++
)
printf("%d
",
a[count]);
printf("\n");
//
注释掉的这2行是我调试用的,别管
//
rightmove(
a,
10);
//
printf("%d
%d",
*a,
n);
return
0;
}
void
rightmove(
int
x[],
int
length
)
{
int
*tmp=NULL,
i;
tmp=(int*)malloc(sizeof(int));
for(i=length-1;
i0;
i--)
{
*tmp=*(x+i);
*(x+i)=*(x+i-1);
*(x+i-1)=*tmp;
}
free(tmp);
tmp=NULL;
}
我不知道我理解的对不对,环移1位就是所有成员向右移动1位,最后1位到最前面来。
main函数就是用来测试的,函数rightmove就是把整形数组向右移动1位,形参是数组首地址和数组长度。
main函数输入N,rightmove循环N次。数组只有10个成员,你可以重新定义。
C语言编写程序,将一维数组中的元素向右循环移动N次
#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函数逐个对数组元素赋值。
参考资料:
百度百科-数组
C语言 数组 将一个整型数组中的元素循环向右移动一个位置 急急急急~~~马上就要交作业了~只要
比如数组a[20]可以先 t=a[19]; for(i=18;i=0;i++); a[i+1]=a[i]; a[1]=t;都右移了一个,最后的到最前面了。
C语言数组循环右移,代码和结果如下,请问大家哪里有错?
问题在ArrayShift函数中的2个for循环中j的值都没有递增,可以在i++后面加个:
,j++
或者
第一个for里改成:a[j++]=a[i];
第二个for里改成:a[i]=a[j++];
网站名称:数组循环右移c语言函数 数组循环右移 c语言
分享地址:http://pcwzsj.com/article/dojisjs.html