【排序算法】PTA选择排序法

202321332046罗旌誉 软件23 2023-11-06 22:04:55

 选择排序算法是通过遍历数组,选择出数组中的最小或者最大值,与指定位置完成交换数据,遍历完整个数组的所有位置就完成排序。

实现本题代码如下

#include<stdio.h>
void SelectSort(int n,int arr[])
{
    for(int i=0;i<n-1;i++)
    {
        for(int j=i+1;j<n;j++)
        {
            if(arr[i]<arr[j])
            {
                int temp=arr[i];
                arr[i]=arr[j];
                arr[j]=temp;
            }
        }
    }
}
int main()
{
    int n;
    scanf("%d",&n);
    int arr[n];
    for(int i=0;i<n;i++)
    {
        scanf("%d",&arr[i]);
    }
    sort(n,arr);
    for(int i=0;i<n;i++)
    {
        if(i==n-1)
            printf("%d",arr[i]);
        else
        printf("%d ",arr[i]);
    }
    return 0;
}

选择排序法的效率

时间复杂度O(n^2)

空间复杂度:O(1)

选择排序法是最简单的排序法之一,优点就是好理解,但选择排序法无论数组是否有序,选择排序法的执行次数不变,效率相对较低。

...全文
99 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
张老师 2023-11-16
  • 打赏
  • 举报
回复

可以演示出排序算法的过程,帮助理解

软件2班徐嘉辰20232133204 软件23 2023-11-06
  • 打赏
  • 举报
回复 1

写的真好,非常有帮助

207

社区成员

发帖
与我相关
我的任务
社区描述
程序设计基础课程教学群
c语言c++ 高校 福建省·厦门市
社区管理员
  • xmzq001
  • jiangxiaoju
  • 星落化尘
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

请加入学习社区的软件23级同学修改社区昵称为学号+姓名,以便登记作业提交情况。

试试用AI创作助手写篇文章吧