有n个整数,使前面各数顺序向后(向左)移m个位置,最后m个数变成前面m个数。要求:用C++实现,头文件使用iostream。
时间: 2023-08-31 08:05:46 浏览: 87
Java for combinatorial number algorithm.zip_4MJN_M?n_enterbl4_组合
以下是一种简单的实现方式:
```
#include <iostream>
using namespace std;
int main() {
int n, m;
cout << "请输入n和m:" << endl;
cin >> n >> m;
int arr[n];
cout << "请依次输入" << n << "个整数:" << endl;
for (int i = 0; i < n; i++) {
cin >> arr[i];
}
// 将前面的m个数移到数组末尾
int temp[m];
for (int i = 0; i < m; i++) {
temp[i] = arr[i];
}
for (int i = m; i < n; i++) {
arr[i - m] = arr[i];
}
for (int i = 0; i < m; i++) {
arr[n - m + i] = temp[i];
}
cout << "移动后的数组为:" << endl;
for (int i = 0; i < n; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
```
这个程序首先让用户输入n和m,然后依次输入n个整数。接着,它将前面的m个数移到数组末尾,最后输出移动后的数组。需要注意的是,这里使用了一个长度为m的临时数组temp来保存前面的m个数,以便后面移动数组元素时不会被覆盖。
阅读全文