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

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 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测