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

创办个人网站潍坊住房公积金

创办个人网站,潍坊住房公积金,百度seo官网,响应式网页需要什么技术1.例子1:环形链表 142. 环形链表 II - 力扣(LeetCode) 思路:我们先定义两个变量slow和fast,slow每次走一步,fast每次走两步,如果链表是环形链表,那么必定存在fast不会走到链表的最后…

1.例子1:环形链表

142. 环形链表 II - 力扣(LeetCode)

思路:我们先定义两个变量slow和fast,slow每次走一步,fast每次走两步,如果链表是环形链表,那么必定存在fast不会走到链表的最后并且fast先slow进环,fast和slow一定会在环内相遇。

fast和slow在环内相遇点定义一个指针变量meet,假设圆的周长为C,head从头开始走,meet从相遇点开始走,head点到进环点距离为L,假设slow和fast在圆内的相遇点距离为N,如下图所示:

 

 从上图可知haed和meet必定会相遇,相遇点就是进环点

 代码:

struct ListNode *detectCycle(struct ListNode *head) {struct ListNode* slow = head;struct ListNode* fast = head;while(fast && fast->next){slow = slow->next;fast = fast->next->next;if(slow == fast){struct ListNode* meet=slow;while(meet != head){meet = meet->next;head = head->next;} return meet;}}return NULL;
}

例子2:随机链表的赋值 

 138. 随机链表的复制 - 力扣(LeetCode)

思路:先在每一个节点后面开辟一个拷贝节点copy,拷贝节点的next指针就是cur的next指针,cur的next指针指向拷贝节点,原链表的random指向的下一个节点就是拷贝节点copy的random指向的节点,然后将拷贝节点尾插在一个新链表中,需要注意在尾插在新链表前先将原链表的cur指针重新指向head节点。

 

 

 代码:

struct Node* copyRandomList(struct Node* head) 
{struct Node* cur = head;//开辟新节点copy节点连接在每一个原链表节点的后面while(cur){//开辟copy节点struct Node* copy = (struct Node*)malloc(sizeof(struct Node));copy->val = cur->val;copy->next = cur->next;cur->next = copy;//cur 移动到copy节点的后面节点的位置cur = copy->next;}cur = head;while(cur){struct Node* copy = cur->next;if(cur->random == NULL){copy->random = NULL;}else{copy->random = cur->random->next;}cur= copy->next;}//将copy节点拿下来尾插到新链表中cur = head;struct Node* newhead = NULL,*newtail = NULL;while(cur){//创建新节点copy节点struct Node* copy = cur->next;//是否为空链表,如果是空链表那么新链表的头结点和尾节点都是copy节点if(newtail == NULL){newhead = newtail = copy;}else{newtail->next = copy;newtail = newtail->next;}cur = copy->next;}return newhead;}

 解析:

在原链表中定义一个cur指针指向头结点,使用malloc开辟copy节点,当cur指针不为空时进入while循环,拷贝节点的值为cur的值,即copy->val = cur->val; copy节点的下一个节点指向cur的下一个节点,而cur节点的下一个节点更改为copy节点,即 copy->next = cur->next:cur->next =copy;

cur移动到copy节点的下一个节点,即cur = copy->next;

cur指针重新指向头结点head节点,当cur不为空时进入循环,如果cur的random指向的节点为空,那么copy节点的random节点也为空,如果cur的random指向的节点不为空,那么copy节点的random指向的下一个节点就是copy节点random,即copy->random = cur->random->next;

 cur指针重新指向头结点head节点,定义新链表的头结点和尾节点,当cur不为空时进入循环,如果新链表为空,那么新链表的头结点和尾节点就是copy节点,如果不为空,那么就将copy节点尾插在新链表的后面

 

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

相关文章:

  • 网络公司建网站足球比赛直播
  • 班级网站 程序wordpress电商方案
  • 英文在线购物网站建设免费小程序开发制作
  • dede手机网站制作创建公司网页
  • 网站开发干啥的甘肃网络推广公司
  • 郑州网站推广服务黑彩网站建设
  • 游戏工作室网站模板网站建设资金方案
  • 成都网站制作赣州网络
  • google网站搜索国家企业网官网查询
  • ui设计作品欣赏网站网站流量一般多少合适
  • 怎样做类似于优酷的视频网站网站吸引客户
  • 网站开发项目经理注意事项打开百度搜索引擎
  • 用护卫神做共享网站企业营销策划的基本原则是
  • 廊坊网站seo排名搭建企业网站宽带多大
  • 中国建设部官方网站文章采集网站
  • 网站开发毕设任务书入门做外贸是先建网站还是先参展
  • 怎样分析一个网站做的好坏建设银行网站用户密码找回
  • 深圳 网站建设网站地图模板.zip
  • 北京专业制作网站公司建筑设计适合的电脑
  • 有几个网站可以做代发的装修装饰网站建设
  • 国内旅游网站排名重庆网站优化服务
  • 网站开发属于哪个板块的盘县 网站建设
  • 浙江小九天建设集团网站系统开发报价
  • 在百度怎么免费制作网站网站建设liluokj
  • 移动端网站建设外贸网站建设方案
  • 平顶山 网站设计wordpress手动更新视频
  • 微信网站改版价格阿里巴巴网站建设与维护
  • 建设信息网站企业负责人电话名录
  • 柳河县建设局网站屏蔽 wordpress 插件下载
  • 招聘网站建设及推广做网站多少分辨率就可以