c语言线性表
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#define MAXSIZE 20 //初始长度 typedef int ElemType; //类型为int
typedef struct{
ElemType data[MAXSIZE];//数组。存储元素
int length;
}SqList;
//顺序表的初始化
SqList Init(){
//创建一个空的线性表L,时间复杂度O(1)
SqList L; //定义
L.length=;//初始长度为0
return L; //返回空顺序表
}
//顺序表的建立
SqList Create(SqList L)
{
int i;
srand((unsigned)time(NULL));
for(i=;i<;i++)
{
L.data[i]=rand()%;
L.length++;
}
return L;
}
//用e返回线性表中第i个元素的值
//此时L应该已经存在
ElemType GetElem(SqList L,int i)
{
if(i<||i>L.length)
{
printf("查找位置错误!\n");//位置是否合法
return ;
}
else
return L.data[i-];
}
//顺序表的插入
SqList ListInsert(SqList L, int i, ElemType x)
{ //在顺序表中的第i个位置插入元素x if(L.length == MAXSIZE)
printf("表已经满了\n");//插入时,必须检查表是否已经满了。否则会出现溢出错误
else if(i < || i > L.length)
printf("插入位置错误\n");//判断插入位置的有效性
int j;
for(j = L.length-; j >= i - ; j--)//第i个位置元素逐个后移
L.data[j+] = L.data[j];
L.data[i-] = x; //插入元素x
L.length++; //顺序表长度增1 return L; } //删除元素
SqList ListDelete(SqList L,int i)
{
int k;
if(L.length==) //线性表为空
printf("表为空无法删除");
if(i<||i>L.length)
printf("删除的位置不正确");
if(i<L.length)
{
for(k=i;k<L.length;k++)//将删除的位置后继元素前移
L.data[k-]=L.data[k];
L.length--;
}
return L;
}
int main()
{
SqList l;
l=Init();
l=Create(l);
char choose;//操作选择
int find;//查找操作
int found;//查找到的元素 int position;//标记元素的位置
int value;//插入的元素 int i; printf("初始化完成.........\n"); while(true){ printf("\n1.查看顺序表 \n2.查找元素 \n3.插入元素 \n4.删除元素 \n5.退出 \n请选择你的操作。。。");
scanf("%c",&choose); switch(choose){
case '':
system("cls");
printf("查看线性表:");
for(i=;i<l.length;i++)
{
printf("%d ",l.data[i]);
}
printf("\n");
break;
case '':
system("cls");
printf("输入你要查找第几个元素?\n");
scanf("%d",&find);
found=GetElem(l,find);
printf("第%d个值为%d\n",find,found);
break;
case '':
system("cls");
printf("请输入要插入的元素位置:");
scanf("%d",&position);
printf("输入要插入的元素的值:");
scanf("%d",&value);
l=ListInsert(l,position,value); printf("\n插入后的顺序表为:");
for(i=;i<l.length;i++)
{
printf("%d ",l.data[i]);
}
printf("\n");
break;
case '':
system("cls");
printf("请输入要删除掉的元素位置:\n");
scanf("%d",&position);
l=ListDelete(l,position);
printf("\n删除后的顺序表为:");
for(i=;i<l.length;i++)
{
printf("%d ",l.data[i]);
}
printf("\n");
break;
case '':
exit(); } }
system("pause");
}
c语言线性表的更多相关文章
- C语言 线性表 双向链式结构 实现
一个双向链式结构实现的线性表 duList (GCC编译). /** * @brief 线性表双向链表结构 * @author wid * @date 2013-10-28 * * @note 若代码 ...
- C语言 线性表 链式表结构 实现
一个单链式实现的线性表 mList (GCC编译). /** * @brief 线性表的链式实现 (单链表) * @author wid * @date 2013-10-21 * * @note 若代 ...
- C语言 线性表 顺序表结构 实现
一个能够自动扩容的顺序表 ArrList (GCC编译). #include <stdio.h> #include <stdlib.h> #include <string ...
- C语言——线性表及其应用
程序要求 1.建立含n个数据元素的顺序表并输出该表中各元素的值及顺序表的长度.2.利用前面的实验先建立一个顺序表L={21,23,14,5,56,17,31},然后在第i个位置插入元素68.3.建立一 ...
- C语言--线性表
#include<stdio.h>#include<stdlib.h>#include<string.h>#define LIST_SIZE 100#define ...
- 数据结构算法C语言实现(二)---2.3线性表的链式表示和实现之单链表
一.简述 [暂无] 二.头文件 #ifndef _2_3_part1_H_ #define _2_3_part1_H_ //2_3_part1.h /** author:zhaoyu email:zh ...
- 数据结构算法C语言实现(一)---2.2线性表的顺序表示和实现
注意: 虽然是用C语言实现,但是考虑到使用了一个C++的特性----引用以简化代码,所以所有的代码均以cpp作为后缀,用g++编译(以后不做说明). g++版本: 一.简述 本节主要讲述线性表的顺序实 ...
- 线性表之顺序存储结构(C语言动态数组实现)
线性表的定义:N个数据元素的有限序列 线性表从存储结构上分为:顺序存储结构(数组)和 链式存储结构(链表) 顺序存储结构:是用一段连续的内存空间存储表中的数据 L=(a1,a2,a3....an) 链 ...
- 数据结构-线性表的链式存储相关算法(C语言实现)
链表的简单介绍 为什么需要线性链表 当然是为了克服顺序表的缺点,在顺序表中,做插入和删除操作时,需要大量的移动元素,导致效率下降. 线性链表的分类 按照链接方式: 按照实现角度: 线性链表的创建和简单 ...
随机推荐
- GDAL 生成shp文件
附件:http://pan.baidu.com/s/1i3GPwrV(C#版GDAL接口.dll) 示例程序: http://pan.baidu.com/s/1jpIKQ (程序是在vs2008 x ...
- Servlet开发(一)
一.Servlet简介 Servlet是sun公司提供的用于开发动态web资源的技术.Sun公司在其API中提供了一个Servlet接口,用户若想开发一个动态web资源(即开发一个java程序向浏览器 ...
- MYSQL 查看当前用户与数据库版本
问题一: 查看当前用户 select user(); 问题二: 查看数据库版本 select version();
- AprioriTID algorithm
What is AprioriTID? AprioriTID is an algorithm for discovering frequent itemsets (groups of items ap ...
- LINUX 暂停、继续进程
LINUX 暂停.继续进程 kill -STOP 1234 将该进程暂停. 如果要让它恢复到后台,用kill -CONT 1234 (很多在前台运行的程序这样是不行的) 如果要恢复到前台,请在当时运行 ...
- COCI 2015/2016 Day 8 PROKLETNIK
PROKLETNIK 题目描述:给出\(n\)个数,定义一段连续的数为魔法串是该区间的左右端点值正好是区间的最小值与最大值(最小值可以在左也可以在右,最大值也一样).\(Q\)个询问,每次询问一个区间 ...
- codevs1039 数的划分
题目描述 Description 将整数n分成k份,且每份不能为空,任意两种划分方案不能相同(不考虑顺序). 例如:n=7,k=3,下面三种划分方案被认为是相同的. 1 1 5 1 5 1 5 1 1 ...
- C#操作XML的完整例子——XmlDocument篇(转载,仅做学习之用)
原文地址:http://www.cnblogs.com/serenatao/archive/2012/09/05/2672621.html 这是一个用c#控制台程序下, 用XmlDocument 进 ...
- linux文件属性
在Linux中,文件的属性是一个很重要的概念,用户或者用户组对一个文件所拥有的权限,都可以 从文件的属性得知.我们可以通过ls -al命令,列出某个文件夹下面的所有文件(包括以.开头的隐藏 文件).下 ...
- poj 2516 (费用流)
题意:有N个供应商,M个店主,K种物品.每个供应商对每种物品的的供应量已知,每个店主对每种物品的需求量的已知,从不同的供应商运送不同的货物到不同的店主手上需要不同的花费,又已知从供应商m送第k种货物的 ...