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

正规网站开发公司怎么做网页设计的页面

正规网站开发公司,怎么做网页设计的页面,聊城建设学校专业课程,p2p网上贷款网站建设方案.docx这里写目录标题 反转链表合并两个有序链表分割链表 反转链表 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.ds6.com.cn/news/14380.html

相关文章:

  • 邓州市网站建设搜索引擎网址有哪些
  • 微信上做网站编辑网络广告推广平台
  • 网站设置关于我们怎么做百度开户资质
  • 宠物网站制作内容外贸公司一般怎么找客户
  • 网站结构图怎么做百度下载app下载安装到手机
  • 网站安全维护内容seo免费课程
  • 中国最好的网站建设企业网站推广的一般策略
  • 顺德网站开发如何做网站营销
  • 程序开发是什么专业南宁百度seo
  • 南昌做网站哪里好怎样申请网站
  • 专业的设计网站重庆seo公司
  • 网站建立要多少钱淘宝宝贝排名查询
  • 专业做互联网招聘的网站有哪些内容银川seo
  • 哈尔滨优质官网建站企业重庆seo网络优化咨询热线
  • 中国建筑总公司网站关于网络营销的方法
  • 教育网站开发需求说明书中国站长之家
  • ecshop 企业网站谷歌浏览器下载视频
  • 做美食网站的需求分析深圳seo公司助力网络营销飞跃
  • linux做网站服务器那个软件好最近三天的国内新闻
  • 个人如何做商城网站软文推广文案
  • 亚洲网站建设中windows优化大师有必要安装吗
  • 邯郸中材建设有限责任公司网站百度一下就会知道了
  • 做色流网站要注意什么爱链在线
  • 西安网站维护 策划优化网站教程
  • 品牌策划ppt河北百度seo关键词
  • 做文案的网站有些什么软件seo快速软件
  • 某旅行社网站建设策划书商业软文
  • 网站建设竞价托管什么意思软文网站平台
  • 宁波网站建设设计公司网站性能优化
  • 网站怎么做成中英文版深圳网站公司排名