数据结构:冒泡排序,快速排序,插入排序

冒泡排序,每次只排一个,像鱼吐泡泡一样,从数组最后开始两两交换,一次只找到一个当前最小的,放到第一个,第二个...位置.

T(n)=O(n的平方),有序O(n)

S(n)=O(1)


#include <stdio.h>
#include <stdlib.h>
#include <time.h>
typedef int ElemType;
typedef struct {ElemType * elem;//存,申请的空间的首地址int tab_length;//存储动态数组里元素的个数
}SSTable;
void ST_Init(SSTable &t,int len) {t.tab_length=len;//元素个数,数组长度t.elem = (ElemType *) malloc(sizeof(ElemType)*t.tab_length);int i;srand(time(NULL));//随机数for (i = 0; i < t.tab_length; i++){t.elem[i] = rand() % 100;//0~99}
}
void Print(SSTable s)
{int i;for ( i = 0; i <s.tab_length ; ++i) {printf("%3d",s.elem[i]);}printf("\n");
}
void swap(ElemType &a,ElemType &b)
{int temp=a;a=b;b=temp;
}
void Bobble(SSTable &t)
{int i,j;bool flag= false;for ( i = 0; i <t.tab_length ; i++)//排好了几个{for ( j = t.tab_length-1; j >i; j--){if(t.elem[j]<t.elem[j-1]){swap(t.elem[j],t.elem[j-1]);flag= true;//冒泡从后往前先find最小的,如果在j=1时都没有发生交换的都没有找到,说明有序}}if (false==flag){return;//本身有序}}
}
int main() {SSTable t;int len=10;//数组长度ST_Init(t,len);Print(t);Bobble(t);Print(t);free(t.elem);return 0;
}

快速排序:这里我采用的是覆盖,所以要记得最后还原分割点元素

t(n)=O(nlogn),如果本身有序O(n)


