线性表的实现--用通用方法实现线性表的初始化、求表长、插入元素、删除元素等

//线性表的通用程序,c语言实现

#include <stdio.h>

#include <stdlib.h>

#define MaxSize 50

typedef char DataType;

typedef struct node

{

  DataType data[MaxSize]; int last;

}Lnode,*List;

//初始化线性表

void Init_List(List L)

{

  L->last = 0;

}

//线性表的长度

int Length_List(List L)

{

  return L->last;

}

//取表中元素

DataType Get_List(List L, int i, DataType x)

{

  if (i<1 || i>L->last)

    printf("error!!!");

  else

    x = L->data[i-1]; return x;

}

//查找表L中值为x的元素,其结果返回在表L中首次出现的值为x元素的序号或地址

DataType Location_List(List L, DataType x)

{

  int i = 0;

  while (i < L->last && L->data[i] != x)

    i++;

  if (i == L->last)

    return -1;

  else

    return (i + 1);

}

//在线性表的第i个位置插入值为x人元素

void Insert_List(List L, int i, DataType x)

{

  int j;

  if (i<1 || i>L->last + 1)

    printf("插入位置错!!!\n");

  else

  {

    for (j = L->last; j >= i; j--)

      L->data[j] = L->data[j - 1];

    L->data[i - 1] = x;

  }

  L->last++;

}

//删除线性表第i个位置上的元素

void Delete_List(List L, int i)

{

  int j;

  if (i<1 || i>L->last)

    printf("del error");

  else

  {

    for (j = i; j < L->last; j++)

      L->data[j - 1] = L->data[j];

    L->last--;

  }

}

//输出线性表

void Print_List(List L)

{

  int i;

  for (i = 1; i < L->last; i++)

    printf("%c->",L->data[i-1]);

  printf("%c",L->data[L->last-1]);

}

///////////////主函数////////////////

void main()

