[数据结构]:09-二分查找(顺序表指针实现形式)(C语言实现)
创始人
2024-05-27 16:38:04
0

目录

前言

已完成内容

二分查找实现

01-开发环境

02-文件布局

03-代码

01-主函数

02-头文件

03-PSeqListFunction.cpp

04-SearchFunction.cpp

结语


前言

        此专栏包含408考研数据结构全部内容,除其中使用到C++引用外,全为C语言代码。使用C++引用主要是为了简化指针的使用,避免二重指针的出现。

        二分查找仅适用于有序的顺序表,对于如链表等不可采用二分查找。

已完成内容

[数据结构]:01-顺序表(C语言实现)_Chandni.的博客-CSDN博客

[数据结构]:02-单链表(C语言实现)_Chandni.的博客-CSDN博客

[数据结构]:03-栈(C语言实现)_Chandni.的博客-CSDN博客

[数据结构]:04-循环队列(数组)(C语言实现)_Chandni.的博客-CSDN博客

[数据结构]:05-循环队列(链表)(C语言实现)_Chandni.的博客-CSDN博客

[数据结构]:06-队列(链表带头结点)(C语言实现)_Chandni.的博客-CSDN博客

[数据结构]:07-二叉树(无头结点)(C语言实现)_Chandni.的博客-CSDN博客

[数据结构]:08-顺序查找(顺序表指针实现形式)(C语言实现)_Chandni.的博客-CSDN博客

二分查找实现

01-开发环境

        语言:C/C++14

        编译器:MinGW64

        集成开发环境:CLion2022.1.3

02-文件布局

        请在CLion集成开发环境中创建C++可执行程序,否则无法运行,原因上面已解释。

                        ​​ 

03-代码

01-主函数

        用于测试顺序查找,初始化形式为随机数生成。

// 顺序表以指针形式实现(申请堆空间,可动态控制顺序表大小)--数组实现形式不可以动态控制顺序表大小
#include "./Head/PSeqSearchData.h"
#include "./Source/PSeqListFunction.cpp"
#include "./Source/SearchFunction.cpp"int main() {// 初始化PSeqList PSList;int Length = 10; // 实际所存元素个数PSeqListCreate(PSList, Length);PSeqListPrint(PSList);// 顺序查找ElemType Value;int pos;scanf("%d", &Value);pos = SequenceSearch(PSList, Value);if (pos != -1) {printf("Search Success.\n%d at position %d\n", Value, pos);} else {printf("Search False.\n");}// 二分查找// 排序函数qsort(PSList.data, PSList.ListLength, sizeof(ElemType), compare);PSeqListPrint(PSList);scanf("%d", &Value);pos = HalfSearch(PSList, Value);if (pos != -1) {printf("Search Success.\n%d at position %d\n", Value, pos);} else {printf("Search False.\n");}return 0;
}

02-头文件

        用于存储结构体和常量等。

//
// Created by 24955 on 2023-03-02.
// 顺序表以指针形式实现(申请堆空间,可动态控制顺序表大小)-数组实现形式不可以动态控制顺序表大小
//#ifndef INC_01_SEQUENCESEARCH_PSEQSEARCHDATA_H
#define INC_01_SEQUENCESEARCH_PSEQSEARCHDATA_H
// 头文件
#include 
#include 
#include // 常量
typedef int ElemType;// 结构体
// 顺序表结构体(以指针形式实现)
typedef struct {ElemType *data;int ListLength;
}PSeqList;
#endif //INC_01_SEQUENCESEARCH_PSEQSEARCHDATA_H

03-PSeqListFunction.cpp

        用于存储顺序表(指针形式)创建、打印等函数。

