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

便宜的做网站公司搜索关键词排名一般按照什么收费

便宜的做网站公司,搜索关键词排名一般按照什么收费,排名好的网站开发,多个网站备案吗解题思路: 1.获取信息: 给出了多个升序链表,要求合并成一个升序链表,返回首元结点 2.分析题目: 外面在21题的时候,讲了怎样合并两个升序链表为一个升序链表,不了解的,建议去看一下21…

解题思路:

        1.获取信息:

                给出了多个升序链表,要求合并成一个升序链表,返回首元结点

        2.分析题目:

                外面在21题的时候,讲了怎样合并两个升序链表为一个升序链表,不了解的,建议去看一下21题题解,不要好高骛远

                (有时候一个问题比较难,将它拆分成多个小问题取逐一解决是一个不错的方法)

                好了,那我们现在知道怎么合并两个有序链表了,类比推理,我们可以将这个问题看作是两数求和的那道题,我们怎么来选取链表进行合并,就显得尤为重要

                (其实每道题的思路和想法都是融会贯通的,只要你理解了,学会了,都大差不差)

                具体选取链表来合并的方式,我们在下面的尝试编写代码环节中借着代码,我会逐一讲解

        3.示例查验:

                示例1:说实话不够鲜明,让我感到鲜明的还是代码框中给出的默认代码

                让我知道,lists中是一个用来储存首元结点地址的vector而已

                示例2:如果lists为空,则返回空

                示例3:如果lists中的链表为空,也返回空,因为空跟空合并也是空,但是如果空跟非空合并,那就是非空了

        4.尝试编写代码

                (1)逐次合并链表

                        (在这里再说一下,我在这个贴子的题解中不会写出怎么合并两个有序链表,只会说怎么选取链表来合并,主要是最近我眼睛有点痛,不想看电子设备,等到康复的时候,我会补上的,还有就是可以帮助你,让你多做一道题哦,就是21题,你可以开始感谢我了,注意:合并两个有序链表可以用递归,也可以用迭代)

                        思路:取第一个链表和第二个链表进行合并,它们合并而成的链表再和第三个链表进行合并,依次类推,直到所有链表都进行了合并,成为了一个升序链表

以下是完整代码

class Solution {
public:ListNode* mergeKLists(vector<ListNode*>& lists) {if(lists.empty())return nullptr;//如果lists为空,则返回空指针ListNode*dummy=lists[0];//取第一个链表for(int i=1;i<lists.size();i++){//依次取后续的链表dummy=Link(dummy,lists[i]);//这里自己品味一下}return dummy;//返回合并后的链表的首元结点的地址(也可以说指向首元结点的指针)}
private://这里还是照顾一下没看过21题题解的。。。我想不出什么亲切的称呼,可以老少皆宜,可以自行脑补一下ListNode* Link(ListNode*dummy,ListNode*list){//这里我使用的递归来写的合并两个有序链表if(dummy==nullptr)return list;//如果某条链表为空,则返回没空的那条链表if(list==nullptr)return dummy;if(dummy->val<list->val){dummy->next=Link(dummy->next,list);//比较小的那个结点的下一位是去掉比较小的那个结点的链表和另一条链表合并后的链表return dummy;}else{list->next=Link(dummy,list->next);return list;}}//我感觉我这里说的,你可能听不懂,所以我还是建议你去看一下21题题解
};

                (2)分治法来合并链表

                        思路:分治法的思想就是大问题拆分成小问题

                        对于链表组lists,我们每次划分为二,那么是不是最后可以划成若干个只有两个链表的组合,我们再合并这些组合,最后就是一个升序的链表了

文字无力,我还是放图说话

以下是完整代码(就不写注释了,自己品味,考验一下你,测试一下你的忠诚度,后续眼睛不痛了,我会补上的)

class Solution {
public:ListNode* mergeKLists(vector<ListNode*>& lists) {if(lists.empty())return nullptr;return Sep(lists,0,lists.size()-1);}
private:ListNode* Sep(vector<ListNode*>& lists,int l,int r){if(r-l==1)return Link(lists[l],lists[r]);if(r==l)return lists[l];int mid=(r+l)/2;ListNode* left=Sep(lists,l,mid);ListNode* right=Sep(lists,mid+1,r);return Link(left,right);}ListNode* Link(ListNode*dummy,ListNode*list){if(dummy==nullptr)return list;if(list==nullptr)return dummy;if(dummy->val<list->val){dummy->next=Link(dummy->next,list);return dummy;}else{list->next=Link(dummy,list->next);return list;}}
};

                (3)选择重造

                        (这里留下这个在力扣上面看到的方法,我只给思路,后续眼睛不痛了,我会补上,还是老样子,考验一下你写代码的能力,你可以后续过来对答案,最迟后天就会补,毕竟是正事)

                        我们取每条链表的首元结点,在这么多个首元结点中,我们从小到大开始连接首元结点,连接完之后,我们再次取每条链表(每次取完首元结点,那些链表就失去了那些结点,原首元结点下一个结点就是新的首元结点)的首元结点,重复操作,直到每条链表都被取完了,那最后拼成的链表就是答案

                        好咯,接下来就交给你咯

http://www.dtcms.com/wzjs/252320.html

相关文章:

  • 天津自贸区建设局网站西安seo建站
  • 希音电商网站google官方下载app
  • 网站建设正规公司建立网站的基本步骤
  • 网站开发技术和工具分类达人介绍
  • 从客户—管理者为某一公司做一份电子商务网站管理与维护的方案免费seo工具大全
  • b2c网站搭建百度seo搜搜
  • 手机app下载软件安装seo排名优化工具
  • 网站建设费计入管理费用深圳百度推广属于哪家公司
  • wordpress模板的网站_网页字体怎么修改?中国国家培训网官网查询
  • 做的网站必须放免费换友情链接
  • php免费开源建站系统广州网络营销运营
  • 有没有一种app类似网站建设百度百家号注册
  • 专门做装修的网站优秀网站
  • 网站跟网页的区别优化营商环境发言稿
  • 自己怎么做网站推广如何开网店
  • wordpress多重筛选合肥seo快排扣费
  • 怎样做国外网站网络营销最主要的工具是
  • 电子商务网站是什么意思关键词优化技巧
  • 做英文网站的标准字体重庆seo公司
  • 长垣有做网站设计的吗河源疫情最新通报
  • 成人本科考试时间东莞网站优化关键词排名
  • 复制别人网站内容被降权如何发布自己的广告
  • 网站没有备案怎么做支付谷歌seo代运营
  • 衡水做wap网站多少钱网站链接提交
  • cms网站地图模板alexa排名查询
  • 宽城区网站建设关键词排名工具有哪些
  • 做海关授权的网站今日军事新闻最新消息新闻报道
  • 如何制作一个软件界面网店seo是什么意思
  • 邯郸住房及城乡建设部网站网站优化助手
  • 自己做的网站怎么取sql数据库营销策略ppt