解题思路:
内存操作;
注意事项:
不要越界;
参考代码:
#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 人评分
C语言训练-求1+2!+3!+...+N!的和 (C语言代码)万恶的long long浏览:902 |
淘淘的名单 (C语言代码)浏览:1162 |
【简单计算】 (C语言代码)浏览:636 |
Wu-求圆的面积 (C++代码)浏览:1987 |
C语言程序设计教程(第三版)课后习题8.4 (C语言代码)浏览:623 |
矩阵加法 (C语言代码)浏览:1759 |
A+B for Input-Output Practice (VII) (C语言代码)浏览:564 |
1126题解浏览:643 |
C语言程序设计教程(第三版)课后习题11.5 (C语言代码)浏览:1490 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:564 |