静态链表

2023-11-19

#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 1000     //链表最大长度为1000
typedef struct {
	int data;
        int cur;             //cursor,为0时表示无指向
}Component,StaticLinkList[MAXSIZE];
int InitList(StaticLinkList space);
int Malloc_SLL(StaticLinkList space);
int ListInsert(StaticLinkList L,int i,int e);
int ListDelete(StaticLinkList L,int i);
void Free_SSL(StaticLinkList space,int k);
int ListLength(StaticLinkList L);
int main()
{    
	int num;    
	StaticLinkList L;    
	InitList(L);    
	printf("请输入数字:");    
	for ( int i = 1; i < 7; i++)    
	{        
	    	scanf("%d",&num);        
		ListInsert(L,i,num);    
	}    
	printf("在第3个位置中插入数字66\n");  //插入之前必须删除该位置的元素    
	ListDelete(L,3);    
	ListInsert(L,3,66);    
	printf("静态链表中的数为:");    
	for ( int j = 1; j < 7; j++)    
	{        
		printf("%d\n",L[j].data);    
	}    
	system("pause");    
	return 0;
}

int InitList(StaticLinkList space)   //静态链表初始化
{                                    //space[0].cur为头指针,“0”表示空指针    
	int i;    
	for ( i = 0; i < MAXSIZE-1; i++)    
	{        
		space[i].cur=i+1;    
	}    
	space[MAXSIZE-1].cur=0;          //目前静态链表为空,最后一个元素的cur为0        				 
	return 0;
}

int Malloc_SLL(StaticLinkList space) //静态链表的空间分配
{    
	int i=space[0].cur;              //当前第一个cur值,也是已经储存数据的长度    
	if (space[0].cur)                //当第一个游标为非零值时,将下一个分量调用    
	{        
		space[0].cur=space[i].cur;    
	}
	return i;
}

int ListInsert(StaticLinkList L,int i,int e)
{    
	int j,k,l;    
	k=MAXSIZE-1;                     //k是最后一个元素的下标    
	if (i<1||i>ListLength(L)+1)    
	{        
		return 1;    
	}    
	j=Malloc_SLL(L);                 //获得空闲分量的下标    
	if (j)    
	{        
		L[j].data=e;                 //将数据赋值给此分量的data        
		for (l = 1; l <= i-1; l++)   //找到第i个元素之前的位置        
		{            
			k=L[k].cur;        
		}        
		L[j].cur=L[k].cur;           //把第i个元素之前的cur赋值给新元素的cur        			 
		L[k].cur=j;                  //把新元素的下标赋值给第i个元素之前的元素cur        	
		return 0;    
	}    
	return 1;
}

int ListDelete(StaticLinkList L,int i)  //删除在L的第i个元素e
{    
	int j,k;    
	if (i<1||i>ListLength(L))    
	{        
		return 1;    
	}    
	k=MAXSIZE-1;    
	for ( j = 1; j <= i-1; j++)    
	{        
		k=L[k].cur;    
	}    
	j=L[k].cur;    
	L[k].cur=L[j].cur;    
	Free_SSL(L,j);    
	return 0;
}

void Free_SSL(StaticLinkList space,int k)  //讲下标为k的结点回收到备用链表
{    
	space[k].cur=space[0].cur;      //把第一个元素cur值赋值给要删除的元素cur    	
	space[0].cur=k;                 //把要删除的分量下标赋值给第一个元素的cur
}

