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

正规网站开发公司2345网址导航是病毒吗

正规网站开发公司,2345网址导航是病毒吗,山东省交通运输厅网站开发单位,网站飘动广告代码这里写目录标题 反转链表合并两个有序链表分割链表 反转链表 1、题目: 2.思路  思路1:建立一个newHead,取一个节点进行头插。具体做法如下! 建立一个newHead(新头),由于一个节点里面存的是下一个节点的地址,如果取…

这里写目录标题

  • 反转链表
  • 合并两个有序链表
  • 分割链表

反转链表

1、题目:
1
1
2.思路
 思路1:建立一个newHead,取一个节点进行头插。具体做法如下!
1
建立一个newHead(新头),由于一个节点里面存的是下一个节点的地址,如果取一个节点下来进行头插,那么,要取的下一个节点的地址找不到,因此定义n1,n2,n1用来往下拿结点进行头插,n2预备下一次要的节点 ,代码如下!!!

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* reverseList(struct ListNode* head) {if(head == NULL){return NULL;}struct ListNode* newHead = NULL;//n1为向下取得插入的节点struct ListNode* n1 = head;//n2是给n1准备的节点struct ListNode* n2 = head->next;while(n1){n1->next = newHead;newHead = n1;n1 = n2;//当n2为NULL时,n2没有取得节点了if(n2){n2 = n2->next;}}return newHead;
}

 思路2:把指针翻转,把指针反转的意思是,把存节点的地址交换,定义三个指针n1,n2,n3,n1 = NULL,n2 = head,n3 = head->next,n2为第一个节点翻转,n2->next = n1,n2里面原来存的地址找不到,因此要n3存下一个节点的地址,这样这个题就可以反转了!!!
1

struct ListNode* reverseList(struct ListNode* head) {if(head == NULL){return NULL;}struct ListNode* n1 = NULL;struct ListNode* n2 = head;struct ListNode* n3 = head->next;while(n2){n2->next = n1;n1 = n2;n2 = n3;if(n3){n3 = n3->next;}}return n1;
}

合并两个有序链表

1、题目:
1
2、思路:
  这个题建立一个新链表,取小的数尾插即可,这儿有一些技巧,可以建立一个头结点,直接尾插,这样就省去了考虑newHead为NULL的情况,这个方法,在一些题中有妙用!!!``

struct ListNode* mergeTwoLists(struct ListNode* l1, struct ListNode* l2) {if(l1==NULL){return l2;}if(l2==NULL){return l1;}//处理这个,建立一个头节点,把为NULL的一种可能性去掉struct ListNode* tmp = (struct ListNode*)malloc(sizeof(struct ListNode));struct ListNode* tail= tmp;while(l1&&l2){if(l1->val<l2->val){tail->next = l1;tail = l1;l1 = l1->next;}else{tail->next = l2;tail = l2;l2 = l2->next;}}if(l1){tail->next = l1;}if(l2){tail->next = l2;}return tmp->next;
}

下面是一个正常的做法!!!

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* mergeTwoLists(struct ListNode* l1, struct ListNode* l2) {if(l1 ==NULL){return l2;}if(l2 == NULL){return l1;}struct ListNode* newHead,*tail;newHead  = NULL;while(l1&&l2){if(l1->val<l2->val){if(newHead == NULL){newHead = tail = l1;}else{tail->next = l1;tail = l1;}l1 = l1->next;}else{if(newHead == NULL){newHead = tail = l2;}else{tail->next = l2;tail = l2;}l2 = l2->next;}}if(l1){tail->next = l1;}if(l2){tail->next = l2;}return newHead;
}

分割链表

1、题目:
1
2、思路:
 建立两个链表,一个是<x的链表,一个是>=x的链表,最后把这两个链表组合起来,返回头即可

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*///建立两个链表
//一个小于x
//一个大于等于x
struct ListNode* partition(struct ListNode* head, int x){/*  if(head == NULL){return NULL;}*/struct ListNode* litterHead = ( struct ListNode*)malloc(sizeof(struct ListNode));struct ListNode* litterTail = litterHead;struct ListNode* biggerHead = ( struct ListNode*)malloc(sizeof(struct ListNode));struct ListNode* biggerTail = biggerHead;struct ListNode* cur = head;while(cur){if(cur->val<x){litterTail->next =cur;litterTail = cur;cur = cur->next;}else{biggerTail->next = cur;biggerTail = cur;cur = cur->next;}}biggerTail->next = NULL;litterTail->next = biggerHead->next;return litterHead->next;
}

完结!!!

http://www.shuangfujiaoyu.com/news/28568.html

相关文章:

  • 手机wap版网站制作槐荫区网络营销seo
  • 哪个网站做舞蹈培训推广效果好友情链接怎么交换
  • 我自己做的网站一直没有效果怎么办如何网站优化排名
  • 简约网页免费的seo优化工具
  • wordpress站做appseo搜索引擎优化教程
  • 网店排行榜前十名重庆seo排名方法
  • 池州市网站建设优化商城小程序开发哪家好
  • wordpress form manager 下载广州seo推广运营专员
  • dw手机销售网站制作手机卡顿优化软件
  • 青岛高端网站开发公司南京百度关键字优化价格
  • 惠州做棋牌网站建设哪家便宜凡科建站登录官网
  • app资源网站开发seo网站排名优化价格
  • 网络网站建设谷歌关键词工具
  • 网站优化外链怎么做今日头条新闻
  • 深圳网站建设注册百度服务电话
  • 外贸网站推广哪家好登封网站建设公司
  • 朔州网站建设收费多少江西短视频seo搜索报价
  • web可以做3d网站吗网络营销模式下品牌推广研究
  • 北京高端网页建设桌子seo关键词
  • 杭州的互联网企业seo整站排名
  • 网站开发技术包括哪些网站建设推广专家服务
  • 做数据分析的网站广告发布平台app
  • 免费一键建站官网大全网络推广的好处
  • 石家庄哪里做微网站百度的企业网站
  • 网站怎么做图片放映效果seo职位招聘
  • 微信小程序可以做电影网站吗广告公司注册
  • 关于建设单位网站的方案百度电话号码
  • wordpress 企业邮箱指定关键词seo报价
  • php怎么给网站做spm白云百度seo公司
  • 自己做网站要多少钱网络推广自学