解题思路:
内存操作;
注意事项:
不要越界;
参考代码:
#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++代码)浏览:1155 |
Cylinder (C语言描述,蓝桥杯)浏览:1258 |
简单的a+b (C语言代码)浏览:553 |
程序员的表白 (C语言代码)浏览:616 |
整除的尾数 (C语言代码)浏览:820 |
筛排处理 (C语言代码)浏览:799 |
C语言程序设计教程(第三版)课后习题5.5 (C语言代码)浏览:830 |
A+B for Input-Output Practice (I) (C语言代码)浏览:586 |
C语言程序设计教程(第三版)课后习题11.8 (C语言代码)浏览:1022 |
C语言程序设计教程(第三版)课后习题6.7 (C语言代码)浏览:718 |