C语言实现数据结构顺序查找和折半查找代码

news2024/10/3 6:30:50

文章目录

  • 一、顺序查找
  • 二、折半查找


一、顺序查找

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
typedef struct {//查找表的数据结构
	int *data;//动态数组基址
	int TableLen;//表长
}SSTable;

void InitTable(SSTable *L) {//初始化一个动态分配的顺序表:5,3,2,4,7,6,1,9,8,0
	L->data = (int*)malloc(sizeof(int) * 10);
	L->TableLen = 10;
	int arr[10] = { 5,3,2,4,7,6,1,9,8,0 };
	for (int i = 0;i < L->TableLen;i++) {
		L->data[i] = arr[i];
	}
}



//顺序查找
int Search_Seq(SSTable ST,int key)//在ST表中查找key,返回key下标,没找到返回-1
{
	int i = 0;
	for (i = 0;i < ST.TableLen;i++) {
		if (ST.data[i] == key) {
			return i;
		}
	}
	//上面还没return出去说明没找到
	return -1;
}

int main()
{
	SSTable ST;
	InitTable(&ST);
	int key = 0;
	printf("请输入要查的元素,将返回给你元素下标:");
	scanf("%d", &key);
	int x = Search_Seq(ST,key);
	if (x != -1) {
		printf("要查元素的下标为:%d", x);
	}
	else {
		printf("表中无该元素");
	}
	return 0;
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、折半查找

#include<stdio.h>
#include<stdlib.h>
typedef struct {//查找表的数据结构
	int *data;//动态数组基址
	int TableLen;//表长
}SSTable;

void InitTable(SSTable *L) {//初始化一个动态分配的顺序表:5,3,2,4,7,6,1,9,8,0
	L->data = (int*)malloc(sizeof(int) * 10);
	L->TableLen = 10;
	int arr[10] = { 1,4,7,8,56,89,90,95,100,121 };
	for (int i = 0;i < L->TableLen;i++) {
		L->data[i] = arr[i];
	}
}

//折半查找
//ps:折半查找的数组必须是有序的
//假设我们这里的测试数组是升序:1,4,7,8,56,89,90,95,100,121
int Binary_Search(SSTable ST,int key) {
	int low = 0;
	int high = ST.TableLen - 1;
	int mid = 0;
	while (low <= high) {
		mid = (low + high) / 2;
		if (ST.data[mid] == key) {
			return mid;
		}
		else if (ST.data[mid] > key) {
			high = mid - 1;
		}
		else {
			low = mid + 1;
		}
	}
	//到这里还没return出去,说明没找到
	return -1;
}


int main()
{
	SSTable ST;
	InitTable(&ST);
	int key = 0;
	printf("请输入要查的元素,将返回给你元素下标:");
	scanf("%d", &key);
	int x = Binary_Search(ST, key);
	if (x != -1) {
		printf("要查元素的下标为:%d", x);
	}
	else {
		printf("表中无该元素");
	}
	return 0;
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


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

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

相关文章

10Wqps网关接入层,LVS+Keepalived(DR模式)如何搭建?

说在前面 在40岁老架构师 尼恩的读者交流群(50)中&#xff0c;很多小伙伴拿高薪&#xff0c;完成架构的升级&#xff0c;进入架构师赛道&#xff0c;打开薪酬天花板。 最近有小伙伴拿到了一线互联网企业如京东、网易、微博、阿里、汽车之家、极兔、有赞、希音、百度、滴滴的架…

Redis的Java客户端-Jedis

目录 一、Jedis基本用法二、Jedis连接池 一、Jedis基本用法 二、Jedis连接池

C语言中的自定义类型详解(结构体 + 枚举 + 联合(共用体))

文章目录 1. 结构体1.1 结构体的声明1.2 结构体成员的访问1.3 匿名结构体1.4 结构体的自引用1.5 结构体内存对齐&#xff08;计算结构体的大小&#xff09;1.6 结构体传参1.6.1 传值传递1.6.2 传址传递&#xff08;使用指针&#xff09; 2. 位段2.1 什么是位段&#xff1f;2.2 …

Pytorch从零开始实战05

Pytorch从零开始实战——运动鞋识别 本系列来源于365天深度学习训练营 原作者K同学 文章目录 Pytorch从零开始实战——运动鞋识别环境准备数据集模型选择数据可视化模型预测总结 环境准备 本文基于Jupyter notebook&#xff0c;使用Python3.8&#xff0c;Pytorch2.0.1cu118…

五、OSPF动态路由实验

拓扑图&#xff1a; 基本ip的配置已经配置好了&#xff0c;接下来对两台路由器配置ospf协议&#xff0c;两台PC进行跨网段通讯 R1与R2构成单区域OSPF区域0&#xff0c;首先对R1进行配置 首先进入ospf 默认进程1&#xff0c;router id省略空缺&#xff0c;之后进入area 0区域&…

NodeMCU ESP8266 GPIO使用详解(图文并茂)

NodeMCU ESP8266 GPIO使用详解 文章目录 NodeMCU ESP8266 GPIO使用详解前言什么是GPIO&#xff1f;GPIO 的使用GPIO模式作为输出输出高电平输出低电平 作为输入上拉输入下拉输入读取输入值 总结 前言 前面的文章中我们已经学习了如何点亮一个LED灯&#xff0c;在嵌入式的世界里…

Web自动化测试入门 : 前端页面的组成分析详解

目前常见的前端页面是由HTMLcssJavaScript组成。 一、HTML&#xff1a; 作用&#xff1a;定义页面呈现的内容 HTML 是用来描述网页的一种语言。 HTML 指的是超文本标记语言 (Hyper Text Markup Language)HTML 不是一种编程语言&#xff0c;而是一种标记语言 (markup langua…

【问题思考】为什么SCAN CSCAN会导致磁臂黏着而FCFS不会导致磁臂黏着?

问题 这道18年的真题引起了我的疑惑&#xff0c;SCAN和CSCAN我认为应该也不会导致磁臂黏着&#xff0c;因为他们对于一个访问序列&#xff0c;比如19&#xff0c;24&#xff0c;52&#xff0c;现在正往外走&#xff0c;但是来了一个12的&#xff0c;不是早晚会往回走&#xff…

【数据结构】:队列的实现

队列 队列的概念及结构 队列&#xff1a;只允许在一端进行插入数据操作&#xff0c;在另一端进行删除数据操作的特殊线性表&#xff0c;队列具有先进先出 FIFO(First In First Out) 入队列&#xff1a;进行插入操作的一端称为队尾 出队列&#xff1a;进行删除操作的一端称为队…

AN基础工具——变形工具

【AN基础工具——变形工具】 基本使用方法&#xff1a;任意变形工具基础动画 本篇内容&#xff1a;学会使用变形工具 重点内容&#xff1a;变形工具 工 具&#xff1a;Adobe Animate 2022 基本使用方法&#xff1a; 任意变形工具 《任意变形工具&#xff08;快捷键Q&#xff0…

QT实现的截屏工具与录像功能

前言 目前实现了高仿微信的截屏工具&#xff0c;altx截屏&#xff0c;用户选取区域进行截屏确认&#xff0c;截屏完成后复制到了粘贴板&#xff0c;用全局按键监听按键&#xff0c;程序在最小化时也可以对按键进行监听&#xff0c;有截屏预览与保存按键。 大致流程&#xff1a…

统计学中箱型图的理解

一、箱形图的介绍 箱形图又称为盒须图、盒式图、盒状图或箱线图&#xff0c;是一种用作显示一组数据分散情况的统计图&#xff0c;因型状如箱子而得名。它是利用数据中的五个统计量&#xff1a;最小值、上四分位数、中位数、下四分位数与最大值来描述数据的一种统计图。 箱形图…

【MySQL入门到精通-黑马程序员】MySQL基础篇-函数

文章目录 前言一、字符串函数二、数值函数三、日期函数四、流程控制函数总结 前言 本专栏文章为观看黑马程序员《MySQL入门到精通》所做笔记&#xff0c;课程地址在这。如有侵权&#xff0c;立即删除。 函数 是指一段可以直接被另一段程序调用的程序或代码。 一、字符串函数 格…

C# AnimeGANv2 人像动漫化

效果 项目 下载 可执行程序exe下载 源码下载 其他 C# 人像卡通化 Onnx photo2cartoon-CSDN博客 C# AnimeGAN 漫画风格迁移 动漫风格迁移 图像卡通化 图像动漫化_天天代码码天天的博客-CSDN博客

复数的三角形式与指数形式

See https://blog.csdn.net/u011089570/article/details/102685877

C++ wpf自制软件打包安装更新源码实例

程序示例精选 C wpf自制软件打包安装更新源码实例 如需安装运行环境或远程调试&#xff0c;见文章底部个人QQ名片&#xff0c;由专业技术人员远程协助&#xff01; 前言 这篇博客针对《C wpf自制软件打包安装更新源码实例》编写代码&#xff0c;代码整洁&#xff0c;规则&…

JAVA设计模式-工厂模式(Factory Pattern)

一.概念 我们在创建对象时不会对客户端直接暴露创建逻辑&#xff0c;而是 通过使用一个共同的接口根据不同的条件来指向具体想要创建的对象。 二.工厂模式优点 1.解耦 &#xff1a;把对象的创建和使用的过程分开 2.降低代码重复&#xff1a; 如果创建某个对象的过程都很复杂…

HTML基础入门02

目录 1.格式化标签 2.图片标签: img 3.超链接标签: a 4.综合案例: 展示博客2 5.表格标签 5.1基本使用 5.2合并单元格 6.列表标签 1.格式化标签 加粗&#xff1a;strong标签和b标签 倾斜&#xff1a;em标签和i标签 删除线&#xff1a;del标签和s标签 下划线&#xff1a;i…

结构体,位段!

目录 1.什么是位段&#xff1f; 别急&#xff01;在下面第二点我和大家介绍。 2.位段的内存怎么分配&#xff1f; 还有一种情况就是两种类型夹杂在一起的位段 3.位段的跨平台问题 4.位段能干嘛&#xff1f;&#xff08;应用&#xff09; 5.位段的注意事项 1.什么是位段&…

MySQL 进阶笔记

&#x1f600;&#x1f600;&#x1f600;创作不易&#xff0c;各位看官点赞收藏&#xff0c;在这里隆重感谢尚硅谷宋红康老师。&#xff0c; 文章目录 MySQL 进阶笔记1、Centos 环境安装 MySQL2、MySQL常用设置2.1、字符集设置2.2、SQL 大小写2.3、sql_mode 模式2.4、MySQL 数…