[OJ] 自定义函数之函数后移

刷刷题,找找感觉;

有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需要我们自己计算字节数,并且返回的时候要强转成指定类型的指针。

  1. malloc的返回是void*,如果我们写成了:p=malloc(sizeof(int));间接的说明了(将void转化给了int*,这不合理,,所以我加了强制类型转换)

  2. malloc的实参是sizeof(int),用于指明一个整型数据需要的大小,如果我们写成p=(int*)malloc(1),那么可以看出:只是申请了一个一个字节大小的空间。

  3. malloc只管分配内存,并不能对其进行初始化,所以得到的一片新内存中,其值将是随机的。一般意义上:我们习惯性的将其初始化为NULL,当然也可以使用memset函数。

总结:

malloc函数其实就是在内存中找一片指定大小的空间,然后将这个空间的首地址给一个指针变量,这里的指针变量可以是一个单独的指针,也可以是一个数组的首地址.。

这要看malloc函数中参数size的具体内容,我们这里malloc分配的内存空间在逻辑上是连续的,而在物理上可以不连续。

OVER!

参考链接:

https://blog.csdn.net/flowing_wind/article/details/81240910

原创文章 42 获赞 15 访问量 1万+

猜你喜欢

转载自blog.csdn.net/Codeliang666/article/details/104008634
OJ