顺序表的基本操作(C)
在顺序存储结构实现基本操作:初始化、创建、插入、删除、查找、遍历、逆置、合并运算。
运行示例:
请输入线性表La的长度:
请输入线性表La中的元素(共5个) *** 此时线性表La中的元素 *** *** 插入数据 ***
请输入要插入的位置:
请输入要插入的元素:
*** 此时线性表La中的元素 *** *** 删除数据 ***
请输入要删除元素的位置:
*** 此时线性表La中的元素 *** *** 查找数据 ***请输入要查找的元素:
顺序表中没有3这个元素!
*** 顺序表逆置 ***
*** 此时线性表La中的元素 *** *** 初始化线性表Lb ***
请输入线性表Lb的长度:
请输入线性表Lb中的元素(共5个) *** 此时线性表Lb中的元素 *** *** 合并线性表La 和 Lb ***
*** 此时线性表Lc中的元素 ***
//#########################################################
// 顺序表上的基本操作实现
// 初始化、创建、插入、删除、查找、遍历、逆置、合并
//#########################################################
#define _CRT_SECURE_NO_DEPRECATE
#include<stdio.h> #define MAX_SIZE 100 typedef int ElemType; //定义结构体SeqList
typedef struct
{
ElemType list[MAX_SIZE];
int size;
} SeqList; //初始化顺序表
void ListInit(SeqList *L)
{
//定义初始元素的个数
L->size = ;
} //插入数据元素
void ListInsert(SeqList *L, int i, ElemType e)
{
int j;
if (L->size >= MAX_SIZE)
{
printf("顺序表已满,无法插入!\n");
}
else if (i < || i > L->size)
{
printf("i must be 0 - %d\n", L->size);
}
else
{
for (j = L->size; j > i - ; j--)
{
L->list[j] = L->list[j - ];
}
L->list[i - ] = e;
L->size++;
}
} //删除数据元素
void ListDelete(SeqList *L, int i)
{
int j = ;
if (L->size <= )
{
printf("顺序表中已空!\n");
}
else if (i < || i > L->size)
{
printf("i must be 0 - %d\n", L->size);
}
else
{
for (j = i; j <= L->size - ; j++)
{
L->list[j - ] = L->list[j];
}
L->size--;
}
} //查找数据元素
void ListSearch(SeqList *L, ElemType e)
{
int i;
for (i = ; i < L->size; i++)
{
if (L->list[i] == e)
{
printf("%d在顺序表中第%d个位置\n", e, i + );
return;
}
}
printf("顺序表中没有%d这个元素!\n", e);
} //显示元素
void ListDisplay(SeqList *L)
{
int i;
for (i = ; i < L->size; i++)
{
printf("%d\t", L->list[i]);
}
printf("\n");
} //逆置顺序表
void ListReverse(SeqList *L)
{
int i;
ElemType temp;
for (i = ; i < (L->size / ); i++)
{
temp = L->list[i];
L->list[i] = L->list[L->size - i - ];
L->list[L->size - i - ] = temp;
}
} //合并数据表
void ListMerge(SeqList *L1, SeqList *L2, SeqList *L3)
{
int i = , j = , k = ;
while (i < L1->size&&j < L2->size)
{
if (L1->list[i] < L2->list[j])
{
L3->list[k] = L1->list[i];
i++;
k++;
}
else
{
L3->list[k] = L2->list[j];
j++;
k++;
}
}
while (i < L1->size)
{
L3->list[k++] = L1->list[i++];
}
while (j < L2->size)
{
L3->list[k++] = L1->list[j++];
}
L3->size = k;
} int main()
{
SeqList La, Lb, Lc;
int i, e;
int m, n; printf("*** 初始化线性表La ***\n");
ListInit(&La);
printf("请输入线性表La的长度:");
scanf("%d", &m);
La.size = m;
printf("请输入线性表La中的元素(共%d个)\n", m);
for (i = ; i < m; i++)
{
scanf("%d", &La.list[i]);
}
printf("*** 此时线性表La中的元素 ***\n");
ListDisplay(&La); printf("*** 插入数据 ***\n");
printf("请输入要插入的位置:");
scanf("%d", &i);
printf("请输入要插入的元素:");
scanf("%d", &e);
ListInsert(&La, i, e);
printf("*** 此时线性表La中的元素 ***\n");
ListDisplay(&La); printf("*** 删除数据 ***\n");
printf("请输入要删除元素的位置:");
scanf("%d", &i);
ListDelete(&La, i);
printf("*** 此时线性表La中的元素 ***\n");
ListDisplay(&La); printf("*** 查找数据 ***");
printf("请输入要查找的元素:");
scanf("%d", &e);
ListSearch(&La, e); printf("*** 顺序表逆置 ***\n");
ListReverse(&La);
printf("*** 此时线性表La中的元素 ***\n");
ListDisplay(&La); printf("*** 初始化线性表Lb ***\n");
ListInit(&Lb);
printf("请输入线性表Lb的长度:");
scanf("%d", &n);
Lb.size = n;
printf("请输入线性表Lb中的元素(共%d个)\n", n);
for (i = ; i < n; i++)
{
scanf("%d", &Lb.list[i]);
}
printf("*** 此时线性表Lb中的元素 ***\n");
ListDisplay(&Lb); printf("*** 合并线性表La 和 Lb ***\n");
ListInit(&Lc);
ListMerge(&La, &Lb, &Lc);
printf("*** 此时线性表Lc中的元素 ***\n");
ListDisplay(&Lc); scanf("%d", &e); }
顺序表的基本操作(C)的更多相关文章
- 顺序表的基本操作【c语言】【创建、插入、删除、输出】
作为数据结构初学者,上课时对一些知识点掌握得不是很透彻,所以利用课余时间通过微博平台总结所学知识,加深对知识的见解,记录学习历程便于后需要时参考. #include<stdio.h> #i ...
- 顺序表及基本操作(C语言)
#include <stdio.h> #include <stdlib.h> //基本操作函数用到的状态码 #define TRUE 1; #define FALSE 0; # ...
- C语言实现顺序表的基本操作(从键盘输入 生成线性表,读txt文件生成线性表和数组生成线性表----三种写法)
经过三天的时间终于把顺序表的操作实现搞定了.(主要是在测试部分停留了太长时间) 1. 线性表顺序存储的概念:指的是在内存中用一段地址连续的存储单元依次存储线性表中的元素. 2. 采用的实现方式:一段地 ...
- 【C++/数据结构】顺序表的基本操作
<span style="font-size:18px;"><strong>#pragma once #include <iostream> u ...
- 数据结构——Java实现顺序表
一.分析 什么是顺序表?顺序表是指用一组地址连续的存储单元依次存储各个元素,使得在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中的线性表.一个标准的顺序表需要实现以下基本操作: 1.初始化顺序表 ...
- 使用JAVA数组实现顺序表
1,引入了JAVA泛型类,因此定义了一个Object[] 类型的数组,从而可以保存各种不同类型的对象. 2,默认构造方法创建了一个默认大小为16的Object数组:带参数的构造方法创建一个指定长度的O ...
- 【C#】【数据结构】001-线性表:顺序表
C#数据结构:顺序表结构 1.自定义顺序表结构 using System.Collections; using System.Collections.Generic; /// <summary& ...
- (java实现)顺序表-ArrayList
什么是顺序表 顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构. 在使用顺序表存储数据前,会先申请一段连续的内存空间(即数组),然后把数组依次存入 ...
- C语言实现顺序表(顺序存储结构)
顺序表(顺序存储结构)及初始化过程详解 顺序表,全名顺序存储结构,是线性表的一种.通过<线性表>一节的学习我们知道,线性表用于存储逻辑关系为"一对一"的数据,顺序表自然 ...
随机推荐
- CentOS查看系统信息命令和方法
收集整理的一些linux查看系统信息的命令和方法: 一.linux查看服务器系统信息的方法: 1.查看主机名/内核版本/CPU构架: # uname -n -r -p -o localhost.loc ...
- 关于Netty4.x中文教程系列更新进度的说明和道歉
最近一些事情.貌似发现很久没更新教程了.这里和大家说一声对不起.教程5的前半部分差不多年前就写好了.但是由于年前我在的项目组项目进度比较紧张.一直在加班.教程的后半部分就一直没有写.年后由于一些公司人 ...
- VNC+SSH相关应用
1.安装vnc-server vncviewer2.执行vncserver 输入密码3.执行vncserver -kill :1 杀死1号屏幕4.修改/root/.vnc/xstartup u ...
- asp.net mvc4使用百度ueditor编辑器
原文 http://www.cnblogs.com/flykai/p/3285307.html 已测试 相当不错 前言 配置.net mvc4项目使用ueditor编辑器,在配置过程中遇见了好 ...
- 安装 jdk、tomcat
jdk 下载地址:http://www.oracle.com/technetwork/java/javasebusiness/downloads/java-archive-downloads-java ...
- MongoDB 学习笔记(四)C# 操作MongoDB
C#驱动对mongodb的操作,目前驱动有两种:官方驱动和samus驱动,不过我个人还是喜欢后者, 因为提供了丰富的linq操作,相当方便. 官方驱动:https://github.com/mongo ...
- Linux 查看端口占用并杀掉
1. 查看端口号占用情况: netstat -apn|grep 80 tcp 0 0 10.65.42.27:80 172.22.142.20:627 ...
- python-unexpected content storage modification出错
提示以上错误,然后在pycharm中的文件内容和实际内容不一致 去我的文档-.PyCharm-system_cache,全部删除
- Codeforces 500A - New Year Transportation【DFS】
题意:给出n个数,终点t 从第i点能够跳到i+a[i],问能否到达终点 #include<iostream> #include<cstdio> #include<cstr ...
- 对比C++中的指针和引用
指针和引用在形式上比较好区分,由于有很多相似的功能,因此在使用上容易混淆.因此有必要对指针和引用进行对比,以便于在使用时使程序正确高效. 1.引用不可以为空,而指针可以为空. 我们知道引用是对象的别名 ...