• 排序算法之——选择排序


    1.算法思想

    选择排序,从头至尾扫描序列,找出无序区最小的一个元素,和有序区的最后一个元素比较,如果较小就交换元素,如果相等就不交换元素,接着下一次循环(有序区不断增加,无序区不断往后减少),执行同样的操作,最终得到一个有序序列。

    2.C++实现

    #include <iostream>
    using namespace std;
    
    //交换2个数 
    void swap(int *p,int *q)
    {
        int temp;
        temp=*p;
        *p=*q;
        *q=temp;
    }
    
    //p表示数组首地址,n表示数组大小 
    void select_sort(int *p,int n)
    {
        //i表示有序区的末尾位置
       //j表示无序区的首位置
       //min表示最小值的位置 
       int i,j,min;
       for(i=0;i<n;i++)
       {
           //假设数组的无序区第一个数是最小的
              min=i; 
           //先找到从i+1~4之间最小的数
           for(j=i+1;j<5;j++)
           {
               if(*(p+j)<*(p+min))
                {
                      min=j;
              }
            } 
          /*如果最小的值的下标min与当前
          循环变量i(即有序区的末尾位置)的值不相等,则交换他们的值 */
          if(min!=i)
          {
              swap(*(p+i),*(p+min));
          }
       }
    }
    
    
    
    int main()
    {
       int a[5]={23,7,1,9,0};
      //排序前
       for(int k=0;k<5;k++)
       {
           cout<<a[k]<<" ";
        } 
        cout<<endl;
        //得到数组的长度 
       int arrlength = (sizeof(a)) / (sizeof(a[0]));
       //排序 
       select_sort(a,arrlength); 
       
       //排序后
       for(int k=0;k<5;k++)
       {
           cout<<a[k]<<" ";
        } 
               
        return 0;
     } 

    运行结果:

    参考文章:

    https://www.cnblogs.com/skywang12345/p/3597641.html#a42

    https://www.runoob.com/w3cnote/selection-sort.html

    转载文章链接已标明,如有侵权请告知。文章仅作为知识记忆所用,如有错误,敬请指正。
  • 相关阅读:
    Win7 64位 php-5.5.13+Apache 2.4.9+mysql-5.6.19 配置
    C# .NET 使用第三方类库DotNetZip解压/压缩Zip rar文件
    64位window7,php5.5.10 +IIS7 配置
    eclipse下编译openfire3.9.1源码
    asp.net 解决IE11下 From身份验证失效问题
    MySQL 数据类型 详解
    ASP.NET安全
    Microsoft Anti-Cross Site Scripting Library V4.2 下载地址
    Entityframework Core去掉外键
    VS2019发布Docker实践
  • 原文地址:https://www.cnblogs.com/YorkZhangYang/p/13974050.html
Copyright © 2020-2023  润新知