数据结构(C语言版)01

//顺序存储
int main(){
int ans[5]={1,1,1,1,3};//定义并初始化
printf("%d",ans[4]); 
return 0;	
}
//链式存储
Typdef struct Lnode{ElemType data;struct Lnode *next;
}Londe,*LinKlist;Londe *L;
L=(LinkList)malloc(sizeof(Lnode));
A->next=B;B->next=C;

线性表:n个想同类型的元素组成的有序集合。(个数有限,每个元素占用相同大小空间,具有逻辑上的顺序性)

直接前驱,直接后继。 

顺序表: 线性表的顺序表示(逻辑上相邻,物理上也相邻)

优点:可以随机存取表中任意一个,存储密度高,每个结点只存储数据元素。

缺点:插入和删除操作移动大量元素,数组的大小不好确认,造成很多碎片。

//顺序表的定义
#define Maxsize 50
typedef int Elemtype;
//静态分配 
typedef struct {Elemtype data[Maxsize];int len;
}Sqlist; 
//动态分配
#define InitSize 100;
typedef struct {Elemtype *data;int capacity;int lenth;
}SepList;//插入操作,插入到第i个元素前面 //L.data[i-1]=e 
bool insert(Sqlist&L,int i,Elemtype e){if(i>L.len+1||i<0)	return false;if(L.len>Maxsize)	return false;for(int j=L.len;j>i-1;j--)L.data[j]=L.data[j-1];L.data[i-1]=e;L.len++;return true;
}
//删除操作,删除第i个元素
bool delet(Sqlist&L,int i){if(i>L.len||i<1)	return false;if(L.len>Maxsize)	return false;int x=L.data[i-1];for(int j=i-1;j<L.len;j++)L.data[j]=L.data[j+1];L.len--;return true;
}void printSq(Sqlist L){for(int i=0;i<L.len;i++)printf("%4d",L.data[i]);printf("\n");
}int main(){Sqlist L;bool ans;Elemtype del;for(int i=0;i<3;i++)L.data[i]=i;L.len=3;ans=insert(L,2,60);if(ans) printSq(L);ans=delet(L,1);if(ans) printSq(L);return 0;
}

知识点补充:

C的初始动态分配语句:
L.data=(ElemType*)malloc(sizeof(ElemType)*InitSize)

 链表:逻辑上相邻的两个元素在物理位置上不相邻。

单链表:

优点:插入删除不需要移动元素,只需要修改指针;不需要大量连续的存储空间。

缺点:附加指针域,浪费存储空间;查找时每次都从头开始,依次查找,不能随机存取

//单链表 
typedef struct LNode{ElemType data;struct LNode *next;
}LNode,*LinkList;

头指针:链表中第一个节点的存储位置,用来标识单链表

头结点:在单链表第一个(有值)的节点之前附加的一个结点,为了操作上的方便。(其data一般为空)有了头结点后,对在第一个结点前插入和删除第一个结点就可以统一操作,不用频繁的重置头指针。(但头结点实际上是可有可无的)

//创建新节点
p=(LNode*)malloc(sizeof(LNode))
p->data=x;//按序号查找结点值
LNode *p=L->next;
int j=1;
while(p&&j<i){p=p->next;j++;
} 
return p;
//按值查找
LNode q=L->next;
while(q&&q.data!=e)q=q->next;
return q;

对应练习作业:王道OJ | 课时10作业 (lgwenda.com)

答案:核心代码不难,注意输出的格式!!!!

