main.cpp
1 #include "myDataBase.h"
2
3 int main()
4 {
5 int i =0;
6 myDataBase::GetInstance().createDataBaseList();
7 for(i=0;i<3 ; ++i)
8 {
9 string str;
10 cin >> str;
11 myDataBase::GetInstance().InsertListDataTail(i,str);
12 }
13 myDataBase::GetInstance().ShowDataBaseList();
14
15 return 0;
16 }

  myDataBase.h

 1 #ifndef _MYDATABASE_H
2 #define _MYDATABASE_H
3
4 #include <cstddef>//NULL 需要使用的头文件
5 #include <iostream>
6 #include <strings.h>
7 using namespace std;
8
9 //Data content
10 class dataContent{
11 public:
12 int key;
13 string name;
14 };
15
16 /*存储连表的class*/
17 class node{
18 public:
19 //数据
20 dataContent data ;
21 //int data;
22 //指向下一个数据区的指针
23 struct node *Next;
24 };
25
26 /*Data content
27 class dataContent{
28 int key;
29 string name;
30 };*/
31
32
33 /*对连表操作的class*/
34 class myDataBase{
35 public:
36 //构造函数
37 myDataBase();
38 //析构函数
39 ~myDataBase();
40 //创建链表
41 void createDataBaseList();
42 //show连表里面的数据
43 void ShowDataBaseList();
44 //数据的尾部插入操作
45 bool InsertListDataTail(int data,std::string & name);
46 //获取类的句柄
47 static myDataBase& GetInstance();
48
49 private:
50 //定义了头节点
51 node *pNode;
52 };
53
54 #endif

myDataBase.cpp


1 #include "myDataBase.h"
2
3 myDataBase::myDataBase()
4 {
5 pNode = NULL;
6 }
7
8 void myDataBase::createDataBaseList()
9 {
10 pNode = new node;
11
12 pNode->data.key=0;
13 pNode->Next = NULL;
14
15 return ;
16 }
17
18
19 bool myDataBase::InsertListDataTail(int data, std::string & name)
20 {
21 node * subNode = new node;
22 if(subNode == NULL)
23 {
24 cout<< "subNode create error!"<<endl;
25
26 return false;
27 }
28
29 subNode->data.key = data;
30 subNode->data.name = name;
31 subNode->Next = NULL;
32
33 node *temNode = pNode;
34
35 while(temNode->Next != NULL)
36 {
37 temNode = temNode->Next;
38 }
39
40 temNode->Next = subNode;
41
42 return true;
43 }
44
45
46 void myDataBase::ShowDataBaseList()
47 {
48 node * tempNode = pNode;
49 if(tempNode == NULL)
50 {
51 return ;
52 }
53
54 do{
55 if( (tempNode = tempNode->Next ) == NULL )
56 {
57 break;
58 }
59 else
60 {
61 cout<<"key: "<<tempNode->data.key<<"\t name :"<<tempNode->data.name<<endl;
62 }
63 }while(tempNode->Next);
64
65 return ;
66 }
67
68
69 static myDataBase *m_instance = NULL;
70
71 myDataBase &myDataBase::GetInstance()
72 {
73 if(m_instance == NULL)
74 {
75 m_instance = new myDataBase;
76 if(m_instance == NULL)
77 {
78 cout<< "create myDataBase class err!"<<endl;
79 exit(0);
80 }
81 }
82 return *m_instance;
83 }
1 运行结果显示
2 ****@****:~/桌面/myDataBaseList/myDataBaseList$ ./main
3 i
4 love
5 u
6 key: 0 name :i
7 key: 1 name :love
8 key: 2 name :u
9 zhou_jiang@zhoujiang:

