数据结构(day5)

思维导图

 

 // 按位置进行修改

int list_update_pos(LinkListPtr L, int pos, datatype e)

{

    if (NULL == L || list_empty(L) || pos < 1 || pos > L->len)

    {

        printf("修改失败\n");

        return 0;

    }

    list_search_pos(L, pos)->data = e;

    printf("修改成功\n");

    return 1;

}

 // 按值进行修改

int list_update_value(LinkListPtr L, datatype value, datatype e)

{

    if (NULL == L || list_empty(L))

    {

        printf("修改失败\n");

        return 0;

    }

    int flag = 0;

    for (int i = 1; i <= L->len; i++)

    {

        if (list_search_pos(L, i)->data == value)

        {

            list_search_pos(L, i)->data = e;

            flag++;

        }

    }

    if (flag == 0)

    {

        printf("修改失败\n");

        return 0;

    }

    printf("修改成功\n");

    return 1;

}

 // 链表排序

void list_sort(LinkListPtr L)

{

    if (NULL == L || L->len <= 1)

    {

        printf("排序失败\n");

        return;

    }

    LinkListPtr p=L->next;

    for(int i=1;i<L->len;i++){    

        LinkListPtr q=p;

        int min_index=i;

        for(int j=i;j<=L->len;j++){

            if(q->data<list_search_pos(L,min_index)->data){

                min_index=j;

            }

            q=q->next;

        }

        if(min_index!=i){

            datatype temp=p->data;

            p->data=list_search_pos(L,min_index)->data;

            list_search_pos(L,min_index)->data=temp;

        }

        p=p->next;

    }

    printf("排序成功\n");

}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值