鱼C论坛

 找回密码
 立即注册
查看: 660|回复: 1

[已解决]单链表逆置

[复制链接]
发表于 2024-10-18 17:24:24 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
将单链表倒置,要求只利用原表的存储空间。

原单链表如下所示:图片.png

倒置后的单链表应为:

1.png

输入格式:
第一行输入n的值,表示单链表的元素个数。
第二行输入n个整数值,作为单链表的各元素值。

输出格式:
输出倒置后的单链表的各元素值,各元素值之间用空格分隔。

输入样例1:
4
2 4 6 8

输出样例1:
8 6 4 2

输入样例2:
7
1 3 5 7 9 11 13

输出样例2:
13 11 9 7 5 3 1

4
2 4 6 8
8 6 4 2

这题用C++怎么做
最佳答案
2024-10-18 17:24:35
要在C++中实现单链表逆置,且只利用原链表的存储空间,可以通过指针操作来改变链表的节点指向。以下是一个简单的实现:

  1. #include <iostream>

  2. struct Node {
  3.     int data;
  4.     Node* next;
  5.     Node(int val) : data(val), next(nullptr) {}
  6. };

  7. class LinkedList {
  8. public:
  9.     Node* head;

  10.     LinkedList() : head(nullptr) {}

  11.     void append(int val) {
  12.         if (!head) {
  13.             head = new Node(val);
  14.         } else {
  15.             Node* temp = head;
  16.             while (temp->next) {
  17.                 temp = temp->next;
  18.             }
  19.             temp->next = new Node(val);
  20.         }
  21.     }

  22.     void reverse() {
  23.         Node* prev = nullptr;
  24.         Node* current = head;
  25.         Node* next = nullptr;
  26.         
  27.         while (current) {
  28.             next = current->next;  // Save next
  29.             current->next = prev;  // Reverse current node's pointer
  30.             prev = current;        // Move pointers one position forward
  31.             current = next;
  32.         }
  33.         head = prev;
  34.     }

  35.     void print() const {
  36.         Node* temp = head;
  37.         while (temp) {
  38.             std::cout << temp->data;
  39.             if (temp->next) {
  40.                 std::cout << " ";
  41.             }
  42.             temp = temp->next;
  43.         }
  44.         std::cout << "\n";
  45.     }
  46. };

  47. int main() {
  48.     int n;
  49.     std::cin >> n;
  50.     LinkedList list;

  51.     for (int i = 0; i < n; ++i) {
  52.         int val;
  53.         std::cin >> val;
  54.         list.append(val);
  55.     }

  56.     list.reverse();
  57.     list.print();

  58.     return 0;
  59. }
复制代码


### 代码说明:
- **Node 结构体**:用于表示链表节点,包含数据和指针用于指向下一个节点。
- **LinkedList 类**:用于管理链表,包括添加新节点 (`append` 方法)、反转链表 (`reverse` 方法) 和打印链表 (`print` 方法) 的功能。
- **reverse 方法**:通过改变节点的指向来逆置链表,不需要额外的存储空间。
- **main 函数**:负责输入并调用上述功能进行链表处理。

通过这个程序,你可以输入链表长度和元素,然后得到逆置后的结果。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2024-10-18 17:24:35 | 显示全部楼层    本楼为最佳答案   
要在C++中实现单链表逆置,且只利用原链表的存储空间,可以通过指针操作来改变链表的节点指向。以下是一个简单的实现:

  1. #include <iostream>

  2. struct Node {
  3.     int data;
  4.     Node* next;
  5.     Node(int val) : data(val), next(nullptr) {}
  6. };

  7. class LinkedList {
  8. public:
  9.     Node* head;

  10.     LinkedList() : head(nullptr) {}

  11.     void append(int val) {
  12.         if (!head) {
  13.             head = new Node(val);
  14.         } else {
  15.             Node* temp = head;
  16.             while (temp->next) {
  17.                 temp = temp->next;
  18.             }
  19.             temp->next = new Node(val);
  20.         }
  21.     }

  22.     void reverse() {
  23.         Node* prev = nullptr;
  24.         Node* current = head;
  25.         Node* next = nullptr;
  26.         
  27.         while (current) {
  28.             next = current->next;  // Save next
  29.             current->next = prev;  // Reverse current node's pointer
  30.             prev = current;        // Move pointers one position forward
  31.             current = next;
  32.         }
  33.         head = prev;
  34.     }

  35.     void print() const {
  36.         Node* temp = head;
  37.         while (temp) {
  38.             std::cout << temp->data;
  39.             if (temp->next) {
  40.                 std::cout << " ";
  41.             }
  42.             temp = temp->next;
  43.         }
  44.         std::cout << "\n";
  45.     }
  46. };

  47. int main() {
  48.     int n;
  49.     std::cin >> n;
  50.     LinkedList list;

  51.     for (int i = 0; i < n; ++i) {
  52.         int val;
  53.         std::cin >> val;
  54.         list.append(val);
  55.     }

  56.     list.reverse();
  57.     list.print();

  58.     return 0;
  59. }
复制代码


### 代码说明:
- **Node 结构体**:用于表示链表节点,包含数据和指针用于指向下一个节点。
- **LinkedList 类**:用于管理链表,包括添加新节点 (`append` 方法)、反转链表 (`reverse` 方法) 和打印链表 (`print` 方法) 的功能。
- **reverse 方法**:通过改变节点的指向来逆置链表,不需要额外的存储空间。
- **main 函数**:负责输入并调用上述功能进行链表处理。

通过这个程序,你可以输入链表长度和元素,然后得到逆置后的结果。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-9 15:07

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表