zoukankan      html  css  js  c++  java
  • 单链表的选择排序

    给定一个无序单链表,实现单链表的选择排序(按升序排序)。

    代码注释挺详细,直接上代码!

    #include <stdio.h>
    #include <stdlib.h>
    struct node{
        int data;
        struct node *next;
    }; 
    void printList(struct node *head){
        struct node *t=head;
        while(t){
            printf("%d ",t->data);
            t=t->next;
        }
    }
    struct node * selectSort(struct node *head)
    /*选择排序 
    在原链表中一轮轮地找最大的那个结点,找到之后就把它从原链表中抽出来用头插法加到新的链表中。 
    需要注意这个最大的结点是否为头结点 
    */
    {
        struct node *head1,*max,*premax,*t,*pret;
        //head1:新链表的头指针;max:原链表中最大的结点;premax:最大结点的前驱结点;t:用于遍历原链表寻找最大结点;pret:t的前驱结点
        head1=NULL;
        while(head)//一遍遍地找原链表中当前最大结点 
        {
            max=head;
            premax=NULL;
            pret=head;
            t=head->next;
            //1、寻找最大结点 
            while(t){
                if(t->data>max->data){
                    max=t;
                    premax=pret;
                }
                pret=t;
                t=t->next;    
            }
            //2、让这个结点离开原链表
            if(max==head)//如果找到的结点是第一个结点
                head=head->next;//让头指针向后移一位就行
            else
                premax->next=max->next;
            //3、把此结点头插法插入新链表
            max->next=head1;
            head1=max;
        }
        return head1;
    }
    int main()
    {
        struct node *head,*p,*q;
        int i,n,a;
        scanf("%d",&n);
        head=NULL;
        for(i=0;i<n;i++){
            p=(struct node *)malloc(sizeof(struct node));
            scanf("%d",&a);
            p->data=a;
            p->next=NULL;
            if(!head){
                head=p;
            }else{
                q->next=p;
            }
            q=p;
        }
        printList(selectSort(head));
     } 
  • 相关阅读:
    our毕业短片
    Android Memory Management, OutOfMemoryError
    android autoswitched ImageSwitcher
    Storage size of Bitmap
    Frequentlyused URI of Intent
    小知识: 软件版本号讲解: 什么是Alpha, Beta, RC
    JSF框架中使用的设计模式介绍
    Unicode编码表/00000FFF
    Spring事务的传播行为和隔离级别
    领略Spring 3.x 时代的Spring MVC
  • 原文地址:https://www.cnblogs.com/littleLittleTiger/p/11524166.html
Copyright © 2011-2022 走看看