以指针作为参数,输入任意十个整数完成冒泡排序(升序:从小到大)
时间: 2023-07-10 10:05:53 浏览: 48
下面是冒泡排序的C++代码实现:
```c++
void bubbleSort(int* arr, int size) {
for (int i = 0; i < size - 1; i++) {
for (int j = 0; j < size - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
```
其中,`arr`是一个指向整型数组的指针,`size`表示数组的大小。在函数中,我们使用两层循环遍历整个数组,每次比较相邻的两个元素,如果前一个元素比后一个元素大,则交换它们的位置。最终,经过多次比较和交换后,数组中的元素就按照升序排列了。
相关问题
使用指针作参数,输入十个整数完成冒泡排序(升序:从小到大)
下面是使用指针作为参数来实现冒泡排序的代码:
```c++
#include <iostream>
using namespace std;
void bubble_sort(int *arr, int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (*(arr + j) > *(arr + j + 1)) {
int temp = *(arr + j);
*(arr + j) = *(arr + j + 1);
*(arr + j + 1) = temp;
}
}
}
}
int main() {
int arr[10] = {5, 9, 2, 1, 7, 6, 3, 4, 8, 0};
bubble_sort(arr, 10);
for (int i = 0; i < 10; i++) {
cout << *(arr + i) << " ";
}
cout << endl;
return 0;
}
```
在 `bubble_sort` 函数中,`int *arr` 表示 `arr` 数组的首地址(即第一个元素的地址),通过 `*(arr + j)` 来访问数组中的元素。排序过程和普通冒泡排序一样,只不过数组元素的访问方式不同。最后在 `main` 函数中输出排序后的结果。
从键盘输入10个无序的整数,并设计一个函数(函数名为Sort),使用指针作参数,完成冒泡排序(升序:从小到大)。 输入:78 -12 12 -8 24 45 47 58 68 59 输出:-12 -8 12 24 45 47 58 59 68 78
下面是一个简单的冒泡排序实现:
```c++
#include <iostream>
using namespace std;
void Sort(int *arr, int size) {
for (int i = 0; i < size - 1; i++) {
for (int j = 0; j < size - i - 1; j++) {
if (arr[j] > arr[j+1]) {
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
int main() {
int arr[10];
cout << "请输入10个整数:" << endl;
for (int i = 0; i < 10; i++) {
cin >> arr[i];
}
Sort(arr, 10);
cout << "排序后的结果为:" << endl;
for (int i = 0; i < 10; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
```
我们先在 `main` 函数中输入 10 个整数,然后调用 `Sort` 函数进行排序。 `Sort` 函数中使用两层循环实现冒泡排序,每次将相邻的两个数进行比较,如果前面的数比后面的数大,则交换它们的位置。最终得到的就是升序排列的结果。