//oj-10
//初始化顺序表
#include<stdio.h>
#define MaxSize 50
typedef struct{int len;int data[MaxSize];
}Sqlist;
//插入元素 
bool inseret(Sqlist &L,int i,int e){if(i>=L.len||i<1) return false;if(L.len>=MaxSize) return false;for(int j=L.len;j>=i;j--)L.data[j]=L.data[j-1];L.data[i-1]=e;L.len++;return true;
} 
//删除元素 
bool delet (Sqlist &L,int i){if(i>L.len||i<1) return false;int x=L.data[i];for(int j=i-1;j<L.len-1;j++){L.data[j]=L.data[j+1];}L.len--;return true;
}
void print(Sqlist L){for(int i=0;i<L.len;i++)printf("%3d",L.data[i]);printf("\n");//return 0;
}
//main()
int main(){Sqlist L;L.data[0]=1;L.data[1]=2;L.data[2]=3;L.len=3;int e;scanf("%d",&e);if(inseret(L,2,e))	print(L);else printf("false\n");int i;scanf("%d",&i);if(delet(L,i)) print(L);else printf("false\n");return 0;
} 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/708666.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python中re模块的使用

在Python中&#xff0c;处理正则表达式的模块是re模块。通过re模块&#xff0c;可以使用正则表达式来进行字符串的匹配、查找、替换等操作。执行效率特别高&#xff0c;可读性不强。 1.方法 match 从头开始匹配 返回Match 或者None import re r re.match(".\w{10}"…

单片机烧录方式 -- IAP、ISP和ICP

目录 背景 1 什么是ICP 2 什么是ISP 3 什么是IAP 4 总结 背景 对于51单片机&#xff0c;我们使用STC-ISP上位机软件通过串口进行程序的烧写&#xff1b;对于STM32系列单片机&#xff0c;我们既可以通过串口烧写程序&#xff0c;也能通过JLink或是STLink进行程序的烧写&am…

如何保护服务器的安全

互联网的迅速发展&#xff0c;让很多企业都很重视网络技术的使用&#xff0c;但是网络的传播速度比较快&#xff0c;同时容易造成数据、隐私方面的泄露现在每个企业基本有自己的服务器。有几点需要注意&#xff0c;可以参考&#xff1a; 1.基础密码安全 最基本的安全就是密码安…

linux 如何给服务器批量做免密,如何批量挂在磁盘

前提条件 所有机器网络互通&#xff0c;且已做了免密登录 linux服务器批量做免密脚本如下 #!/bin/bash # 定义服务器列表文件 SERVERS_FILE"host" # 定义生成的密钥的存储目录 KEY_DIR"/root/.ssh" # 检查是否输入了文件路径 if [ $# -ne 1 ]; then …

车载电子电器架构 —— 基础技术开发概述

车载电子电器架构 —— 基础技术开发概述 我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师&#xff1a; 屏蔽力是信息过载时代一个人的特殊竞争力&#xff0c;任何消耗…

.Net Core与存储过程(一)

例子1 C# 调用存储过程 CREATE PROCEDURE [dbo].[spFunc] id BIGINT, isTrue BIT, str NVARCHAR (60), strZh NVARCHAR (60) AS BEGINSELECT *FROM tableAWHERE id idAND isTrue isTrueAND str strAND strZh strZh; ENDlong idLong 18; bool isBoolean true; string …

【element-ui】el-select multiple多选,表单校验问题解决方法

在项目开发过程中发现&#xff0c;el-select设置了multiple支持多选属性之后&#xff0c;el-select赋值之后&#xff0c;表单校验不通过 解决思路及解决方法&#xff1a; 1、首先看看v-model 、prop属性、rules校验是否正确&#xff0c;这里注意el-select的rules校验的trigger…

代码随想录三刷day17

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、力扣144. 二叉树的前序遍历二、力扣145. 二叉树的后序遍历三、力扣94. 二叉树的中序遍历四、力扣144. 二叉树的前序遍历无、力扣145. 二叉树的后序遍历六、…

【Go语言】Go语言中的指针

Go语言中的指针 变量的本质是对一块内存空间的命名&#xff0c;我们可以通过引用变量名来使用这块内存空间存储的值&#xff0c;而指针则是用来指向这些变量值所在内存地址的值。 注&#xff1a;变量值所在内存地址的值不等于该内存地址存储的变量值。 Go语言中&#xff0c;…

42.do...while语句

