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

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

2.3.7, 6

image.png


  • 把链表数据取出来放到数组里排序,然后再将排好序的数放回链表
  • 典型的空间换时间,排序时间复杂度O(nlog2n),空间复杂度O(n)


void sortList(LinkList &L, int len) {
  // 1.将链表数据复制到数组中
  LNode *head = L->next;
  int a[len], i = 0;
  while (head != NULL) {
    a[i++] = head->data;
    head = head->next;
  }
  // 2.排序
  sort(a, a+len);
  // 3.将排序后的数组复制回链表
  head = L->next, i = 0;
  while (head != NULL) {
    head->data = a[i++];
    head = head->next;
  }
}
复制代码


  • 插入排序,首先构造一个只有一个结点的有序列表pre
  • 剩下的p链表中的元素分别找位置插入即可
  • 时间复杂度O(n2),空间复杂度O(1)


void sortList2(LinkList &L) {
  LNode *p = L->next, *pre;
  LNode *q = p->next;
  p->next = NULL;     // 1.构建只有一个结点的有序链表
  p = q;
  // 2.分别查找位置插入
  while (p != NULL) {
    q = p->next;
    pre = L;
    // 找到有序的位置
    while (pre->next != NULL && pre->next->data < p->data) {
      pre = pre->next;
    }
    // 插入
    p->next = pre->next;
    pre->next = p;
    p = q;
  }
}
复制代码

2.3.7, 7

image.png


  • 这题非常的简单,直接遍历逐个检查,不符合就删除
  • 双指针,删除必须有其前驱指针
  • 时间复杂度O(n),空间复杂度O(1)


void delRange(LinkList &L, int min, int max) {
  LNode *p = L->next, *pre = L;
  while (p != NULL) {
    if (p->data > min && p->data < max) {
      // 在范围内就删除
      pre->next = p->next;
      free(p);
      p = pre->next;
    } else {
      // 不在范围内就继续遍历
      pre = pre->next;
      p = p->next;
    }
  }
}


目录
相关文章
|
11天前
|
存储 算法
【单向链表】数据结构——单向链表的介绍与代码实现&笔记
【单向链表】数据结构——单向链表的介绍与代码实现&笔记
|
11天前
|
搜索推荐 算法
【排序】数据结构——排序算法概念及代码详解(插入、冒泡、快速、希尔)
【排序】数据结构——排序算法概念及代码详解(插入、冒泡、快速、希尔)
|
5天前
|
算法
数据结构和算法常见的问题和代码
数据结构和算法常见的问题和代码
|
15天前
|
存储 机器学习/深度学习 缓存
【数据结构】布隆过滤器原理详解及其代码实现
【数据结构】布隆过滤器原理详解及其代码实现
|
22天前
|
算法 C语言
数据结构和算法——桶排序和基数排序(图示、伪代码、多关键字排序,基数排序代码)
数据结构和算法——桶排序和基数排序(图示、伪代码、多关键字排序,基数排序代码)
11 0
|
22天前
|
算法 C语言
数据结构和算法——归并排序(有序子列的归并、递归算法、非递归算法、思路图解、C语言代码)
数据结构和算法——归并排序(有序子列的归并、递归算法、非递归算法、思路图解、C语言代码)
12 0
|
22天前
|
存储 算法 C语言
数据结构和算法——堆排序(选择排序、思路图解、代码、时间复杂度、堆排序及代码)
数据结构和算法——堆排序(选择排序、思路图解、代码、时间复杂度、堆排序及代码)
14 0
|
22天前
|
算法 Shell C语言
数据结构与算法——希尔排序(引例、希尔增量序列、原始希尔排序、代码、时间复杂度、Hibbard增量序列、Sedgewick增量序列)
数据结构与算法——希尔排序(引例、希尔增量序列、原始希尔排序、代码、时间复杂度、Hibbard增量序列、Sedgewick增量序列)
15 0
|
22天前
|
人工智能 算法 C语言
数据结构与算法——简单排序-冒泡排序、插入排序,时间复杂度下界(图示、代码、时间复杂度、定理)
数据结构与算法——简单排序-冒泡排序、插入排序,时间复杂度下界(图示、代码、时间复杂度、定理)
17 0
|
22天前
|
算法 C语言
数据结构与算法——拓扑排序(引例、拓扑排序、伪代码、代码、关键路径问题)
数据结构与算法——拓扑排序(引例、拓扑排序、伪代码、代码、关键路径问题)
15 0