慕唯昕 2021-12-06 21:18 采纳率: 50%
浏览 238
已结题

c语言选择排序法练习

输入n个数据。利用选择排序进行编程,输出第k轮排序后的数列状况。

输入格式:
每组测试包含两行,分别是整数n,k (0<=k<n<100),以及n个原始数据。

输出格式:
输出第k轮排序后的数列结果(数据之间1个空格,尾端无多余空格)。

输入样例:
6 3
3 5 1 2 8 6
4 3
9 8 7 6
5 0
4 3 2 9 7
结尾无空行
输出样例:
1 2 3 5 8 6
6 7 8 9
4 3 2 9 7
结尾无空行

  • 写回答

2条回答 默认 最新

  • 关注

    参考如下:

    img

    代码:

    #include <stdio.h>
    
    int main()
    {
        int a[100],n,k;
        int i,j;
        int minindex,tmp;
        while (scanf("%d %d",&n,&k)!=EOF)
        {
            for(i=0;i<n;i++)
                scanf("%d",&a[i]);
            
            //排序
            for (i=0;i<n-1;i++)
            {
                if(i==k)
                    break;
                minindex = i;
                //找出第i小的数所在的位置
                for(j=i+1;j<n;j++)
                {
                    if(a[j] < a[minindex])
                        minindex = j;
                }
    
                //将第i小的数放在第i个位置
                if (i != minindex)
                {
                    tmp = a[i];
                    a[i] = a[minindex];
                    a[minindex] = tmp;
                }
            }
            //输出k轮排序后的结果
            for(i=0;i<n;i++)
            {
                if(i<n-1)
                    printf("%d ",a[i]);
                else
                    printf("%d\n",a[i]);
            }
    
        }
        
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月14日
  • 已采纳回答 12月6日
  • 创建了问题 12月6日

悬赏问题

  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应
  • ¥15 matlab基于pde算法图像修复,为什么只能对示例图像有效
  • ¥100 连续两帧图像高速减法
  • ¥15 如何绘制动力学系统的相图