编写程序:定义一个具有10个容量的一维整 数数组,并通过键盘输入10个任意整数,请采用交换排序法实现数组数据的由小到大的排序及输出

img


想问一下怎么求解,改了好久,结果是乱码,不知道哪里有细微的错估计

用冒泡排序吧

#include <stdio.h>
int main()
{
    int a[10],i,j,t;
    for(i=0;i<10;i++)
        scanf("%d",&a[i]);
    for(i=0;i<9;i++)
      for(j=0;j<9-i;j++)
      {
          if(a[j] > a[j+1])
          {
              t = a[j];
              a[j] = a[j+1];
              a[j+1] = t;
          }
      }
      for(i=0;i<10;i++)
          printf("%d ",a[i]);
}

供参考:

#include <stdio.h>
int main()
{
    int i, j, a[10], t;
    for (i = 0; i < 10; i++)
        scanf("%d", &a[i]);
    for (i = 0; i < 9; i++) {
        for (j = i + 1; j < 10; j++)
            if (a[i] > a[j]) {
                t = a[i];
                a[i] = a[j];
                a[j] = t;
            }
    }
    for (i = 0; i < 10; i++)
        printf(i ? " %d" : "%d", a[i]);
    return 0;
}

  • 你可以参考下这个问题的回答, 看看是否对你有帮助, 链接: https://ask.csdn.net/questions/7677366
  • 你也可以参考下这篇文章:编写一个程序,提示用户输入一个整数,然后打印从该数到比该数大10的所有整数例如,用户输入10,则打印10~20的所有整数,包括10和20。要求打印的各值之间用一个空格、制表格或换行符分开。
  • 除此之外, 这篇博客: 输入十个数,将最小的与第一个交换,最大的与最后一个交换 写三个函数:输入10个数,进行处理,输出10个数中的 输入十个数,将最小的与第一个交换,最大的与最后一个交换 写三个函数:输入10个数,进行处理,输出10个数 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • 题目来源:《谭浩强C语言程序设计》指针习题3
    - 思路
    1.编写输入输出函数。
    2.编写能够找出最大值和最小值并按照:最小的与第一个交换,最大的与最后一个交换的要求进行编写。
    (1)定义三个指针变量*max,*p,*min,使得开始的时候三者都指向同一个地址;
    (2)先找的最大的和最小的数
    (3)交换(借助中间变量temp)交换最大的与最后一个交换; 最小的与第一个交换。
    3.在主函数中对三个函数分别进行调用。

    - 注意事项:
    如果先 最小的与第一个交换,那么如果第一个就是最大的先与最后一个交换之后,max和min指向的地址是没有变化的,但是此时最大的数的值变化了
    变成了最后一个数,所以要加下面这一句:if (max == number)max = min;
    代码部分如下:

      temp = number[0];
        number[0] = *min;
        *min = temp;
        if (max == number)max = min;
      temp = number[9];
        number[9] = *max;
        *max = temp;
    

    具体代码

    // Created by acer on 2020/5/12.
    //输入十个数,将最小的与第一个交换,最大的与最后一个交换 写三个函数:输入10个数,进行处理,输出10个数
    #include <stdio.h>
    
    void output(int *number);  //函数声明
    
    void print(int *number);
    
    void max_min(int *number);
    
    int main() {
        int number[10];
    //    函数调用
        print(number);
        max_min(number);
        output(number);
        return 0;
    }
    
    void print(int *number) {    //输入函数
        for (int i = 0; i < 10; i++) {
            scanf("%d", &number[i]);
        }
    }
    
    void max_min(int *number) {
        int *p, *max, *min, temp;
        max = min = number;
    //    1.先找的最大的和最小的
        for (p = number; p < number + 10; p++) {
            if (*p > *max)max = p;  //把p指向地址给max,使得如果*p大于*max就让max指向p所指的数
            else if (*p < *min)min = p;//把p指向地址给min,使得如果*p小于*max就让min指向p所指的数
        }
    //    2.交换最大的与最后一个交换
        temp = number[9];
        number[9] = *max;
        *max = temp;
    
        /*特殊情况:如果第一个就是最大的先与最后一个交换之后,max和min指向的地址是没有变化的,但是此时最大的数的值变化了
      变成了最后一个数,所以要加下面这一句if (max == number)max = min;*/
    //    最小的与第一个交换
        temp = number[0];
        number[0] = *min;
        *min = temp;
    }
    
    void output(int *number) {  //输出函数
        int *p;
        printf("请输入十个数字\n");
        for (p = number; p < number + 10; p++) {
            printf("%d", *p);
            printf(" ");
        }
    
    
    }
    

    结果

    98 24 56 78 1 32 36 44 29 6
    请输入十个数字
    1 24 56 78 6 32 36 44 29 98
    
  • 您还可以看一下 郑逊敏老师的抖音快手短视频自媒体制作引流运营兼职创业赚钱盈利实战教程课程中的 巧妙借势热点,实现快速涨粉小节, 巩固相关知识点