{

  int i = 1, n;

  Lnode L;

  char ch, x;

  Init_List(&L);

  printf("\n\n\n***************线性表演示程序****************\n");

  printf("请输入您想建立的线性表的元素,以#结束:");

  ch = getchar();

  while (ch != ‘#‘)

  {

  Insert_List(&L,i,ch);

  i++;

  ch = getchar();

  }

  printf("你建立的线性表为:");

  Print_List(&L);

  printf("\n线性表的长度为:%d",L.last);

  //fflush(stdin);

  printf("\n输入你想查找的元素:");

  fflush(stdin);

  scanf("%c",&x);

  printf("你查找的元素为%c序位为%d\n",x,Location_List(&L,x));

  printf("输入你想查找的元素序位:");

  scanf("%d",&n);

  printf("\n你查找的元素为:%c\n",Get_List(&L,n,x));

  printf("输入你想插入的元素以及序位:<用逗号隔开>");

  fflush(stdin);

  scanf("%c,%d",&x,&n);

  Insert_List(&L,n,x);

  printf("\n插入后的线性表为:\n");

  Print_List(&L);

  fflush(stdin);

  printf("\n请输入你想删除的元素序位:");

  scanf("%d",&n);

  Delete_List(&L,n);

  printf("\n删除后的线性表为:\n");

  Print_List(&L);

  printf("\n");

  system("pause");

}

原文地址:https://www.cnblogs.com/duanqibo/p/11098480.html

时间: 2024-08-12 00:54:41

线性表的实现--用通用方法实现线性表的初始化、求表长、插入元素、删除元素等的相关文章

(转)表单和HTML辅助方法 - ASP.NET MVC 3

——选自<ASP.NET MVC3 高级编程(第5章)  孙远帅 译> ——微软ASP.NET MVC系列书籍地址: http://www.wrox.com/WileyCDA/WroxTitle/Professional-ASP-NET-MVC-3.productCd-1118076583.html 第5章 表单和HTML辅助方法  本章内容简介: * 理解表单 * 如何利用HTML辅助方法 * 编辑和输入的辅助方法 * 显示和渲染的辅助方法 顾名思义,HTML辅助方法是用来辅助HTML开发的

DATASNAP多表提交之事务控件之通用方法

ERP系统的单据,总是些主从表结构,有一个主表,N个子表,子表又有子表,形成N层,单据数据提交时,主从表数据都要提交,为了保证数据的完整性,必须提供事务控制,要么都提交成功,有一个提交失败所有的提交都要回滚.看起来是有些难,但我们有OLEVARIANT数组可以利用,解决起来就简单了.上码. 服务端: function TServerMethods1.SaveDatas(tableNames, deltas: OleVariant; tableCount: Integer): Boolean;va

hash表以及处理冲突的方法

哈希表及处理冲突的方法 哈希法又称散列法.杂凑法以及关键字地址计算法等,相应的表称为哈希表.这种方法的基本思想是:首先在元素的关键字k和元素的存储位置p之间建立一个对应关系f,使得p=f(k),f称为哈希函数.创建哈希表时,把关键字为k的元素直接存入地址为f(k)的单元:以后当查找关键字为k的元素时,再利用哈希函数计算出该元素的存储位置p=f(k),从而达到按关键字直接存取元素的目的. 当关键字集合很大时,关键字值不同的元素可能会映象到哈希表的同一地址上,即 k1≠k2 ,但 H(k1)=H(k

hibernate学习笔记4---HQL、通用方法的抽取实现

一.通用方法的抽取实现 由于hibernate中对增删改查的一切操作都是面向对象的,所以将增删改查抽取成通用方法,以满足不同的表的增删改查操作,简化jdbc代码. 具体例子如下: [java] view plaincopyprint? package cn.itcast.hibernate; import java.io.Serializable; import org.hibernate.Session; import org.hibernate.SessionFactory; import 

Java连接MySQL数据库增删改查通用方法

Java连接MySQL数据库增删改查通用方法 运行环境:eclipse+MySQL 以前我们Java连接MySQL数据库都是一个数据库写一个类,类下面写好多方法,要是多个数据库,就要写多个类多个方法,导致代码编写太过于繁琐,所以为了改变这样的繁琐,我将连接数据库的方法进行了一系列的封装,使用户传入一个对象值Object就可以得到想要的. 我在之前写过一篇普通的Java连接MySQL数据库,大家可以看看,以便对比参考之后就知道差距了  数据库--MySQL-->Java篇 接下来我给大家讲讲如何将

c#操作XML文件的通用方法

c#操作XML文件的通用方法 本文导读:我们在编写C#程序时,经常会通过C#访问XML文件,实现对XML文档的读写操作.下面为大家列出了通用的调用方法,大家可以将这些方法放在共用类里,其它的程序共享调用就可以了. 下面通过一个类将我们平时用c#操作XML文件的通用方法详细的介绍一下,关于asp.net C#操作xml文档实现代码,大家可以参考参考. c# 代码 1 sing System; 2 using System.Data; 3 using System.Configuration; 4

共享一个MVC4通过NPOI导出excel的通用方法

1 public static System.IO.MemoryStream ExportExcel<T>(string title, List<T> objList, params string[] excelPropertyNames) 2 { 3 NPOI.SS.UserModel.IWorkbook workbook = new NPOI.HSSF.UserModel.HSSFWorkbook(); 4 NPOI.SS.UserModel.ISheet sheet = wo

js通用方法获取元素,节点父子关系查找

/* *通用方式来获取元素 * 1.通过id来获取元素document.getElementById('属性名') * 2.通过便签名来获取元素document.getElementsByTagName('属性名');得到的是一个数组 * 3.通过class属性来获取元素有兼容性问题document.getElementsByClassName('class属性名');得到是一个数组 * 4.通过name属性来获取元素存在兼容性问题document.getElementsByName('name

UI第九讲.UITableView表视图创建,表视图的重用机制,表视图的相关配置方法

一.UITableView表视图创建 1>.基本属性: UITableView继承自UIScrollView,所以可以滚动          表视图的每一条数据都是显示在UITableViewCell对象中          表视图可以分区显示数据,每个分区称为一个section,每一行称为row,编号都是从0始 2>.重要用法: 最重要的是两个代理方法 <UITableViewDelegate,UITableViewDataSource>(其中必须实现的是 numberOfRow