当前位置: 首页 > news >正文

数据结构(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;
} 

相关文章:

数据结构(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->nextB;B->nextC;…...

Node.js-文件读取输入

Node.js-文件读取输入 fs模块&#xff08;操作文件的模块&#xff09; 读取 fs.readFile(path[, options], callback)&#xff1b;[]里面 是可选参数&#xff0c;表示以什么样的编码 格式读取path是路径callback表示读取完成后的回调函数 例子 fs.readFile (‘./files/11.txt…...

时隔一年的测评:gpt3.5发展到什么程度了?

名人说&#xff1a;一花独放不是春&#xff0c;百花齐放花满园。——《增广贤文》 作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 目录 一、简要介绍1、chatgpt是什么&#xff1f;2、主要特点3、工作原理4、应用限制5、使…...

[RCTF2015]EasySQL1 题目分析与详解

一、题目介绍&#xff1a; 1、题目来源&#xff1a; BUUCTF网址 2、题目介绍&#xff1a; 拿到flag。 二、解题思路&#xff1a; 我们发现题目首页有登录和注册账号两个选项&#xff0c;我们首先尝试注册账号&#xff0c;尝试注册username为admin的账号&#xff0c;输入密码…...

开源的 Python 数据分析库Pandas 简介

阅读本文之前请参阅-----如何系统的自学python Pandas 是一个开源的 Python 数据分析库&#xff0c;它提供了高性能、易用的数据结构和数据分析工具。Pandas 特别适合处理表格数据&#xff0c;例如时间序列数据、异构数据等。以下是对 Pandas 的简明扼要的介绍&#xff0c;包括…...

LeetCode 2125.银行中的激光束数量

银行内部的防盗安全装置已经激活。给你一个下标从 0 开始的二进制字符串数组 bank &#xff0c;表示银行的平面图&#xff0c;这是一个大小为 m x n 的二维矩阵。 bank[i] 表示第 i 行的设备分布&#xff0c;由若干 ‘0’ 和若干 ‘1’ 组成。‘0’ 表示单元格是空的&#xff0…...

【探索AI】Sora - 探索AI视频模型的无限可能

Sora - 探索AI视频模型的无限可能 随着人工智能技术的飞速发展&#xff0c;AI视频模型已成为科技领域的新热点。而在这个浪潮中&#xff0c;OpenAI推出的首个AI视频模型Sora&#xff0c;以其卓越的性能和前瞻性的技术&#xff0c;引领着AI视频领域的创新发展。让我们将一起探讨…...

NGINX的重写与反向代理机制解析

目录 引言 一、重写功能 &#xff08;一&#xff09;if指令 1.判断访问使用的协议 2.判断文件 &#xff08;二&#xff09;return指令 1.设置返回状态码 2.返回指定内容 3.指定URL &#xff08;三&#xff09;set指令 1.手动输入变量值 2.调用其它变量值为自定义变…...

JVM的深入理解

1、JVM&#xff08;Java虚拟机&#xff09;&#xff1a;我们java编译时候&#xff0c;下通过把avac把.java文件转换成.class文件&#xff08;字节码文件&#xff09;&#xff0c;之后我们通过jvm把字节码文件转换成对应的cpu能识别的机器指令&#xff08;翻译官角色&#xff09…...

JavaWeb——007MYSQL(DQL多表设计)

# 数据库开发-MySQL 一级目录二级目录三级目录 1. 数据库操作-DQL1.1 介绍1.2 语法1.3 基本查询1.4 条件查询1.5 聚合函数1.6 分组查询1.7 排序查询1.8 分页查询1.9 案例1.9.1 案例一1.9.2 案例二 2. 多表设计2.1 一对多2.1.1 表设计2.1.2 外键约束 2.2 一对一2.3 多对多2.4 案…...

深度学习500问——Chapter01:数学基础

文章目录 前言 1.1 向量和矩阵 1.1.1 标量、向量、矩阵、张量之间的联系 1.1.2 张量与矩阵的区别 1.1.3 矩阵和向量相乘结果 1.1.4 向量和矩阵的范数归纳 1.1.5 如何判断一个矩阵为正定 1.2 导数和偏导数 1.2.1 导数偏导计算 1.2.2 导数和偏导数有什么区别 1.3 特征值和特征向量…...

day03_登录注销(前端接入登录,异常处理, 图片验证码,获取用户信息接口,退出功能)

文章目录 1. 前端接入登录1.1 修改前端代码1.2 跨域请求1.2.1 跨域请求简介1.2.2 COSR概述CORS简介CORS原理 1.2.3 CORS解决跨域 2. 异常处理2.1 提示空消息分析2.2 系统异常分类2.3 异常处理2.2.1 方案一2.2.2 方案二 3. 图片验证码3.1 图片验证码意义3.2 实现思路3.3 后端接口…...

k8s初始化报错 [ERROR CRI]: container runtime is not running: ......

一、环境参数 linux系统为centos7kubernetes版本为v1.28.2containerd版本为1.6.28 二、报错内容 执行初始化命令kubeadm init命令时报错&#xff0c;内容如下 error execution phase preflight: [preflight] Some fatal errors occurred:[ERROR CRI]: container runtime is…...

vscode windows 免密登录 powershell.sh

Linux 生成秘钥 ssh-keygenwindows powershell.sh $HOST_IP"zhang192.168.1.1" $PUBPATH"$HOME\.ssh\id_rsa.pub" $KEY(Get-Content "$PUBPATH" | Out-String); ssh "$HOST_IP" "mkdir -p ~/.ssh && chmod 700 ~/.ssh …...

10 种3D 建模技术

在本文中&#xff0c;我将列出 10 种不同类型的 3D 建模。也许可以了解下一个项目将走向何方&#xff0c;或者你可能会像我一样惊讶&#xff0c;究竟有多少 3D 被用作以多种方式进行可视化的工具。这些是我们将讨论和探索的建模类型&#xff1a; 盒子造型多边形建模Nurbs 和曲…...

常见的socket函数封装和多进程和多线程实现服务器并发

常见的socket函数封装和多进程和多线程实现服务器并发 1.常见的socket函数封装2.多进程和多线程实现服务器的并发2.1多进程服务器2.2多线程服务器2.3运行效果 1.常见的socket函数封装 accept函数或者read函数是阻塞函数&#xff0c;会被信号打断&#xff0c;我们不能让它停止&a…...

Tomcat架构分析

Tomcat的核心组件 Tomcat将请求器和处理器分离&#xff0c;使用多种请求器支持不同的网络协议&#xff0c;而处理器只有一个。从而网络协议和容器解耦。 Tomcat的容器 Host&#xff1a;Tomcat提供多个域名的服务&#xff0c;其将每个域名都视为一个虚拟的主机&#xff0c;在…...

旧项目集成阿里云滑动验证码(web和H5方式)

简述 旧项目集成阿里云滑动验证码(web和H5方式) 适用于servlet和HTML项目,VUE + springboot请看另一篇文档 前情提示 系统: 一说 部分截图、链接等因过期、更换域名、MD语法等可能不显示,可联系反馈(备注好博文地址),谢谢❤带有​​#号、删除线、不操作、不执行​…...

机器人内部传感器阅读梳理及心得-速度传感器-数字式速度传感器

在机器人控制系统中&#xff0c;增量式编码器既可以作为位置传感器测量关节相对位置&#xff0c;又可作为速度传感器测量关节速度。当作为速度传感器时&#xff0c;既可以在模拟量方式下使用&#xff0c;又可以在数字量方式下使用。 模拟式方法 在这种方式下&#xff0c;需要…...

【vue+element ui】大屏自适应中el-select下拉内容在低分辨率下显示不全问题解决

目录 背景 现象 解决方案 背景 最近要把一个1920px*1080px的大屏改成自适应的&#xff1b;最低适配到1028px*720px&#xff1b; 现象 自适应适配改完之后 将电脑屏幕改成1028px*720px分辨率后&#xff0c;下拉显示正常 通过谷歌浏览器设置Toggle device toolbar为1028px*…...

《SAP FICO系统配置从入门到精通共40篇》025、新总账(New GL)配置:平行会计与扩展分类账

025、新总账&#xff08;New GL&#xff09;配置&#xff1a;平行会计与扩展分类账 上周帮客户排查一个怪问题&#xff1a;利润表科目余额突然对不上了。业务部门反馈说&#xff0c;按成本中心维度查的数据和按利润中心维度查的数据差了二十几万。查了一下午&#xff0c;最后发…...

STM32--MPU内存保护单元实战:从原理到安全区域配置

1. 为什么嵌入式系统需要内存保护&#xff1f; 在嵌入式开发中&#xff0c;内存保护常常被初学者忽视&#xff0c;直到某天程序突然崩溃却找不到原因。我曾经在一个工业控制项目上吃过亏——某个任务意外改写了另一个任务的堆栈数据&#xff0c;导致系统随机死机&#xff0c;花…...

避坑指南:Zephyr工作队列(Workqueue)的5个常见误用与性能调优(基于2.2.99版本)

Zephyr工作队列深度避坑&#xff1a;2.2.99版本实战调优手册 在嵌入式开发中&#xff0c;Zephyr RTOS的工作队列(Workqueue)机制是处理异步任务的利器&#xff0c;但许多开发者往往在看似简单的API背后踩中意想不到的"地雷"。我曾亲眼见证一个智能家居项目因工作队列…...

不是每一天都闪闪发光,但也都算数

不是每一天都闪闪发光&#xff0c;但也都算数上大学以前&#xff0c;我对大学生活其实有很多想象。我以为大学会是那种很“热烈”的阶段。每天都过得很充实&#xff0c;社团、比赛、朋友、学习、自我提升&#xff0c;生活像开了倍速一样往前冲。好像只要迈进大学校门&#xff0…...

一次由Nginx的proxy_pass尾随斜杠引发的重定向循环

一次由Nginx的proxy_pass尾随斜杠引发的重定向循环 在Web服务器配置中&#xff0c;Nginx的proxy_pass指令是反向代理的核心组件&#xff0c;但一个看似微不足道的斜杠差异可能导致严重的重定向循环问题。某次线上服务突然出现大量HTTP 302跳转&#xff0c;最终发现是proxy_pas…...

终极Python m3u8下载器:如何快速解密并批量下载加密视频的完整指南

终极Python m3u8下载器&#xff1a;如何快速解密并批量下载加密视频的完整指南 【免费下载链接】m3u8_downloader 项目地址: https://gitcode.com/gh_mirrors/m3/m3u8_downloader 你是否曾经遇到过想要保存在线课程、收藏精彩视频&#xff0c;却因为复杂的加密技术而束…...

mysql数据库表名区分大小写问题_调整lower_case_table_names

MySQL表名大小写敏感由lower_case_table_names变量决定&#xff0c;Linux默认0&#xff08;区分&#xff09;&#xff0c;macOS/Windows默认1&#xff08;不区分&#xff09;&#xff1b;该值启动时读取且不可动态修改&#xff0c;改为1需重命名文件、清理元数据并重启。MySQL …...

[嵌入式系统-257]:如何理解进程是任务资源分配的最小单位,线程是CPU调度的最小单位

要理解“进程是资源分配的最小单位&#xff0c;线程是CPU调度的最小单位”这句话&#xff0c;关键在于将程序的“资源所有权”和“执行权”分离开来看。我们可以通过一个生动的比喻来理解&#xff0c;然后深入其技术原理。&#x1f3e2; 一个生动的比喻&#xff1a;工厂与工人想…...

3个关键功能,让FanControl成为Windows风扇控制的终极解决方案

3个关键功能&#xff0c;让FanControl成为Windows风扇控制的终极解决方案 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Tren…...

数字IC面试核心:从MUX基础到Glitch-Free时钟切换电路深度剖析

1. 二选一MUX的基础原理 多路选择器&#xff08;MUX&#xff09;是数字电路中最基础的组合逻辑单元之一&#xff0c;它的核心功能就像铁路道岔的扳道工——根据控制信号决定哪条输入通道的数据能够到达输出端。我们先从最简单的二选一MUX入手&#xff0c;这不仅是面试必考题&am…...