//
// Created by 24955 on 2023-03-02.
// 顺序表以指针形式实现(申请堆空间,可动态控制顺序表大小)--数组实现形式不可以动态控制顺序表大小
// 不使用哨兵
//
// 顺序表初始化
void PSeqListCreate(PSeqList &PSList, int Length) {/** 1. 为顺序表申请堆空间* 2. 根据Length大小设置顺序表长度* 3. 随机数初始化顺序表*/PSList.ListLength = Length;PSList.data = (ElemType *) malloc((PSList.ListLength) * sizeof(ElemType));srand(time(NULL));for (int i = 0; i < PSList.ListLength; i++) {PSList.data[i] = rand() % 100;}
}// 顺序表打印输出
void PSeqListPrint(PSeqList PSList) {/** 1. 0号元素为哨兵因此从1号元素开始打印输出*/for (int i = 0; i < PSList.ListLength; i++) {printf("%3d", PSList.data[i]);}printf("\n");
}// 比较-用于qsort函数
int compare(const void *left, const void *right) {/** 1. 函数名字中存储的为函数的入口地址* 2. qsort函数规定若left指针所指向的值大于right指针指向的值,返回正值;小于返回负值;等于返回0* 3. left, right 是任意两个元素的地址值*/return *(ElemType *) left - *(ElemType *) right; // 从小到大//return *(ElemType*)right - *(ElemType*)left; // 从大到小
}

04-SearchFunction.cpp

        用于存储查找函数。

//
// Created by 24955 on 2023-03-02.
// 顺序表以指针形式实现(申请堆空间,可动态控制顺序表大小)--数组实现形式不可以动态控制顺序表大小
// 不使用哨兵
//
// 顺序表查找
int SequenceSearch(PSeqList PSList, ElemType Value) {/** 1. 若查找到返回元素当前位置* 2. 若存在多个相同元素,则返回第一个匹配元素的所在位置* 3. 未查找到返回-1*/for (int pos = 0; pos < PSList.ListLength; pos++) {if (PSList.data[pos] == Value) {return pos + 1;}}// 未查到返回 -1return -1;
}// 折半查找(二分查找)
int HalfSearch(PSeqList PSList, ElemType Value) {/** 1. 初始化low,high标识位* 2. 比较元素值大小进行二分查找* 3. 查到返回元素位置,未查到返回-1*/int low = 0, high = PSList.ListLength - 1, mid;while (low <= high) {mid = (low + high) / 2;if (PSList.data[mid] == Value) {return mid + 1;} else if (PSList.data[mid] > Value) {high = mid - 1;} else {low = mid + 1;}}// 未查到返回 -1return -1;
}

结语

        此博客主要用于408考研数据结构C语言实现记录,内有不足,可留言,可讨论。

相关内容

热门资讯

私占公共区域堆放的杂物被清理,... 堆在地下室的废旧物品 怎样提示都无人认领 被物业清走后的第二天 却有人报警…… 物业返还后的物品存在...
中央财政优化资金奖补政策 促进... (央视财经《经济信息联播》)记者从财政部了解到,“十五五”时期,中央财政将优化资金奖补政策,促进生态...
女子称在菜地连续两日遭男子猥亵... 近日据媒体,广东中山一女子果某起诉男子夏某,称其2025年4月13日与14日连续两日对自己实施猥亵,...
女排国家队主攻 被球队除名 内... 北京时间1月17日,土耳其排坛传出一则重磅消息,效力于土耳其女排甲级联赛B组球队保险商店女排的外援、...
原创 因... 据《全市场网》报道,韦斯顿·麦肯尼与尤文图斯的续约谈判仍处于搁置状态,主要原因在于财务问题,僵局的根...
哈梅内伊会见数千名民众:特朗普... 当地时间1月17日,伊朗最高领袖哈梅内伊在德黑兰会见了来自社会各界的数千名民众,并就近期局势发表讲话...
2026年消费品以旧换新及汽车... 一、家电以旧换新活动 (一)政策内容 个人消费者购买冰箱、洗衣机、电视、空调、电脑、热水器等6类家电...
高培勇:解决消费问题需统筹政策... 1月17日,中国社会科学院学部委员高培勇在第二十七届北大光华新年论坛上表示,消费本质是收入和财富积累...
彭艳军,擅长离婚纠纷 资深背景与专业素养彭艳军律师拥有12年的执业年限,现执业于北京市常鸿律师事务所,服务地区为北京。他的...