鱼C论坛

 找回密码
 立即注册
查看: 1155|回复: 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
以下是一个使用冒泡排序算法实现的示例代码:
#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[j] < arr[j+1]) {
                int temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }
}

int main() {
    int N;
    cin >> N;

    int a[N];
    for (int i = 0; i < N; i++) {
        cin >> a[i];
    }

    bubbleSort(a, N);

    for (int i = 0; i < N; i++) {
        cout << a[i] << " ";
    }
    
    return 0;
}

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

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

使用道具 举报

发表于 2023-6-30 17:35:33 | 显示全部楼层    本楼为最佳答案   
以下是一个使用冒泡排序算法实现的示例代码:
#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[j] < arr[j+1]) {
                int temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }
}

int main() {
    int N;
    cin >> N;

    int a[N];
    for (int i = 0; i < N; i++) {
        cin >> a[i];
    }

    bubbleSort(a, N);

    for (int i = 0; i < N; i++) {
        cout << a[i] << " ";
    }
    
    return 0;
}

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

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

使用道具 举报

发表于 2023-6-30 17:42:34 | 显示全部楼层
下面是一个符合你需求的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[j] < a[j+1]) {
                int temp = a[j];
                a[j] = a[j+1];
                a[j+1] = temp;
            }
        }
    }
}

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

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

    sort(a, N);

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

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

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-24 07:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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