#include <stdio.h>
#include <stdlib.h>
#include <time.h>
typedef int ElemType;
typedef struct {ElemType * elem;//存,申请的空间的首地址int tab_length;//存储动态数组里元素的个数
}SSTable;
void ST_Init(SSTable &t,int len) {t.tab_length=len;//元素个数,数组长度t.elem = (ElemType *) malloc(sizeof(ElemType)*t.tab_length);int i;srand(time(NULL));//随机数for (i = 0; i < t.tab_length; i++){t.elem[i] = rand() % 100;//0~99}
}
void Print(SSTable s)
{int i;for ( i = 0; i <s.tab_length ; ++i) {printf("%3d",s.elem[i]);}printf("\n");
}
void swap(ElemType &a,ElemType &b)
{int temp=a;a=b;b=temp;
}
int  partition(ElemType  *a,int low,int high)
{int pivot=a[low];while (low<high) {while ( low<high&&pivot<=a[high]){high--;}a[low]=a[high];while ( low<high&&pivot>=a[low]){low++;}a[high]=a[low];}a[low]=pivot;return low;
}
void Quick_sort(SSTable &s,int low,int high)
{if(low<high){int pivot= partition(s.elem, low, high);//保存分割点Quick_sort(s, low, pivot-1);
//        Print(s);Quick_sort(s, pivot+1, high);}}
int main() {SSTable t;int len=10,low=0,high=len-1;//数组长度,,index最大len-1ST_Init(t,len);Print(t);Quick_sort(t,low,high);Print(t);free(t.elem);return 0;
}

如果没看懂边界条件可以看看这个图,因为最后一定是两个值之间的排序~

插入排序

T(n)=O(n的平方),如果本身有序O(n)

第一个是放好的,有序,从第二个开始依次往里面插入,每插入一个都排一次序

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <time.h>
typedef int ElemType;
typedef struct {ElemType * elem;//存,申请的空间的首地址 8bit,指针int tab_length;//存储动态数组里元素的个数
}SSTable;
void ST_Init(SSTable &t,int len) {t.tab_length=len;//元素个数,数组长度t.elem = (ElemType *) malloc(sizeof(ElemType)*t.tab_length);int i;srand(time(NULL));//随机数for (i = 0; i < t.tab_length; i++){t.elem[i] = rand() % 100;//0~99}}
void Print(SSTable s)
{int i;for ( i = 0; i <s.tab_length ; ++i) {printf("%3d",s.elem[i]);}printf("\n");
}
void swap(ElemType &a,ElemType &b)
{int temp=a;a=b;b=temp;
}
//第一个有序,倒着插入
void insert(SSTable &s)
{int i,j,temp_val;for ( i = 1; i <s.tab_length ; i++) {//外层控制插入的数,表示已经排了几个temp_val=s.elem[i];//保存当前比较的值,因为换位置后,原先的位置上的值替换掉了,比较的内容会变for ( j =i-1 ; j>=0&&s.elem[j]>temp_val; j--) {swap(s.elem[j],s.elem[j+1]);}}}
int main() {SSTable t;int len=10,low=0,high=len-1;//数组长度,,index最大len-1ST_Init(t,len);
//    ElemType a[10]={40,86,71,33,77,59,61,86,71,35};
//    memcpy(t.elem,a,sizeof(a));//copy整型或者浮点型数组用这个//printf("%d\n",sizeof(a)); //a长度为4bit*10Print(t);insert(t);Print(t);free(t.elem);return 0;
}

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

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

相关文章

使用 Spring Boot 和 Maven 引入本地 Jar 包

背景 在 Java 开发中&#xff0c;有时候我们需要引入本地的 Jar 包到项目中&#xff0c;以满足特定的功能需求。本文将以引入 id 生成器为例&#xff0c;介绍如何在 Spring Boot 项目中使用 Maven 管理本地 Jar 包。 准备工作 创建 libs 目录&#xff1a; 在项目根目录下创建…

spring eureka 服务实例实现快速下线快速感知快速刷新配置解析

背景 默认的Spring Eureka服务器&#xff0c;服务提供者和服务调用者配置不够灵敏&#xff0c;总是服务提供者在停掉很久之后&#xff0c;服务调用者很长时间并没有感知到变化。或者是服务已经注册上去了&#xff0c;但是服务调用方很长时间还是调用不到&#xff0c;发现不了这…

pandas,polars,pyspark的df对象常见用法对比

案例背景 最近上班需要处理的都是百万&#xff0c;千万级的数据&#xff0c;pandas的性能已经不够看了&#xff08;虽然它在处理数据上是真的很好用&#xff09;&#xff0c;公司都是用的polar和pyspark&#xff0c;我最近也学习了一些&#xff0c;然后写篇文章对比一下他们的…

达梦使用disql登录数据库显示“未连接”

基础环境 操作系统&#xff1a;Red Hat Enterprise Linux Server release 7.9 (Maipo) 数据库版本&#xff1a;DM Database Server 64 V8 架构&#xff1a;单实例问题&#xff1a;达梦数据库在使用disql登录时&#xff0c;显示“未连接”。 指定了IP和端口号还是连接异常。 […

CentOS如何做端口映射?

在今天的技术发展中&#xff0c;越来越多的应用需要跨越网络进行远程管理和控制。为了实现这一目标&#xff0c;端口映射技术被广泛应用于各个领域。其中&#xff0c;【天联】作为一种性能稳定、安全可靠的端口映射工具&#xff0c;在各种应用场景中得到了广泛的应用和认可。 结…

python+django+flask+vue贫困地区儿童资助网站22pk7

Python 中存在众多的 Web 开发框架&#xff1a;Flask、Django、Tornado、Webpy、Web2py、Bottle、Pyramid、Zope2 等。近几年较为流行的&#xff0c;大概也就是 Flask 和 Django 了 一开始&#xff0c;本文就对系统内谈到的基本知识&#xff0c;从整体上进行了描述&#xff0c…

SEO优化艺术:精细化技巧揭示与搜索引擎推广全面战略解读

SEO&#xff08;搜索引擎优化&#xff0c;Search Engine Optimization&#xff09;是一种网络营销策略&#xff0c;旨在通过改进网站内外的各项元素&#xff0c;提升网站在搜索引擎自然搜索结果中的排名&#xff0c;从而吸引更多目标用户访问网站&#xff0c;增加流量&#xff…

面试算法-154-搜索二维矩阵 II

题目 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性&#xff1a; 每行的元素从左到右升序排列。 每列的元素从上到下升序排列。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,…

鸿蒙ArkUI声明式学习:【UI资源管理】

OpenHarmony 应用的资源分类和资源的访问以及应用开发使用的像素单位以及各单位之间相互转换的方法。 资源分类 移动端应用开发常用到的资源比如图片&#xff0c;音视频&#xff0c;字符串等都有固定的存放目录&#xff0c;OpenHarmony 把这些应用的资源文件统一放在 resourc…

python+django教师业绩考评考核评分系统flask

在设计过程中&#xff0c;将参照一下国内外的一些同类网站&#xff0c;借鉴下他们的一些布局框架&#xff0c;将课题要求的基本功能合理地组织起来&#xff0c;形成友好、高效的交互过程。开发的具体步骤为&#xff1a;   第一步&#xff0c;进行系统的可行性分析&#xff0c…

java实现TCP交互

服务器端 import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.io.PrintWriter; import java.net.ServerSocket; import java.net.Socket; import java.util.PriorityQueue; import java.util.Scanner;public class TCP_Serv…

【Leetcode每日一题】 递归 - 二叉树剪枝(难度⭐⭐)(50)

1. 题目解析 题目链接&#xff1a;814. 二叉树剪枝 这个问题的理解其实相当简单&#xff0c;只需看一下示例&#xff0c;基本就能明白其含义了。 2.算法原理 想象一下&#xff0c;你有一堆层层叠叠的积木&#xff0c;你想从底部开始&#xff0c;把那些标记为0的积木拿走。如…

C++奇迹之旅:我与类和对象相遇

文章目录 &#x1f4dd;面向过程和面向对象初步认识&#x1f320; 类&#x1f309;类的引入&#x1f309;类的定义 &#x1f320;类的访问限定符&#x1f320;访问限定符 &#x1f320;类的两种定义方式&#x1f309;封装 &#x1f6a9;总结 &#x1f4dd;面向过程和面向对象初…

spring cloud gateway openfeign 联合使用产生死锁问题

spring cloud gateway openfeign 联合使用产生死锁问题&#xff0c;应用启动的时候阻塞卡住。 spring.cloud 版本如下 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><vers…

国际数字影像产业园以数字影像技术,重构文创生活

国际数字影像产业园区&#xff0c;作为树莓集团与成都市金牛区人民政府合作的重点项目&#xff0c;于2023年3月正式在金牛区落地生根。这一园区不仅是第五代产业园区的代表&#xff0c;更是数字影像相关产业服务的特色园区&#xff0c;其独特的定位和宏大的愿景“以数字影像技术…

达梦关键字(如:XML,EXCHANGE,DOMAIN,link等)配置忽略

背景&#xff1a;在使用达梦数据库时&#xff0c;查询SQL中涉及XML,EXCHANGE,DOMAIN,link字段&#xff0c;在达梦中是关键字&#xff0c;SQL报关键词不能使用的错误。 解决办法&#xff1a; 配置达梦安装文件E:\MyJava\dmdbms\data\DAMENG\dm.ini 忽略这些关键词&#xff0c;…

景联文科技:为AI大模型提供高质海量训练数据

在全球AI浪潮的推动下&#xff0c;大量训练数据已成为AI算法模型发展和演进中的关键一环。 艾瑞咨询数据显示&#xff0c;包括数据采集、数据处理&#xff08;标注&#xff09;、数据存储、数据挖掘等模块在内的AI基础数据服务市场&#xff0c;将在未来数年内持续增长。 预计到…

MySQL典型示例

目录 1.使用环境 2.设计表 3.创建表 4.准备数据 5.查询 1.使用环境 数据库&#xff1a;MySQL 8.0.30 客户端&#xff1a;Navicat 15.0.12 2.设计表 假设我们已经建好了一个名为test的数据库。我们添加如下几个表&#xff1a;教师、课程、学生、班级、成绩。实体联系图设…

跨平台私人ChatGPT应用ChatGPT-Next-Web

什么是 NextChat (ChatGPT Next Web) &#xff1f; NextChat (ChatGPT Next Web) 是可以一键免费部署的跨平台私人 ChatGPT 应用, 支持 GPT3, GPT4 & Gemini Pro 模型。 准备 因为老苏没有 OpenAI Key&#xff0c;所以使用 FreeGPT35 来提供无限免费的 GPT-3.5-Turbo API …

qt调试日志文件生成

系列文章目录 第一章 qt日志文件生成功能 文章目录 系列文章目录前言一、qt日志文件生成功能二、使用步骤1.代码示例2.运行截图 前言 qt有固定的调试日志接口&#xff0c;可以通过终端去打印&#xff0c;但是仅适用在本地去调试&#xff0c;例如想长期放到测试台去检测&#…