C++实现链表---可直接运行通过的更多相关文章

  1. 深度剖析linux内核万能--双向链表,Hash链表模版

    我们都知道,链表是数据结构中用得最广泛的一种数据结构,对于数据结构,有顺序存储,数组就是一种.有链式存储,链表算一种.当然还有索引式的,散列式的,各种风格的说法,叫法层出不穷,但是万变不离其中,只要知 ...

  2. 图解Java数据结构之单链表

    本篇文章介绍数据结构中的单链表. 链表(Linked List)介绍 链表可分为三类: 单链表 双向链表 循环列表 下面具体分析三个链表的应用. 单链表 链表是有序的列表,它在内存中存储方式如下: 虽 ...

  3. [代码记录] C语言链表

    #开始 · 简单的创建链表 #代码 #include<conio.h> #include<stdio.h> #include<stdlib.h> struct St ...

  4. 【Weiss】【第03章】练习3.11:比较单链表递归与非递归查找元素

    [练习3.11] 编写查找一个单链表特定元素的程序.分别用递归和非递归实现,并比较它们的运行时间. 链表必须达到多大才能使得使用递归的程序崩溃? Answer: 实现都是比较容易的,但是实际上查找链表 ...

  5. Contiki-一个进程的例子

    进程调度器 进程调度器的作用是调用进程.进程调度器通过调用实现进程线程的函数来调用进程.Contiki中所有的进程被设计为响应传递到进程中的事件,或者相应进程请求的轮询.进程调度器在调度进程的时候会将 ...

  6. [HDU1017]Exact cover[DLX][Dancing Links详解][注释例程学习法]

    Dancing Links解决Exact Cover问题. 用到了循环双向十字链表. dfs. 论文一知半解地看了一遍,搜出一篇AC的源码,用注释的方法帮助理解. HIT ACM 感谢源码po主.链接 ...

  7. HashMap 底层算法分析

    详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp72 Hash算法HashMap使用Hash算法,所以在解剖HashMap ...

  8. 理解channel 工作原理以及源码

    Go 的并发特性  goroutines: 独立执行每个任务,并可能并行执行 channels: 用于 goroutines 之间的通讯.同步 一个简单的事务处理的例子  对于下面这样的非并发的程序: ...

  9. 【Java集合系列五】HashMap解析

    2017-07-31 19:36:00 一.简介 1.HashMap作用及使用场景 HashMap利用数组+单向链表的方式,实现了key-value型数据的存储功能.HashMap的size永远是2^ ...

随机推荐

  1. Hadoop 2.6.1 集群安装配置教程

    集群环境: 192.168.56.10 master 192.168.56.11 slave1 192.168.56.12 slave2 下载安装包/拷贝安装包 # 存放路径: cd /usr/loc ...

  2. Elementor如何隐藏页面上的标题(2种办法)

    原文首发于:https://loyseo.com/how-to-hide-page-title-in-elementor/ 本文介绍两种隐藏Elementor页面默认标题的方法,一种是单个隐藏,一种是 ...

  3. Linux离线安装mysql 5.6详细步骤

    一.安装MySQL 1.下载安装包 mysql-5.6.40-linux-glibc2.12-x86_64.tar.gz 2.卸载系统自带的Mariadb rpm -qa|grep mariadb / ...

  4. (几乎)完美实现 el-table 列宽自适应

    背景 Element UI 是 PC 端比较流行的 Vue.js UI 框架,它的组件库基本能满足大部分常见的业务需求.但有时候会有一些定制性比较高的需求,组件本身可能没办法满足.最近在项目里就碰到了 ...

  5. 国内几大seo高手(夫唯,王通,久久)的技术分析

    http://www.wocaoseo.com/thread-146-1-1.html 目前学习seo的人越来越多了,这种技术的普及和推广也在不断的扩大,先进的好的培训机构不断涌现,很多高水平老师都在 ...

  6. Qt QString转char[]数组

    Qt QString转char[]数组 QString s1="1234456";char str[20]={0};strcpy(str,s1.toStdString().c_st ...

  7. 力扣Leetcode 983. 最低票价

    最低票价 在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行.在接下来的一年里,你要旅行的日子将以一个名为 days 的数组给出.每一项是一个从 1 到 365 的整数. 火车票有三种不同的销 ...

  8. python练习 数字不同数之和+人名最多数统计

    数字不同数之和 描述 获得用户输入的一个整数N,输出N中所出现不同数字的和.‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬ ...

  9. Struts+Servlet+JDBC网上手机销售系统

    项目描述 Hi,大家好,今天给大家分享一个<网上手机销售系统>.本系统一共分为前台和后台两大模块,两个模块之间虽然在表面上是相互独立的,但是在对数据库的访问上是紧密相连的,各个模块访问的是 ...

  10. VuePress初探(一)

    原文参考链接 手把手教你使用 VuePress 搭建个人博客 有阅读障碍的同学,可以跳过第一至四节,下载我写好的工具包: git clone https://github.com/zhangyunch ...