当前位置: 首页 > news >正文

建站工具 风铃成都百度网站排名优化

建站工具 风铃,成都百度网站排名优化,门面商铺装修,wordpress菜单分类目录目录 第1题 合并两个非递减有序链表 得分点(必背) 题解 函数声明与初始化变量: 初始化合并链表的头节点: 合并两个链表: 处理剩余节点: 返回合并后的链表: 完整测试代码 🌈…

目录

第1题 合并两个非递减有序链表

得分点(必背)

题解

函数声明与初始化变量:

初始化合并链表的头节点:

合并两个链表:

处理剩余节点:

返回合并后的链表:

完整测试代码


🌈 嗨,我是命运之光!

🌌 2024,每日百字,记录时光,感谢有你,携手前行~

🚀 携手启航,我们一同深入未知的领域,挖掘潜能,让每一步成长都充满意义。


第1题 合并两个非递减有序链表

已知带头节点单链表 LA LB ,其元素均为非递减有序排列,编写算法利用原表结点空间,将链表 LA LB 合并为非递减有序序列的单链表 LC

得分点(必背)

// 合并两个非递减有序链表(得分点)
LinkList mergeLists(LinkList lista, LinkList listb){LinkList listc, p = lista, q = listb, r;
//listc指向lista 和 listb所指结点中较小者
//初始化合并链表的头节点if(lista->data<=listb->data){listc=lista;r=lista;p=lista->next;}else{listc=listb;r=listb;q=listb->next;}
//合并两个链表while(p!=NULL && q!=NULL){if(p->data<=q->data){r->next=p;r=p;p=p->next;}else{r->next=q;r=q;q=q->next;}}r->next=(p!=NULL)?p:q; //处理剩余节点return listc; //返回合并后的链表
}

题解

这段代码的功能是将两个非递减有序链表合并成一个非递减有序链表。下面我将逐步解释这段代码:

