单链表的冒泡排序和选择排序

选择排序:

void select_Sort(Fruit* point){
    Fruit *t=point;
    for(Fruit *temp_point=point;temp_point!=NULL; temp_point=temp_point->next){        
            for(Fruit *temp2_point=temp_point; temp2_point->next !=NULL; temp2_point=temp2_point->next){
                    if(temp2_point->price > temp2_point->next->price){
                           strcpy(t->name,temp2_point->next->name);
                           t->price=temp2_point->next->price;             

                           strcpy(temp2_point->next->name,temp2_point->name);
                           temp2_point->next->price=temp2_point->price;

                           strcpy(temp2_point->name,t->name);
                           temp2_point->price=t->price;    
            }

        }
    }
}

冒泡排序:

void bubbleSort(Fruit* point){
    Fruit *cur,*tail;
    char temp1[20];
    cur=point;
    tail=NULL;
    if(cur==NULL||cur->next==NULL){
        return;
    }
    while(cur!=tail){
        while(cur->next!=tail){                //逐个减一,从倒数第一个、倒数第二个、倒数第三个到... 第一个
            if(cur->price > cur->next->price){
                double temp=cur->price;
                cur->price=cur->next->price;
                cur->next->price=temp;
                strcpy(temp1,cur->name);
                strcpy(cur->name,cur->next->name);
                strcpy(cur->next->name,temp1);
            }
            cur=cur->next;
        }
        tail=cur;
        cur=point;

    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值