直接選擇排序

來源:互聯網
上載者:User
直接選擇排序的作法是:第一趟掃描所有資料,選擇其中最小的一個與第一個資料互換;第二趟從第二個資料開始向後掃描,選擇最小的與第二個資料互換;依次進行下去,進行了(n-1)趟掃描以後就完成了整個排序過程。 

演算法:
void selectsort(int a[],int n)
{
  int i,j,p,temp;
  for(i=1;i<=n-1;i++)   //從第1個記錄開始到倒數第2個結束
  {
    p=i;   //準備
    for(j=i+1;j<=n;j++)  //第i個記錄後開始到最後個結束,同時找到最小元素,下標為p表示
     if(a[p]>a[j])      
        p=j;    //確定為最小,
    if(p!=i)  //迴圈結束後,p為標記最小元素的下標,檢查是否是同一數,如果不是,交換
    {
     x=r[k]; 
     r[k]=r[i]; 
     r[i]=x;
    }
  }
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.