本题要求实现一个函数,对数组下标为奇数的数据进行从小到大排序。
时间: 2024-08-13 10:05:51 浏览: 102
c++计算器代码 包含三角函数运算
4星 · 用户满意度95%
在实现一个函数来对数组下标为奇数的数据进行排序时,我们可以使用经典的排序算法,例如快速排序、归并排序或插入排序。这里我将给出一个简单的插入排序示例,因为它适合处理小型数组,并且易于理解。我们将只考虑奇数索引元素,因为题目要求这样。
```cpp
#include <iostream>
#include <vector>
// 仅对奇数索引进行插入排序的函数
void sortOddIndices(std::vector<int>& arr) {
for (size_t i = 2; i < arr.size(); i += 2) { // 只处理奇数索引
int key = arr[i];
size_t j = i - 2; // 插入位置的前一个元素
while (j >= 0 && arr[j] > key) {
arr[j + 2] = arr[j]; // 将前面的奇数索引元素后移
j -= 2;
}
arr[j + 2] = key; // 插入键值
}
}
// 示例用法
int main() {
std::vector<int> testArray = {5, 2, 8, 1, 9, 6, 3, 7, 4};
sortOddIndices(testArray);
for (size_t i = 0; i < testArray.size(); ++i) {
std::cout << "Element at index " << i << ": " << testArray[i] << std::endl;
}
return 0;
}
```
阅读全文