函数声明与初始化变量
LinkList mergeLists(LinkList lista, LinkList listb){LinkList listc, p = lista, q = listb, r;
  • LinkList mergeLists(LinkList lista, LinkList listb):函数名为mergeLists,参数是两个非递减有序链表listalistb,返回值是合并后的链表。
  • LinkList listc, p = lista, q = listb, r;:定义了四个指针变量:
    • listc:用于指向合并后的链表的头节点。
    • p:初始化为指向链表lista的当前节点。
    • q:初始化为指向链表listb的当前节点。
    • r:用于构建合并后的链表。
初始化合并链表的头节点
if(lista->data<=listb->data){listc=lista;r=lista;p=lista->next;
}
else{listc=listb;r=listb;q=listb->next;
}

if(lista->data<=listb->data):比较listalistb的头节点数据。

  • 如果lista的头节点数据小于等于listb的头节点数据:
    • listc = lista:将合并链表的头节点指向lista的头节点。
    • r = listar指向当前合并链表的最后一个节点(此时是lista的头节点)。
    • p = lista->next:将指针p移动到lista的下一个节点。
  • 否则:
    • listc = listb:将合并链表的头节点指向listb的头节点。
    • r = listbr指向当前合并链表的最后一个节点(此时是listb的头节点)。
    • q = listb->next:将指针q移动到listb的下一个节点。
合并两个链表
while(p!=NULL && q!=NULL){if(p->data<=q->data){r->next=p;r=p;p=p->next;}else{r->next=q;r=q;q=q->next;}
}

while(p!=NULL && q!=NULL):循环遍历listalistb,直到其中一个链表遍历完(pq变为NULL)。

  • if(p->data<=q->data):比较pq指向的节点数据。
    • 如果p的数据小于等于q的数据:
      • r->next=p:将当前合并链表的最后一个节点的next指针指向p
      • r=p:将r指向p,即更新当前合并链表的最后一个节点。
      • p=p->next:将指针p移动到lista的下一个节点。
    • 否则:
      • r->next=q:将当前合并链表的最后一个节点的next指针指向q
      • r=q:将r指向q,即更新当前合并链表的最后一个节点。
      • q=q->next:将指针q移动到listb的下一个节点。
处理剩余节点
r->next=(p!=NULL)?p:q;

r->next=(p!=NULL)?p:q;:当while循环结束时,可能还剩下一个链表中有未处理完的节点。

  • 如果p不为空,则将r->next指向p,即将剩余的lista节点连接到合并链表的末尾。
  • 如果p为空,则将r->next指向q,即将剩余的listb节点连接到合并链表的末尾。
返回合并后的链表
return listc;
  • return listc;:返回合并后的链表listc

总结:这段代码通过比较两个链表的节点数据,将较小的数据节点依次连接到合并后的链表中,最终返回一个合并后的非递减有序链表。

完整测试代码

#include<iostream>
using namespace std;// 定义链表节点结构
struct Node {
int data;
Node* next;
};
// 定义 LinkList 类型为指向 Node 的指针
typedef Node* LinkList;
// 初始化链表
void InitList(LinkList& L){L=new Node;L->next=NULL;
}
// 合并两个非递减有序链表(得分点)
LinkList mergeLists(LinkList lista, LinkList listb){LinkList listc, p = lista, q = listb, r;//lilistc指向lista 和 listb所指结点中较小者if(lista->data<=listb->data){listc=lista;r=lista;p=lista->next;}else{listc=listb;r=listb;q=listb->next;}while(p!=NULL && q!=NULL){if(p->data<=q->data){r->next=p;r=p;p=p->next;}else{r->next=q;r=q;q=q->next;}}r->next=(p!=NULL)?p:q;return listc;
}
// 打印链表
void printList(LinkList head) {while (head != nullptr) {cout << head->data << " ";head = head->next;}cout << endl;
}int main() {// 创建链表 a: 1 -> 3 -> 5Node* a1 = new Node{1, nullptr};Node* a2 = new Node{3, nullptr};Node* a3 = new Node{5, nullptr};a1->next = a2;a2->next = a3;// 创建链表 b: 2 -> 4 -> 6Node* b1 = new Node{2, nullptr};Node* b2 = new Node{4, nullptr};Node* b3 = new Node{6, nullptr};b1->next = b2;b2->next = b3;// 合并链表LinkList mergedList = mergeLists(a1, b1);// 打印结果printList(mergedList); // 应该输出: 1 2 3 4 5 6// 清理内存while (mergedList != nullptr) {Node* temp = mergedList;mergedList = mergedList->next;delete temp;}return 0;
}

嗨,我是命运之光。如果你觉得我的分享有价值,不妨通过以下方式表达你的支持:👍 点赞来表达你的喜爱,📁 关注以获取我的最新消息,💬 评论与我交流你的见解。我会继续努力,为你带来更多精彩和实用的内容。

点击这里👉 ,获取最新动态,⚡️ 让信息传递更加迅速。

http://www.yayakq.cn/news/99929/

相关文章:

  • 微网站模板代码如何做好营销
  • 做网站设计师工资多少网站横幅图片
  • 做企业网站市场分析text-indent:2em wordpress
  • 建设直播网站需要多少钱牛商网专注营销型网站建设
  • 有关网站开发的文献南京网络推广
  • 网站建设新闻稿新西兰网站后缀
  • 网站建设周志200字注册公司上什么网站
  • 灵犀 科技高端网站建设wordpress实现文件上传
  • 公司网站流量大 怎么办四川城市建设住建厅网站
  • 网站开发规格一级域名如何分发二级域名
  • 个人可以建网站卖东西吗可信的专业网站建设
  • 网站目录做301怎么优化标题和关键词排名
  • 网站备案需要哪些东西临淄辛店今天招聘信息
  • 海南省建设厅网站首页如何做网站营销
  • 泉州网站制作多少钱域名注册人信息
  • 贵阳seo网站推广网站策划书的主题有哪些
  • wordpress网站域名地址安装Wordpress个人网站
  • 蓬莱住房和规划建设管理局网站做网站不推广管用吗
  • 网站 栏目添加 文章不显示网站外贸推广
  • 开网站怎么开做网站怎么引流
  • 网站开发有哪些方式微信做单子的网站源码
  • 淘客客怎么做自己的网站在哪个网站可以学做甜点
  • 多个域名绑定同一网站抖音代运营一般几个周期
  • 我的世界是怎么做的视频网站遂宁市建设银行网站
  • 新站点seo联系方式青岛需要做网站的公司
  • 企业网站收费标准wordpress美图插件
  • 海事网站开发怎么看一个网站做外链
  • 凡客网能直接做网站重庆正云环境网页制作
  • 做网站要和企业logowordpress信用卡支付
  • 企业网站制作建设的框架有哪几种湖南做网站找谁