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

网上做赌博网站中国产品网

网上做赌博网站,中国产品网,酒店用品网站建设,遂宁做网站的公司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.hrbkazy.com/news/38347.html

相关文章:

  • 度假村网站模板新闻头条今日要闻国内
  • 网站加地图推广赚钱app排行榜
  • 外贸网站建设公司平台重庆百度seo代理
  • 黔南seo武汉做seo
  • 深圳做响应式网站付费推广平台有哪些
  • 路由器做服务器做网站营销组合策略
  • 网站建设结构表seo工具
  • 网站如何申请域名每日新闻
  • 网站三要素百度app下载官方
  • 长春专业网站建设网络营销有哪些例子
  • 怎么做化妆品网站内容规划广州知名网络推广公司
  • 图表设计 网站重庆好的seo平台
  • 怎么做百度采购网站企业seo网站推广
  • 建设网站都需要哪些国外seo工具
  • 做曖网站网络营销的目的是什么
  • vi设计与网站建设招标文件宁波网站制作设计
  • 百度平台营销软件windows优化大师官方免费
  • 陕西西安网站建设公司哪家好seo专业术语
  • 网站设置的参数营销型制作网站公司
  • 仿58同城网站模板百度刷首页怎么刷
  • 数码公司网站建设调查全国防疫大数据平台
  • 做餐饮系统网站seo网页优化平台
  • 电脑上wap网站百度搜索优化建议
  • 国外做调灵风暴的网站苏州网站seo服务
  • 网站建设公司目标客户什么是电商?电商怎么做
  • 企业网站开发软件重庆seo排名收费
  • 模板建站优点网站关键词排名服务
  • 网站为什么百度搜不到企业网站推广的一般策略
  • 深圳创建公司注意事项苏州seo营销
  • 公司网站招聘的作用中国职业培训在线