int ListLength(StaticLinkList L)    //返回L中数据元素的个数
{    
	int j=0;    
	int i=L[MAXSIZE-1].cur;    
	while (i)   
	{        
 		i=L[i].cur;        
		j++;    
 	}    
	return j;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

静态链表 的相关文章

  • 2021-07-29

    git和GitHub的搭配使用1 作为一个小白 一直觉得GitHub是个程序员大佬玩转的东西 最近在发现了宝贝教程https www bilibili com video BV1db4y1d79C spm id from 333 788 b

随机推荐

  • Excalidraw本地化部署

    1 Excalidraw介绍 Excalidraw是一个开源 小巧易用的手写风格的框图画板软件 excalidraw官网地址 https excalidraw com 2 Excalidraw本地化安装 git方式 2 1安装部署 在ter
  • shell case 分支选择

    转自 http hlee iteye com blog 577628 case和select结构在技术上说并不是循环 因为它们并不对可执行代码块进行迭代 但是和循环相似的是 它们也依靠在代码块顶部或底部的条件判断来决定程序的分支 在代码块中
  • STM32单片机的IIC硬件编程---查询等待方式

    IIC器件是一种介于高速和低速之间的嵌入式外围设备 其实总体来说 它的速度算是比较慢的 通常情况下 速度慢的器件意味着更多的等待 这对于精益求精的嵌入式工程师来说 简直就是一个恶梦 低速器件的存取数据实在是太浪费资源 如何面对这种低速设备
  • 【日常】DBeaver中sql连接,局域网状态下

    投身外包大军 项目组使用内网 不能自己下软件 不能自己带U盘 上头的很 使用的DBeaver进行数据库的使用 碰到了sql连接的问题 记录一下 不得不说这个软件的图标有点可爱 一个小河狸 内网连接 不能联网 所以一般配套会给一个sql co
  • 父进程等待子进程终止 wait, WIFEXITED, WEXITSTATUS

    wait 的函数原型是 include
  • jqGrid 编辑完数据后能返回到当前位置的方法

    jqGrid 是一个js的jquery组件 虽然不轻便 但功能还是蛮强大的 也比较方便使用 在数据加载后 经常需要对其中的记录进行编辑 修改完后再返回时需要看到修改后的数据 一般采取重新加载的方法reloadGrid 但问题是列表中的数据因
  • STM8自学入门方向

    我还是我 今年计划自学学习STM8和汇编基础 STM8花了半个月 学的一点皮毛 对芯片有一定的了解了 学完后 发现可以拿到的资源远远没有32多 学习了内部大部分常用资源的应用 IO操作 定时器 IO中断 RS232 IIC 后面会发布我的总
  • 大数据时代下的个人知识管理

    前言 说到个人知识管理 在之前通过网络查询了一些资料 定义看起来让人蠢蠢欲动 作用是能快速找到自己收藏的文档 每个人或多或少都必须的有一些文件管理的习惯 管理就是一种习惯 利用专业的软件可以更容易的养成个人知识管理的习惯 当不小心清空了自己
  • c++双向列表释放_Python 列表List常见操作和错误总结

    一 列表的输入 即从控制台读取输入 然后创建列表 1 一维列表创建常见的方法有 当然 可以进一步简化成下面这样 其中第二句 在列表里用到了列表解析式 这是非常Pythonic的写法 酷炫 2 二维列表的输入和创建 二维列表复杂一些 可以以矩
  • Quartz-Spring[一]之MethodInvokingJobDetailFactoryBean配置任务

    Spring中使用Quartz的3种方法 MethodInvokingJobDetailFactoryBean implements Job extends QuartzJobBean 动态启动 暂定 添加 删除定时功能 可传参数 Quar
  • React之state、hooks性能分析

    目录 一 state 1 为什么使用setState 2 setState异步更新 3 如何获取异步的结果 4 setState一定是异步吗 5 源码分析 6 数据的合并 7 多个state的合并 二 为什么需要Hook 三 Class组件
  • stm32之iap实现应用(基于串口,上位机,详细源码)

    开发环境 Window 7 开发工具 Keil uVision4 硬件 stm32f103c8t6 篇幅略长 前面文字很多 主要是希望能让小白们理解 后面就是实现步骤 包括实现的代码 在研发调试的时候我们一般用烧录器下载代码 对于stm32
  • 4.0创建型模式 描述

    创建型模式的主要关注点是 怎样创建对象 它的主要特点是 将对象的创建与使用分离 这样可以降低系统的耦合度 使用者不需要关注对象的创建细节 对象的创建由相关的工厂来完成 就像我们去商场购买商品时 不需要知道商品是怎么生产出来一样 因为它们由专
  • mysql按照某个字段值内容排序

    举个栗子 假如一个商品下 有多个货品 各个货品的状态值都不一样 那么当只想展示商品中的某一个货品时 希望用户端看到的优先级是在售的货品中的一个 根据mysql提供的方法 field column value1 value2 value3 可
  • RTThread学习有关的Keil的两个符号 $Sub$ $main 与 $Super$ $main

    Keil的两个符号 Sub 与 Super 是其做的打 补丁 功能 具体调用方法就是程序中包含有main函数 和 Sub main Super main 两个符号 源码先放出来 re define main function int Sub
  • 三校生计算机教育,三校生有什么专业

    三校生的专业有计算机信息类 旅游类 艺术类 电工技术类 农林类 机械类 建筑工程类 经济管理类 外语类 烹饪 生物化学类 国土资源类 体育类 教育类 交通运输类 自动化类 包装印刷类 医学类 护理学 药学类 铁道运输类 师范类 水利水电类
  • CTreeView

    ClassWizard为CTreeCtrl 树控件 添加的NM DBLCLK 双击 消息的响应函数中带有一个NMHDR 型指针形参 1 OnDblClkTree NMHDR pNMHDR LRESULT pResult 这个陌生的指针类型常
  • IDEA中使用Java连接MySQL数据库的配置和使用方法

    文章目录 IDE和必要配置 数据库连接代码 IDE和必要配置 IDE IntelliJ IDEA 2023 1 必要配置 1 安装好JDK 并且配置环境变量 2 导入MYSQL数据库所需的驱动 如果没有导入 可以参考这篇文章IDEA中的My
  • android Scroller

    参考 http www linuxidc com Linux 2016 01 127276 htm 以前只知道怎么使用scroller 照猫画虎 复制粘贴 今天遇到使用scroller 还是要去搜索 这样不行 要搞懂原理 上面的博客写的很漂
  • 静态链表

    include