程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C >> C語言問答 >> C語言利用結構體變量構成的單項鏈表怎麼排序?

C語言利用結構體變量構成的單項鏈表怎麼排序?

編輯:C語言問答

C語言利用結構體變量構成的單項鏈表怎麼排序?

100 用選擇排序和冒泡排序給鏈表排序,只給出排序的程序就可以了.要解釋,詳細;

最佳回答:

首先定義一個結構體,如:
struct studentData
{
char sno[4];  /*學號*/
char sname[21];  /*姓名*/
int age;  /*年齡*/
int score[5]; /*五門成績*/
};

 

再定義構成單鏈表的結點:

struct student
{ /*數據域*/
struct studentData info;
struct student *next;/*指針域*/
};

 

下面是選擇排序:

void OrderBySnoAsc(){  //以學號按升序排序
 struct student *p,*q,*min;
 struct studentData temp;   //交換時用到的臨時變量
 for(p=head;p != NULL;p=p->next){
  min=p;
  for(q=p->next;q != NULL;q=q->next)
   if(strcmp(min->info.sno,q->info.sno)>0)
    min=q;
  if(min!=p){
   temp=min->info;  min->info =p->info; p->info=temp;
  }
 }
}

以下是冒泡排序:

void OrderBySnoAsc(){  //以學號按升序排序
 struct student *p,*q;
 struct studentData temp;   //交換時用到的臨時變量
 
 for(p=head;p!=NULL;p=p->next)
 {
  for(q=head;q->next!=NULL;q=q->next)
  {
   if(strcmp(q->info.sno,q->next->info.sno)>0)//相鄰的兩個之間比較
   {
    temp=q->info;  q->info =q->next->info; q->next->info=temp;
    
   }
  }
 }
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved