408王道数据结构课后代码习题(XII)

简介: 408王道数据结构课后代码习题(XII)

10


image.png


  • 遍历,设一个变量查看奇偶,分别插入
  • 保持相对顺序不变,采用尾插法
  • 时间复杂度O(n),空间复杂度O(1)


void splitList(LinkList L, LinkList &A, LinkList &B) {
  // 1.创建工作指针
  LNode *p = L->next, *pa = A, *pb = B;
  int i = 1;
  while (p != NULL) {
    // 2.采用尾插法分别插入
    if (i % 2 != 0) {
      pa->next = p;
      pa = p;
    } else {
      pb->next = p;
      pb = p;
    }
    p = p->next;    // 继续处理
    i++;
  }
  // 3.最后设为空
  pa->next = NULL;
  pb->next = NULL;
}
复制代码


  • 当然你也可以不使用变量记录奇偶,一次循环处理两个就可以了


void splitList2(LinkList L, LinkList &A, LinkList &B) {
  // 1.创建工作指针
  LNode *p = L->next, *pa = A, *pb = B;
  while (p != NULL) {
    // 2.采用尾插法分别插入
    pa->next = p;
    pa = p;
    p = p->next;    // 继续处理
    if (p != NULL) {
      pb->next = p;
      pb = p;
      p = p->next;    // 继续处理
    } 
  }
  // 3.最后设为空
  pa->next = NULL;
  pb->next = NULL;
}
复制代码


11

image.png


  • 与上一题类似,不过在插入B时需要采用头插法使其逆序
  • 头插时要注意记录后继元素,防止断链
  • 就地算法,时间复杂度O(n),空间复杂度O(1)


void splitList(LinkList L, LinkList &A, LinkList &B) {
  // 1.创建工作指针
  LNode *p = L->next, *pa = A;
  int i = 1;
  while (p != NULL) {
    // 2.分别采用头插法和尾插法插入
    if (i % 2 != 0) {
      pa->next = p;
      pa = p;
      p = p->next;
    } else {
      LNode *q = p->next;   // 记录p的后继防止断链
      p->next = B->next;
      B->next = p;
      p = q;
    }
    i++;
  }
  // 3.收尾
  pa->next = NULL;
}
复制代码


  • 同上也可以不使用变量记录奇偶


void splitList2(LinkList L, LinkList &A, LinkList &B) {
  // 1.创建工作指针
  LNode *p = L->next, *pa = A;
  while (p != NULL) {
    // 2.分别采用头插法和尾插法插入
    pa->next = p;
    pa = p;
    p = p->next;
    if (p != NULL) {
      LNode *q = p->next;   // 记录p的后继防止断链
      p->next = B->next;
      B->next = p;
      p = q;
    }
  }
  // 3.收尾
  pa->next = NULL;
}


目录
相关文章
|
18小时前
|
存储 算法 安全
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
数据结构与算法系列学习之串的定义和基本操作、串的储存结构、基本操作的实现、朴素模式匹配算法、KMP算法等代码举例及图解说明;【含常见的报错问题及其对应的解决方法】你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
|
19小时前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习(8)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
22小时前
|
存储 算法 安全
2024重生之回溯数据结构与算法系列学习之顺序表【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
顺序表的定义和基本操作之插入;删除;按值查找;按位查找等具体详解步骤以及举例说明
|
19小时前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
21小时前
|
存储 Web App开发 算法
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
19小时前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
22小时前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之顺序表习题精讲【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
顺序表的定义和基本操作之插入;删除;按值查找;按位查找习题精讲等具体详解步骤以及举例说明
|
22小时前
|
存储 算法 安全
2024重生之回溯数据结构与算法系列学习【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构的基本概念;算法的基本概念、特性以及时间复杂度、空间复杂度等举例说明;【含常见的报错问题及其对应的解决方法】
|
19小时前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之王道第2.3章节之线性表精题汇总二(5)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
IKU达人之数据结构与算法系列学习×单双链表精题详解、数据结构、C++、排序算法、java 、动态规划 你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
20天前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
18 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器