国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

一個快速排序算法代碼分享

2020-01-26 15:38:16
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

/*
 * quickSort.c
 *
 *  Created on: 2012-4-9
 *      Author: LW
 */
#include <stdio.h>
#include <string.h>

typedef struct _student
{
 int id;
 char name[30];
}student,*pStudent;

student students[20] =
{
 {13,"狐貍金"},{15,"杜十娘"},{8,"葫蘆娃"},{4,"喜羊羊"},
 {14,"叮當貓"},{18,"孫悟空"},{3,"格列佛"},{6,"咖啡貓"},
 {19,"豬八戒"},{11,"程序員"},{5,"魯濱遜"},{9,"金槍魚"},
 {10,"馬大哈"},{12,"周星星"},{1,"灰太狼"},{2,"唐老鴨"},
 {20,"子虛君"},{16,"烏有君"},{7,"小二郎"},{17,"賈寶玉"},
};

//students[]是需要進行排序的數組,length是students數組的元素個數
void quickSort(student students[],int length)
{
 int i,j,flag = students[0].id;
 student stutemp;
 int t;

 if(length>1)
 {
  for(t=0;t<length;t++)
  {
   printf("%d   ",students[t].id);
  }
  printf("/n");

  //為分區選好分裂點
  for(i=0,j=length-1;i<j;)
  {
   for(;students[i].id<flag;i++);
   for(;students[j].id>flag;j--);

   stutemp.id = students[j].id;
   strcpy(stutemp.name,students[j].name);

   students[j].id = students[i].id;
   strcpy(students[j].name,students[i].name);

   students[i].id = stutemp.id;
   strcpy(students[i].name,stutemp.name);
  }

  //打印排序過程
  for(t=0;t<length;t++)
  {
   printf("%d   ",students[t].id);
  }
  printf("----排序后/n-----------------------------------中軸:%d 中軸下標:%d/n",flag,j);

  //進行分區并對分區進行遞歸調用quickSort,在原數組空間里進行操作
  quickSort(&students[0],j+1);
  quickSort(&students[j+1],length-j-1);
 }
}

int main()
{
 int i;

 //排序前打印
 printf("排序前:/n");
 for(i=0;i<20;i++)
 {
  printf("%d  %s/t",students[i].id,students[i].name);
  if(!((i+1)%5))
  {
   printf("/n");
  }
 }

 quickSort(students,20);

 //排序后打印
 printf("__________________________________________________________________/n排序后:/n");
 for(i=0;i<20;i++)
 {
  printf("%d  %s/t",students[i].id,students[i].name);
  if(!((i+1)%5))
  {
   printf("/n");
  }
 }

 return 0;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 佳木斯市| 宜良县| 恭城| 澎湖县| 蒲城县| 满城县| 孟津县| 寿光市| 县级市| 固原市| 贡嘎县| 勐海县| 公安县| 晋江市| 原平市| 革吉县| 四平市| 理塘县| 响水县| 剑川县| 中卫市| 石景山区| 改则县| 怀安县| 旌德县| 紫金县| 竹北市| 庆元县| 庆城县| 卓资县| 长春市| 光山县| 宜阳县| 邵阳市| 儋州市| 宁都县| 金平| 南岸区| 卓资县| 仁化县| 怀安县|