自定义函数题求助,感谢
题目内容:从键盘输入一个整数N(2<=N<=30),然后输入N个整型数据存入数组a,要求将数组a中的数据从大到小排序并输出,其中排序要求编写自定义函数实现(排序方法不限),在主函数中输出排序后的数组a 。
输入格式:
两行
第一行输入整数N(2<=N<=30)
第二行输入N个整数,整数之间以一个空格间隔
输出格式:
N个整型数据,数据之间以一个空格间隔
输入样例:
10
-200 1000 89 137 10001 -50000 7893 8 20 888
输出样例:
10001 7893 1000 888 137 89 20 8 -200 -50000 以下是一个使用冒泡排序算法实现的示例代码:
#include <iostream>
using namespace std;
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 < arr) {
int temp = arr;
arr = arr;
arr = temp;
}
}
}
}
int main() {
int N;
cin >> N;
int a;
for (int i = 0; i < N; i++) {
cin >> a;
}
bubbleSort(a, N);
for (int i = 0; i < N; i++) {
cout << a << " ";
}
return 0;
}
您可以将上述代码复制粘贴到C++编译器中运行,输入样例的结果会按照从大到小的顺序输出。
希望对您有帮助!如果有任何问题,请随时提问。 下面是一个符合你需求的C语言程序,使用了冒泡排序算法实现自定义排序函数:
#include <stdio.h>
// 自定义排序函数,使用冒泡排序算法
void sort(int a[], int N) {
for (int i = 0; i < N-1; i++) {
for (int j = 0; j < N-i-1; j++) {
if (a < a) {
int temp = a;
a = a;
a = temp;
}
}
}
}
int main() {
int N;
printf("请输入整数N:");
scanf("%d", &N);
int a;
printf("请输入%d个整数,以空格分隔:\n", N);
for (int i = 0; i < N; i++) {
scanf("%d", &a);
}
sort(a, N);
printf("排序后的数组为:\n");
for (int i = 0; i < N; i++) {
printf("%d ", a);
}
return 0;
}
请注意,这个程序没有进行任何的错误检查。在实际编程中,你需要考虑各种可能的输入错误,并进行相应的处理。此外,冒泡排序算法并不是最优的排序算法,对于大规模的数据,它的效率会非常低。你可以学习其他更有效的排序算法,比如快速排序、归并排序等。 谢谢大家帮忙{:10_275:}
页:
[1]