Forpyst 发表于 2023-6-30 17:34:20

自定义函数题求助,感谢

题目内容:

从键盘输入一个整数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

sfqxx 发表于 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 < 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++编译器中运行,输入样例的结果会按照从大到小的顺序输出。

希望对您有帮助!如果有任何问题,请随时提问。

isdkz 发表于 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 < 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;
}

请注意,这个程序没有进行任何的错误检查。在实际编程中,你需要考虑各种可能的输入错误,并进行相应的处理。此外,冒泡排序算法并不是最优的排序算法,对于大规模的数据,它的效率会非常低。你可以学习其他更有效的排序算法,比如快速排序、归并排序等。

Forpyst 发表于 2023-6-30 17:52:28

谢谢大家帮忙{:10_275:}
页: [1]
查看完整版本: 自定义函数题求助,感谢