解题思路:
内存操作;
注意事项:
不要越界;
参考代码:
#include<iostream> #include<stdlib.h> #include<cstring> using namespace std; int main() { int m, n; cin >> n;//赋值 int *p = (int *)malloc(sizeof(int) * n);//开辟内存 int *p1 = (int *)malloc(sizeof(int) * n);//开辟内存 if(p == NULL || p1 == NULL)//检查是否开辟成功 return 1; for(m = 0; m < n; m++){ cin >> *(p+m);//赋值 } cin >> m;//赋值 memcpy(p1, p + n - m, sizeof(int) * m);//将p尾部要调换的copy到p1头部 memcpy(p1 + m, p, sizeof(int) * (n - m));//将p头部要调换的copy到p1尾部 for(m = 0; m < n; m++){ cout << *(p1 + m) << ' ';//输出 } cout << endl; free(p);//释放资源 free(p1);//释放资源 return 0; }
0.0分
1 人评分