鱼C论坛

 找回密码
 立即注册
查看: 1693|回复: 1

[已解决]编程操作

[复制链接]
发表于 2023-3-22 09:14:25 | 显示全部楼层 |阅读模式

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

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

x
编写一个递归函数sort(int array[],int low,int high),实现将数组下标从low到high-1范围内的元素按从小到大的顺序选择排序
  1. #include<stdio.h>
  2. int fun(int a[],int low,int high);
  3. int main()
  4. {
  5.         int a[10],i;
  6.         for(i=0;i<10;i++)
  7.         {
  8.                 scanf("%d",&a);
  9.         }
  10.         fun(a,0,10);
  11.         for(i=0;i<10;i++)
  12.         {
  13.                 printf("%2d",a[i]);
  14.         }
  15. }
  16. int fun(int a[],int low,int high)
  17. {
  18.         int i,j,k,t;
  19.         for(i=low;i<high;i++)
  20.         {
  21.                 k=i;
  22.                 for(j=i+1;j<high;j++)
  23.                 {
  24.                         if(a[k]>a[j])
  25.                         {
  26.                                 k=j;
  27.                         }
  28.                 }
  29.                 if(k!=i)
  30.                 {
  31.                         t=a[k];
  32.                         a[k]=a[i];
  33.                         a[i]=t;
  34.                 }
  35.         }
  36. }
复制代码

我这段为什么没有成功
最佳答案
2023-3-22 09:41:55
你的代码存在几个问题:
1. 在主函数中,输入数组元素时,应该使用&a[i]而不是&a。

2. 在主函数中,您调用了fun()函数,但fun()函数并没有返回任何值,因此您需要将fun()函数的返回值类型改为void。

3. 在fun()函数中,您使用了选择排序算法的实现,但是您的fun()函数没有递归调用自身,所以它不是一个递归函数。根据题目要求,您需要实现一个递归函数。
尝试一下如下代码:
  1. #include <stdio.h>

  2. void sort(int a[], int low, int high);

  3. int main() {
  4.     int a[10], i;
  5.     for (i = 0; i < 10; i++) {
  6.         scanf("%d", &a[i]);
  7.     }
  8.     sort(a, 0, 10);
  9.     for (i = 0; i < 10; i++) {
  10.         printf("%2d", a[i]);
  11.     }
  12.     return 0;
  13. }

  14. void sort(int a[], int low, int high) {
  15.     if (low >= high - 1) {
  16.         return;
  17.     }
  18.     int i, j, min_idx, temp;
  19.     min_idx = low;
  20.     for (i = low + 1; i < high; i++) {
  21.         if (a[i] < a[min_idx]) {
  22.             min_idx = i;
  23.         }
  24.     }
  25.     temp = a[low];
  26.     a[low] = a[min_idx];
  27.     a[min_idx] = temp;
  28.     sort(a, low + 1, high);
  29. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-3-22 09:41:55 | 显示全部楼层    本楼为最佳答案   
你的代码存在几个问题:
1. 在主函数中,输入数组元素时,应该使用&a[i]而不是&a。

2. 在主函数中,您调用了fun()函数,但fun()函数并没有返回任何值,因此您需要将fun()函数的返回值类型改为void。

3. 在fun()函数中,您使用了选择排序算法的实现,但是您的fun()函数没有递归调用自身,所以它不是一个递归函数。根据题目要求,您需要实现一个递归函数。
尝试一下如下代码:
  1. #include <stdio.h>

  2. void sort(int a[], int low, int high);

  3. int main() {
  4.     int a[10], i;
  5.     for (i = 0; i < 10; i++) {
  6.         scanf("%d", &a[i]);
  7.     }
  8.     sort(a, 0, 10);
  9.     for (i = 0; i < 10; i++) {
  10.         printf("%2d", a[i]);
  11.     }
  12.     return 0;
  13. }

  14. void sort(int a[], int low, int high) {
  15.     if (low >= high - 1) {
  16.         return;
  17.     }
  18.     int i, j, min_idx, temp;
  19.     min_idx = low;
  20.     for (i = low + 1; i < high; i++) {
  21.         if (a[i] < a[min_idx]) {
  22.             min_idx = i;
  23.         }
  24.     }
  25.     temp = a[low];
  26.     a[low] = a[min_idx];
  27.     a[min_idx] = temp;
  28.     sort(a, low + 1, high);
  29. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-22 17:42

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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