IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> c语言或c++读取一组数字/输入创建链表/遍历打印链表/ -> 正文阅读

[C++知识库]c语言或c++读取一组数字/输入创建链表/遍历打印链表/

一 c语言实现

/**
 * @file CreateList.cpp
 * @author Crazyfox
 * @brief c语言实现链表创建
 * @version 1.0
 * @history
 *   1.Date: 2021-07-15
 *     Version: 1.0
 *     Modification: First release
 * @copyright Copyright (c) 2021
 *
 */
#include <stdio.h>
#include <stdlib.h>

/**
 * 单链表结点
 */
struct ListNode {
  int data;
  struct ListNode* next;
};

/**
 * @brief 尾插法创建不带头结点的单链表
 * @param array 数据数组
 * @param sz 数组有效尺寸
 * @return 创建的单链表的头指针
 */
ListNode* CreateList(int array[], int sz) {
  ListNode* guard = (ListNode*)malloc(sizeof(ListNode)); //哨兵结点
  guard->next = NULL;
  ListNode* back = guard;
  for (int i=0; i<sz; ++i) {
    ListNode* cur = (ListNode*)malloc(sizeof(ListNode));
    cur->data = array[i];
    back->next = cur;
    back = cur;
  }
  back->next = NULL;
  return guard->next;
}

/**
 * @brief 打印单链表
 * @param head
 */
void PrintList(ListNode* head) {
  while (head) {
    printf("%d ", head->data);
    head = head->next;
  }
}
int main(int argc, char** argv) {
  // 0.处理输入数据
  int data_array[100];
  int sz = 0;
  while (scanf("%d", &data_array[sz++]) != EOF) {
    if (getchar() == '\n') break;
  }

  // 1.创建链表
  ListNode* head = CreateList(data_array, sz);

  // 2.打印链表
  PrintList(head);
  return 0;
}

二 c++实现

/**
 * @file CreateList2.cpp
 * @author Crazyfox
 * @brief c++实现链表创建
 * @version 1.0
 * @history
 *   1.Date: 2021-07-15
 *     Version: 1.0
 *     Modification: First release
 * @copyright Copyright (c) 2021
 *
 */

#include <vector>
#include <iostream>

using namespace std;

/**
 * 单链表结点结构体
 */
struct ListNode {
  int data;
  struct ListNode* next;
  ListNode(int i) : data(i), next(nullptr) {}
};

/**
 * @brief 创建单链表
 * @param inputs 输入数据容器
 * @return 创建的单链表的头指针
 */
ListNode* CreateList(const vector<int> &inputs) {
  ListNode* guard = new ListNode(0);
  ListNode* back = guard;
  for (const auto &m : inputs) {
    ListNode* cur = new ListNode(m);
    back->next = cur;
    back = cur;
  }
  return guard->next;
}

/**
 * @brief 打印单链表
 * @param head 单链表头指针
 */
void PrintList(ListNode* head) {
  while(head) {
    cout << head->data << " ";
    head = head->next;
  }
  cout << endl;
}

int main (int argc, char** argv) {
  // 1.处理输入数据
  vector<int> inputs;
  int in;
  while(cin >> in) {
    inputs.push_back(in);
    if(getchar() == '\n') break;
  }

  // 2.创建链表
  ListNode* head = CreateList(inputs);

  // 3.打印链表
  PrintList(head);

  return 0;
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-16 11:05:17  更:2021-07-16 11:07:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年4日历 -2024/4/28 7:27:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码