线性表作业

这篇博客主要探讨了线性表的三种操作:顺序表的逆置存储、单链表的逆置存储以及如何将两个有序链表合并为一个新的有序链表。对于顺序表,通过半遍历实现元素的对调实现逆置;单链表逆置则通过辅助指针反转元素链接;而合并有序链表则通过比较两个链表的第一个元素并插入目标链表来实现。
摘要由CSDN通过智能技术生成

顺序表的转置

1、请完成下列算法填空实现对顺序表逆置存储,逆置存储是指将元素线性关系逆置后的顺序存储,例如(a0,a1,a2),关系逆置后为(a2,a1,a0).

SeqList的结构体定义如下:

typedef struct seqList

{

    int n;

    int maxLength;

    ElemType *element;

}SeqList;



void Invert(SeqList *L) {

ElemType temp; int i; 

for ( i=0; i<________; i++) { 

    temp =____________; 

    L->element[i] = L->element[___________]; 

    L->element[________] = ___________; }

}

答案

(L->n)/2

L->element[i]

i-n-1

i-n-1

temp

算法思想:

利用for循环半遍历顺序表,将表头尾的数据对换。 i<(L->n)/2;是实现半变历的关键。

单链表的转置

请完成下列算法填空现对单链表的逆置存储,逆置存储是指将元素线性关系逆置后的链表存储,例如(a0,a1,a2),关系逆置后为(a2,a1,a0).

单链表结点Node和单链表SingleList结构体定义如下:

typedef struct node

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值