目录 一.什么是do...while语句 二.语法 三.执行流程图 四.举例 五.视频教程 一.什么是do...while语句 do...while语句也是循环语句&#xff0c;和while语句的区别是&#xff0c;while语句是先判断表达式&#xff0c;如果表达式成立才会执行循环体中的内容&#xff0c;否则…

新书速览|Python数据分析快速上手

从零开始&#xff0c;小白轻松入手&#xff0c;一步一步教你学数据分析&#xff0c;让数据分析变得简单易懂 本书内容 《Python数据分析快速上手》通过通俗易懂的语言、丰富多彩的实例&#xff0c;详细介绍了使用Python进行数据分析应该掌握的各方面技术。本书内容包括Python基…

LeetCode215: 数组中的第K个最大元素

题目描述 给定整数数组 nums 和整数 k&#xff0c;请返回数组中第 k 个最大的元素。 请注意&#xff0c;你需要找的是数组排序后的第 k 个最大的元素&#xff0c;而不是第 k 个不同的元素。 你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。 示例 1: 输入: [3,2,1,5,6,4…

区块链游戏解说:什么是 Arcade Champion

作者&#xff1a;lesleyfootprint.network 编译&#xff1a;cicifootprint.network 数据源&#xff1a;Arcade Champion Dashboard 什么是 Arcade Champion Arcade Champion 代表了移动游戏世界的重大革新。它将经典街机游戏的怀旧与创新元素结合在一起&#xff0c;包括 NF…

自学Python笔记总结(2——了解)

网络了解 网络调试助手 NetAssist.exe NetAssist.exe 使用方法请自行寻找 UDP协议 &#xff08;只能一来一回的的发消息&#xff0c;不可连续发送&#xff09; UDP 是User Datagram Protocol的简称&#xff0c; 中文名是用户数据报协议。在通信开始之前&#xff0c;不需要建…

计算机网络体系结构

本篇博客是基于谢希仁编写的《计算机网络》和王道考研视频总结出来的知识点&#xff0c;本篇总结的主要知识点是第一章的计算机网络概述。 计算机网络概述 整体介绍 概念 计算机网络&#xff1a;是一个将分散的。具有独立功能的计算机系统&#xff0c;通过通信设备和线路连…

Android13 framework添加关机接口

framework层修改&#xff1a; t0_sys/frameworks/base/core/api/current.txt method RequiresPermission(android.Manifest.permission.REBOOT) public void reboot(Nullable String);method public void rebootp();t0_sys/frameworks/base/core/java/android/os/IPowerManager…

Zookeeper基础入门-1【集群搭建】

Zookeeper基础入门-1【集群搭建】 一、Zookeeper 入门1.1.概述1.2.Zookeeper工作机制1.3.Zookeeper特点1.4.数据结构1.5.应用场景1.5.1.统一命名服务1.5.2.统一配置管理1.5.3.统一集群管理1.5.4.服务器动态上下线1.5.5.软负载均衡 1.6.Zookeeper官网1.6.1.Zookeeper下载1.6.2.历…

day01-HTML-CSS

一、Web 开发 1. 什么是 Web &#xff1f; Web&#xff1a;全球广域网&#xff0c;也称为万维网(www&#xff0c;World Wide Web)&#xff0c;能够通过浏览器访问的 网站。 2. Web 网站的开发模式 3. Web 标准 Web 标准也称为网页标准&#xff0c;由一系列的标准组成&#xff…

ubuntu开发板问题汇总

1 上网 网线一端连接到开发板 一端连接到无线路由网口 发现局域网可以相互ping通&#xff0c;但是ping www.baidu.com不通&#xff0c;提示消息 ping: bad address www.baidu.com 需要下面命令配置网关 route add default gw 192.168.31.1 然后再ping www,baidu.com即…

yii2框架 mysql两个点的经纬度计算距离排序查询

$query Location::find()->select([id, name])->addSelect([ distance > "ST_DISTANCE(POINT(:latitude, :longitude), POINT(latitude, longitude))", ])->orderBy(distance)->params([ :latitude > $targetLatitude, // 目标纬度 :…