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

网站建设 小程序旅游新闻热点

网站建设 小程序,旅游新闻热点,推广兼职,建设个公司网站需要多少费用文章目录 一、插入排序的基本原理二、插入排序的C语言实现三、代码解析 插入排序 C语言实例 一、插入排序的基本原理 插入排序的基本思想是将数组中的元素逐一取出,然后将其插入到已经排好序的部分中的适当位置,直到整个数组排序完成。具体步骤如下&…

文章目录

  • 一、插入排序的基本原理
  • 二、插入排序的C语言实现
  • 三、代码解析

插入排序 C语言实例

一、插入排序的基本原理

插入排序的基本思想是将数组中的元素逐一取出,然后将其插入到已经排好序的部分中的适当位置,直到整个数组排序完成。具体步骤如下:
初始状态:假设数组的第一个元素已经排好序。
从第二个元素开始:依次取出每个元素,与已经排好序的部分进行比较。
找到插入位置:在已经排好序的部分中,从后向前扫描,找到该元素应该插入的位置。
插入元素:将该元素插入到找到的位置,并将插入位置之后的所有元素向后移动一位。
重复步骤:重复上述步骤,直到所有元素都被插入到适当位置。

二、插入排序的C语言实现

下面是一个用C语言实现的插入排序示例代码:
#include <stdio.h>
// 插入排序函数
void insertionSort(int arr[], int n) {
for (int i = 1; i < n; i++) {
int key = arr[i];
int j = i - 1;
// 将arr[i]插入到已经排好序的arr[0…i-1]中
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
}
// 打印数组函数
void printArray(int arr[], int size) {
for (int i = 0; i < size; i++) {
printf(“%d “, arr[i]);
}
printf(”\n”);
}
int main() {
int arr[] = {12, 11, 13, 5, 6};
int n = sizeof(arr) / sizeof(arr[0]);
printf(“排序前的数组: \n”);
printArray(arr, n);
insertionSort(arr, n);
printf(“排序后的数组: \n”);
printArray(arr, n);
return 0;
}

三、代码解析

函数定义
insertionSort(int arr[], int n):接受一个整数数组和数组的大小作为参数,对数组进行排序。
printArray(int arr[], int size):接受一个整数数组和数组的大小作为参数,打印数组内容。
排序过程
insertionSort函数中,使用两层循环实现排序。外层循环变量i从1开始,表示当前要插入的元素。内层循环变量ji-1开始,向前扫描已经排好序的部分。
如果arr[j]大于key(当前要插入的元素),则将arr[j]向后移动一位。
当找到合适的位置后,将key插入到该位置。
主函数
定义一个待排序的数组arr
调用printArray函数打印排序前的数组。
调用insertionSort函数对数组进行排序。
再次调用printArray函数打印排序后的数组。
四、插入排序的性能分析
时间复杂度
最好情况:O(n)(数组已经有序)
平均和最坏情况:O(n^2)(数组完全逆序)
空间复杂度:O(1)(不需要额外的存储空间)
稳定性:稳定(相同元素的相对顺序保持不变)
插入排序适用于小规模数据排序,或者部分有序的数据集。虽然其时间复杂度在最坏情况下较高,但由于其实现简单且稳定,在实际应用中仍有一定的价值。

http://www.hrbkazy.com/news/20946.html

相关文章:

  • 哪家公司做跳转网站百度用户服务中心官网电话
  • 个人网站建设教学视频百度云盘好的竞价推广外包公司
  • 密云青岛网站建设优化英语
  • 推广网站的公司seo知识分享
  • 国内做色情网站关键词排名点击软件推荐
  • 哪个网站可以做店招网销怎么销售的
  • 璧山集团网站建设百度网站建设
  • 网站开发形式有哪些购买域名后如何建立网站
  • 发布任务做任务赚钱网站西安疫情最新消息1小时内
  • 网站建设评审会semifinal
  • 让网站做的有吸引力女教师遭网课入侵视频大全播放
  • wordpress部份变英文天津seo优化公司哪家好
  • 天河区营销型网站建设正规的关键词优化软件
  • 网站建设对企业的发展厦门seo起梦网络科技
  • 专门做图标的网站每日新闻摘抄10条
  • 个人备案怎么做旅游网站黄页推广
  • 一个网站做两种产品如何制作个人网站
  • 淳安网站建设网络营销方式与工具有哪些
  • wordpress 中国 替代seo的概念
  • 百度总部在哪里郑州seo外包
  • 开发电商网站要多少钱提高工作效率的重要性
  • 专业网站建设哪里找steam交易链接怎么用
  • react.js做的网站百度小说排行榜2020前十名
  • 集团logo设计公司优化疫情防控
  • 工作中网页开发方案系统优化软件哪个最好的
  • 如何让客户做网站全网引流推广 价格
  • 天津模板建站代理今天刚刚发生的新闻最新新闻
  • 安康做网站的公司电话站长工具查询网站
  • 企业宣传网站建设说明书长尾关键词挖掘
  • 广州网站制作哪家全面凡科建站怎么收费