刷刷题,找找感觉;
有n个整数,使前面各数顺序向后移m个位置,最后m个数变成前面m个数。写一函数:实现以上功能,在主函数中输入n个数和输出调整后的n个数。
输入
输入数据的个数n n个整数 移动的位置m
输出
移动后的n个数
样例输入
10
1 2 3 4 5 6 7 8 9 10
2
样例输出
9 10 1 2 3 4 5 6 7 8
#include <stdio.h>
#include <malloc.h>
//清除可能多余的输入
void handleNums(int *p,int *q,int n,int m);
int main (){
int n;
int m;
int a[n];
int b[n];
int *p= a; //数组a[n]的首地址给p
int *q= b; //数组b[n]的首地址给p
scanf( "%d",&n); //获取一共要输入n个数字
p=(int *)malloc(sizeof(int)*n); //给数组a分配n个int型占用的内存空间
q=(int *)malloc(sizeof(int)*n); //给数组b分配n个int型占用的内存空间
//获取n个输入
for (int i=0;i<n;i++){
scanf("%d",(p+i));
}
scanf( "%d",&m); //获取移动的位数
handleNums(p,q,n,m);
for (int i=0;i<n;i++){
printf("%d ",*(q+i));
}
return 0;
}
void handleNums(int *p,int *q,int n,int m){
for (int i=0;i<n;i++){
*(q+i) = *(p+((n-m+i)%n)); //核心代码
}
}
同时说下malloc函数,自己也算是写个笔记:
int *p;
p = (int *)malloc(sizeof(int));
malloc需要我们自己计算字节数,并且返回的时候要强转成指定类型的指针。
-
malloc的返回是void*,如果我们写成了:p=malloc(sizeof(int));间接的说明了将void转化给了int*,这不合理,所以我加了强制类型转换。
-
malloc的实参是sizeof(int),用于指明一个整型数据需要的大小,如果我们写成p=(int*)malloc(1),那么可以看出:只是申请了一个一个字节大小的空间。
-
malloc只管分配内存,并不能对其进行初始化,所以得到的一片新内存中,其值将是随机的。一般意义上:我们习惯性的将其初始化为NULL,当然也可以使用memset函数。
总结:
malloc函数其实就是在内存中找一片指定大小的空间,然后将这个空间的首地址给一个指针变量,这里的指针变量可以是一个单独的指针,也可以是一个数组的首地址.。
这要看malloc函数中参数size的具体内容,我们这里malloc分配的内存空间在逻辑上是连续的,而在物理上可以不连续。
参考链接:
https://blog.csdn.net/flowing_wind/article/details/81240910