已知线性表存储在带头结点的单链表head中,请设计算法函数void sort(linklist head),将head中的结点按结点值升序排列。
时间: 2023-05-28 08:05:44 浏览: 184
方法顺序建立带头结点的单链表-线性表讲解PPT
算法思路:
1. 遍历链表,统计链表长度,记录在变量n中。
2. 进行n-1次遍历,每次遍历找到当前最小结点,将其与当前遍历的第一个结点互换位置。
3. 遍历结束后,链表中的结点就按照升序排列。
算法实现:
```
typedef struct node{
int data;
struct node *next;
}Node,*linklist;
void sort(linklist head){
int n=0;
Node *p=head->next,*q;
while(p!=NULL){
n++;
p=p->next;
}
for(int i=0;i<n-1;i++){
p=head->next;
q=p->next;
for(int j=0;j<n-i-1;j++){
if(p->data>q->data){
int temp=p->data;
p->data=q->data;
q->data=temp;
}
p=p->next;
q=q->next;
}
}
}
```
算法分析:
时间复杂度为O(n^2),空间复杂度为O(1)。
阅读全文