鱼C论坛

 找回密码
 立即注册
查看: 767|回复: 3

[已解决]自定义函数题求助,感谢

[复制链接]
发表于 2023-6-30 17:34:20 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目内容:

从键盘输入一个整数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
最佳答案
2023-6-30 17:35:33
以下是一个使用冒泡排序算法实现的示例代码:

  1. #include <iostream>
  2. using namespace std;

  3. void bubbleSort(int arr[], int size) {
  4.     for (int i = 0; i < size - 1; i++) {
  5.         for (int j = 0; j < size - i - 1; j++) {
  6.             if (arr[j] < arr[j+1]) {
  7.                 int temp = arr[j];
  8.                 arr[j] = arr[j+1];
  9.                 arr[j+1] = temp;
  10.             }
  11.         }
  12.     }
  13. }

  14. int main() {
  15.     int N;
  16.     cin >> N;

  17.     int a[N];
  18.     for (int i = 0; i < N; i++) {
  19.         cin >> a[i];
  20.     }

  21.     bubbleSort(a, N);

  22.     for (int i = 0; i < N; i++) {
  23.         cout << a[i] << " ";
  24.     }
  25.    
  26.     return 0;
  27. }
复制代码


您可以将上述代码复制粘贴到C++编译器中运行,输入样例的结果会按照从大到小的顺序输出。

希望对您有帮助!如果有任何问题,请随时提问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-6-30 17:35:33 | 显示全部楼层    本楼为最佳答案   
以下是一个使用冒泡排序算法实现的示例代码:

  1. #include <iostream>
  2. using namespace std;

  3. void bubbleSort(int arr[], int size) {
  4.     for (int i = 0; i < size - 1; i++) {
  5.         for (int j = 0; j < size - i - 1; j++) {
  6.             if (arr[j] < arr[j+1]) {
  7.                 int temp = arr[j];
  8.                 arr[j] = arr[j+1];
  9.                 arr[j+1] = temp;
  10.             }
  11.         }
  12.     }
  13. }

  14. int main() {
  15.     int N;
  16.     cin >> N;

  17.     int a[N];
  18.     for (int i = 0; i < N; i++) {
  19.         cin >> a[i];
  20.     }

  21.     bubbleSort(a, N);

  22.     for (int i = 0; i < N; i++) {
  23.         cout << a[i] << " ";
  24.     }
  25.    
  26.     return 0;
  27. }
复制代码


您可以将上述代码复制粘贴到C++编译器中运行,输入样例的结果会按照从大到小的顺序输出。

希望对您有帮助!如果有任何问题,请随时提问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-6-30 17:42:34 | 显示全部楼层
下面是一个符合你需求的C语言程序,使用了冒泡排序算法实现自定义排序函数:

  1. #include <stdio.h>

  2. // 自定义排序函数,使用冒泡排序算法
  3. void sort(int a[], int N) {
  4.     for (int i = 0; i < N-1; i++) {
  5.         for (int j = 0; j < N-i-1; j++) {
  6.             if (a[j] < a[j+1]) {
  7.                 int temp = a[j];
  8.                 a[j] = a[j+1];
  9.                 a[j+1] = temp;
  10.             }
  11.         }
  12.     }
  13. }

  14. int main() {
  15.     int N;
  16.     printf("请输入整数N:");
  17.     scanf("%d", &N);

  18.     int a[N];
  19.     printf("请输入%d个整数,以空格分隔:\n", N);
  20.     for (int i = 0; i < N; i++) {
  21.         scanf("%d", &a[i]);
  22.     }

  23.     sort(a, N);

  24.     printf("排序后的数组为:\n");
  25.     for (int i = 0; i < N; i++) {
  26.         printf("%d ", a[i]);
  27.     }

  28.     return 0;
  29. }
复制代码

请注意,这个程序没有进行任何的错误检查。在实际编程中,你需要考虑各种可能的输入错误,并进行相应的处理。此外,冒泡排序算法并不是最优的排序算法,对于大规模的数据,它的效率会非常低。你可以学习其他更有效的排序算法,比如快速排序、归并排序等。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-6-30 17:52:28 | 显示全部楼层
谢谢大家帮忙
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-20 13:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表