c++链表演示
#include<iostream>
#include<string.h>
#include<conio.h>
using namespace std;
#define MAXLEN 100
typedef struct
{
char key[];
char name[];
int age;
}DATA;
typedef struct
{
DATA ListData[MAXLEN + ];
int ListLen;
}SLType;
void SLInit(SLType*SL)//初始化顺序表
{
SL->ListLen = ;
}
int SLLength(SLType*SL)//返回顺序表的元素数量
{
return(SL->ListLen);
}
int SLInsert(SLType*SL, int n, DATA data)//只在表间插入
{
int i;
if (SL->ListLen >= MAXLEN)
{
cout << "顺序表已满,不能插入结点!\n";
return ;
}
if (n< || n>SL->ListLen - )//插入结点序号不正确
{
cout<<"插入结点的序号错误";
return ;
}
for (i = SL->ListLen; i >= n; i--)
{
SL->ListData[i + ] = SL->ListData[i];
}
SL->ListData[n] = data;
SL->ListLen++;
return ;//成功插入返回1
}
int SLAdd(SLType*SL, DATA data)
{
if (SL->ListLen >= MAXLEN)
{
cout << "顺序已满,不能再添加结点了" << endl;
return ;
}
SL->ListData[++SL->ListLen] = data;
return ;
}
int SLDelete(SLType* SL, int n)
{
int i;
if (n< || n>SL->ListLen + )
{
cout << "删除结点序号错误,不能删除";
return ;
}
for (i = n; i < SL->ListLen; i++)
{
SL->ListData[i] = SL->ListData[i + ];
}
SL->ListLen--;
return ;
}
DATA*SLFindByNum(SLType*SL, int n)
{
if (n< || n>SL->ListLen + )
{
cout << "结点序号错误,不能返回结点";
return NULL;
}
return &(SL->ListData[n]);
}
int SLFindByCont(SLType*SL, char *key)
{
int i;
for (i = ; i < SL->ListLen; i++)
{
if (strcmp(SL->ListData[i].key, key) == )
{
return i;//返回结点序号
}
}
return ;
}
int SLALL(SLType*SL)
{
int i;
for (i = ; i <=SL->ListLen; i++)
{
cout << SL->ListData[i].key << SL->ListData[i].name << SL->ListData[i].age << endl;
}
return ;
}
int main()
{
int i;
SLType SL;
DATA data;
DATA *pdata;
char key[];
cout << "顺序操作表演示" << endl;
SLInit(&SL);
cout << "链表初始化完成" << endl;
do
{
cout << "输入添加的结点(学号 姓名 年龄):" << endl;
fflush(stdin);//清空输入缓冲区
cin>>data.key>>data.name>>data.age;
if (data.age)//若年龄不为0
{
if (!SLAdd(&SL, data))
{
break;
}
}
else
{
break;
}
} while ();
cout << "顺序表中的结点顺序为:" << endl;
SLALL(&SL);//显示所有的结点数据
fflush(stdin);
cout << "要取出结点的序号:" << endl;
cin >> i;
pdata = SLFindByNum(&SL, i);
if (pdata)
{
cout << i << pdata->key << pdata->name << pdata->age << endl;
}
fflush(stdin);
cout << "要查找结点的关键字" << endl;
cin >> key;
i = SLFindByCont(&SL, key);
pdata = SLFindByNum(&SL, i);
if (pdata)
{
cout << i << pdata->key << pdata->name << pdata->age << endl;
}
getch();
return ;
}
c++链表演示的更多相关文章
- 链表插入和删除,判断链表是否为空,求链表长度算法的,链表排序算法演示——C语言描述
关于数据结构等的学习,以及学习算法的感想感悟,听了郝斌老师的数据结构课程,其中他也提到了学习数据结构的或者算法的一些个人见解,我觉的很好,对我的帮助也是很大,算法本就是令人头疼的问题,因为自己并没有学 ...
- 链表创建和链表遍历算法的演示_C语言
今天搞了一个多小时,头是疼的,应该是没休息好吧,学习了数据结构这一节,感觉收益良多,下面贴上代码和心得: /*24_链表创建和链表遍历算法的演示*/ # include <stdio.h> ...
- php实现找两个链表的第一个公共结点(实例演示)
php实现找两个链表的第一个公共结点(实例演示) 一.总结 因为是链表,第一个节点公共之后,后面所有的节点都公共了 画个图实例演示一下,会超清晰且简单 二.php实现找两个链表的第一个公共结点 题目描 ...
- 静态链表过程演示及代码实现(A - B) U (B - A)
静态链表说明 使用数组来实现链式存储结构,目的是方便在不设指针类型的高级程序设计语言中使用链式结构 c语言定义数据结构 #define MAX_SIZE 1000 // 所有的类型都统一定义为Elem ...
- 28_链表插入和删除算法的演示.swf
#include<stdio.h> #include<malloc.h> #include <stdio.h> #include <stdlib.h> ...
- C(C++)/ 数据结构 链表
内容概括: 一.链表简介及创建列表 二.添加节点 三.链表排序 代码编译平台: CentOS 6.4 64b 一.链表简介及创建列表: 传统数组缺点: 传统数组长度需要事先设定,不能改变,内存由系统自 ...
- 分离的思想结合单链表实现级联组件:CascadeView
本文介绍自己最近做省市级联的类似的级联功能的实现思路,为了尽可能地做到职责分离跟表现与行为分离,这个功能拆分成了2个组件并用到了单链表来实现关键的级联逻辑,下一段有演示效果的gif图.虽然这是个很常见 ...
- c++实现简单的链表
注:我是一个编程菜鸟,哪个大神看出来缺陷提点一下,感激不尽. 链表由一个个的节点串联而成,同一由first头指针管理,属于线性表中相比于数组,添加删除方便,但访问又有点慢的数据结构. 第一步:节点 N ...
- C语言链表中数组实现数据选择排序,升序、降序功能主要难点
链表排序讲解: head指针指向链表的头结点,是找到整个链表的唯一依据,如果head指针丢失,整个链表就找不到了. head存储的是第一个节点的地址,head->next存储的是第二个节点的地址 ...
随机推荐
- 「SP10628 COT - Count on a tree」
主席树的综合运用题. 前置芝士 可持久化线段树:其实就是主席树了. LCA:最近公共祖先,本题需要在\(\log_2N\)及以内的时间复杂度内解决这个问题. 具体做法 主席树维护每个点到根节点这一条链 ...
- 在win10中启动redis
1.输入命令"redis-server.exe redis.windows.conf ",按回车键, 2.输入“redis-cli.exe -h 127.0.0.1 -p 6379 ...
- java各种面试问题
二.Java多线程相关 线程池的原理,为什么要创建线程池?创建线程池的方式: 线程的生命周期,什么时候会出现僵死进程: 说说线程安全问题,什么实现线程安全,如何实现线程安全: 创建线程池有哪几个核心参 ...
- 题解 JSOI2010 找零钱的洁癖
题解 JSOI2010 找零钱的洁癖 题面 BZOJ 个人体会 van全没有思路... 只能去看题解... 还是个bfs+贪心 不管怎样竟然乱搞过了... 听M_sea小姐姐说她有更正经的做法(线性规 ...
- NetCore Web项目目录结构说明
目录结构说明 目录/文件 说明 依赖项 ASP.NET Core 开发.构建和运行过程中的依赖想,一般都是 NuGet 包和一些 SDK Properties 配置,存放了一些 .json 文件用于配 ...
- ADO.NET基础必背知识
DO.NET 由.Net Framework 数据提供程序和DataSet 两部分构成. .NET FrameWork 是 Connection 连接对象 Command 命令对象 DataRe ...
- Java Hashtable遍历与方法使用
参考文档 我参考了Java 集合系列11之 Hashtable详细介绍(源码解析)和使用示例,阅读了jdk 1.8的源码 Hashtable的继承关系 Hashtable继承了Dictionary类, ...
- java第二次课件课后动手动脑习题整理总结(2019年9月23号)
一.动手动脑 1 1.题目 2.程序源代码 package yang8; import java.util.Scanner; import java.util.Random; public class ...
- day16-Python运维开发基础(os / os.path / shutil模块)
1. OS模块与shutil模块 os :新建/删除shutil: 复制/移动 # ### os模块 与 shutil模块 """ os 新建/删除 shutil 复制/ ...
- 小笔记----about JC
JC project JAVA,Mysql. 页面用velocity template engine render的html/css Apache Velocity template engine ...