美文网首页
线性表算法设计题(六)

线性表算法设计题(六)

作者: 搬砖的猫 | 来源:发表于2019-10-26 12:50 被阅读0次

题目

设计一个算法,通过一趟遍历确定长度为n的单链表中值最大的结点。

算法思想

在遍历的时候利用指针pmax记录值最大的结点的位置。

完整代码

#include <iostream>
using namespace std;

//设计一个算法,通过一趟遍历确定长度为n的单链表中值最大的结点 

typedef int ElemType;
typedef struct LNode{
    ElemType data;
    LNode *next;
}LNode, *LinkList;

//创建链表
int CreateList(LinkList &L,int n){
    LNode *p,*r;
    int i;
    L = new LNode;
    L -> next = NULL;
    r = L;
    for(i = 0;i < n;i ++)
    {
        p = new LNode;
        cin >> p -> data;
        p -> next = NULL;
        r -> next = p;
        r = p;
    }
    return 0;
}

ElemType Max(LinkList L){
    //确定单链表中值最大的结点 
    LinkList pmax, p;
    if(L -> next == NULL){
        return NULL;
    }
    pmax = L -> next;                    //pmax指向首元结点 
    p = L -> next -> next;               //p指向第二个结点 
    while(p != NULL){                    //遍历链表,如果下一个结点存在 
        if(p -> data > pmax -> data){
            pmax = p;                    //pmax指向数值大的结点 
        }
        p = p -> next;                   //p指向下一个结点,继续遍历 
    }
    return pmax -> data;
}

int main(){
    LinkList L;
    int n;
    cout << "请输入链表的长度:";
    cin >> n;
    cout << "请依次输入要存入的数据:" << endl;
    CreateList(L, n);
    int max = Max(L);
    cout << "该链表的最大值为:" << max << endl;
    return 0;
} 

结果显示

TIM图片20191026124952.png

相关文章

  • 线性表算法设计题(六)

    题目 设计一个算法,通过一趟遍历确定长度为n的单链表中值最大的结点。 算法思想 在遍历的时候利用指针pmax记录值...

  • 线性表算法设计题(七)

    题目 设计一个算法,将链表中所有结点的链接方向“原地”逆转,即要求仅利用原表的存储空间,换句话说,要求算法的空间复...

  • 线性表算法设计题(八)

    题目 设计一个算法,删除递增有序链表中值大于mink且小于maxk的所有元素(mink和maxk是给定的两个参数,...

  • 线性表算法设计题(五)

    题目 设计算法将一个带头结点的单链表A分解为两个具有相同结构的链表B和C,其中B表的结点为A表中值小于零的结点,而...

  • 线性表算法设计题(九)

    题目 已知长度为n的线性表A采用顺序存储结构,请写一个时间复杂度为O(n)、空间复杂度为O(1)的算法,该算法可删...

  • 线性表算法设计题(二)

    题目 将两个非递减的有序链表合并为一个非递增的有序链表。要求结果链表仍使用原来两个链表的存储空间,不另外占用其他的...

  • 线性表算法设计题(三)

    题目 已知两个链表A和B分别表示两个集合,其元素递增排列。请设计一个算法,用于求出A与B的交集,并存放在A链表中。...

  • 线性表算法设计题(四)

    题目 已知两个链表A和B分别表示两个集合,其元素递增排列。请设计一个算法,用于求出A与B的差集(即仅由在A中出现而...

  • 线性表算法设计题(一)

    题目 将两个递增的有序链表合并为一个递增的有序链表。要求结果链表仍使用原来两个链表的存储空间,不另外占用其他的存储...

  • 2019-05-26

    今天看数据结构中线性表,还有算法设计与分析,

网友评论

      本文标题:线性表算法设计题(六)

      本文链接:https://www.haomeiwen.com/subject/lciyvctx.html