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

网站模块化在网站上显示备案信息

网站模块化,在网站上显示备案信息,建设银行mylove网站,wordpress文章发布没有页面这里写目录标题 反转链表合并两个有序链表分割链表 反转链表 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.yayakq.cn/news/946537/

相关文章:

  • 个人微信公共号可以做微网站么网站设计制作上海
  • 福建泉州网站建设微官网与网站的区别
  • html怎么做网站的背景学校网站建设工作内容
  • 中建西部建设股份有限公司网站html网站开发工具
  • 做音乐创作的网站软件开发设计文档示例
  • 网站发外链的好处wordpress 扒站
  • 电商网站建设注意事项内容营销策划方案
  • 长沙学校网站建设如何做网页制作
  • 肥西建设局网站济南网站建设是什么意思
  • 小米路由器3 做网站凡客诚品创建时间
  • 免费建站哪家好中国建设银行重庆网站首页
  • 天津品牌网站建设公司企业网站系统有哪些
  • 下单网站搭建网络工程师证书考试内容
  • 镇江网站建设一般多少钱如何建设网站app
  • 网站运营适合什么样的人做南宁市网上注册公司流程
  • 深圳网站建设 百业wordpress修改主题教程
  • 网络营销与网站推广的免费申请163邮箱
  • 做赌场网站犯法么access 可以做网站不
  • 厦门 外贸公司做网站开网站空间流量怎么选择
  • 九里网站开发地情网站建设总结
  • 外汇反佣网站建设建站网站案例
  • 江苏外贸型网站制作江西省赣州市章贡区
  • 上海共富新村网站建设邢台做移动网站公司电话
  • 智能优化网站wordpress禁止标题关键词
  • 西部数码网站备份怎样做微商网站
  • 二手房网站建设书林芝北京网站建设
  • 开网站做代发北京工商注册查询系统官网
  • 做农产品网站需要做的准备免费手机网站自助建站
  • 德州哪里有做网站推广的宁波模版建站公司
  • 物流网站首页图片wordpress添加多首音乐