swap函数数组逆序排列c++
时间: 2024-06-14 10:07:08 浏览: 82
以下是使用swap函数进行数组逆序排列的C++代码示例:
```cpp
#include <iostream>
using namespace std;
const int N = 10002;
void swapArray(int a[], int n) {
for (int i = 1; i <= n / 2; i++) {
swap(a[i], a[n + 1 - i]);
}
}
int main() {
int a[N], n;
cin >> n;
for (int i = 1; i <= n; i++) {
cin >> a[i];
}
swapArray(a, n);
for (int i = 1; i <= n; i++) {
cout << a[i] << " ";
}
return 0;
}
```
相关问题
设计一个函数模板,将一维数组 逆序
好的,下面是一个将一维数组逆序的函数模板:
```c++
template <typename T, size_t N>
void reverseArray(T (&arr)[N]) {
for (size_t i = 0; i < N / 2; ++i) {
std::swap(arr[i], arr[N - i - 1]);
}
}
```
这个函数模板接受一个一维数组的引用作为参数,使用 `std::swap` 函数将数组中的元素逆序排列。由于数组的大小是在编译时就确定的,因此我们可以使用模板的非类型参数 `N` 表示数组的大小。
将数组中的数逆序排放c++
在 C++ 中,如果你想要将数组中的元素逆序排列,你可以使用两层循环。这里是一个简单的示例:
```cpp
#include <iostream>
// 定义数组类型
int arr[5]; // 假设这是一个包含5个元素的整型数组
void reverseArray(int arr[], int size) {
for (int i = 0; i < size / 2; ++i) {
// 交换数组的第一个元素和最后一个元素,然后移动到内部
std::swap(arr[i], arr[size - 1 - i]);
}
}
int main() {
// 初始化数组
arr[0] = 1;
arr[1] = 2;
arr[2] = 3;
arr[3] = 4;
arr[4] = 5;
// 获取数组长度
int size = sizeof(arr) / sizeof(arr[0]);
// 逆序数组
reverseArray(arr, size);
// 输出逆序后的数组
for (int i = 0; i < size; ++i)
std::cout << arr[i] << " ";
return 0;
}
```
在这个例子中,`reverseArray` 函数接收数组和它的大小作为参数,通过遍历数组的一半并使用 `std::swap` 来交换对应的元素实现逆序。
阅读全文