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

php动态网站开发难吗全网万能搜索引擎

php动态网站开发难吗,全网万能搜索引擎,网站工商标识做网站的公司负责,深圳网站制作的公司哪家好目录 前言 一、代码实现 二、时空复杂度 时间复杂度: 空间复杂度: 前言 建议:1.学习算法最重要的是理解算法的每一步,而不是记住算法。 2.建议读者学习算法的时候,自己手动一步一步地运行算法。 tips:希尔排序算…

目录

前言

一、代码实现

二、时空复杂度

时间复杂度:

空间复杂度:


前言

建议:1.学习算法最重要的是理解算法的每一步,而不是记住算法。

           2.建议读者学习算法的时候,自己手动一步一步地运行算法。

tips:希尔排序算法就是通过该算法衍生出来的,通过理解本算法可以为理解希尔排序打下基础。同时,本算法的逻辑简单。

直接排序算法,也称为选择排序(Selection Sort),是一种简单直观的排序算法。其基本思想是每一趟从待排序的数据元素中选择最小(或最大)的一个元素,将它与序列的第一个元素进行交换,然后再从剩余的元素中选择最小(或最大)的元素,与序列的第二个元素进行交换,如此循环,直到整个序列有序。总结就是,将无序元素与其前面的元素比较大小,以此来确定其位置,从而将其加入前面的有序的部分。

一、代码实现

#include <stdio.h>// 交换数组中两个元素的值
void swap(int *xp, int *yp) {int temp = *xp;*xp = *yp;*yp = temp;
}// 直接排序函数
void selectionSort(int arr[], int n) {int i, j, min_idx;// 选择排序的主循环for (i = 0; i < n-1; i++) {// 寻找在未排序部分中的最小元素的索引min_idx = i;for (j = i+1; j < n; j++)if (arr[j] < arr[min_idx])min_idx = j;// 将找到的最小元素与当前位置元素交换swap(&arr[min_idx], &arr[i]);}
}// 打印数组元素
void printArray(int arr[], int size) {for (int i = 0; i < size; i++)printf("%d ", arr[i]);printf("\n");
}int main() {int arr[] = {64, 25, 12, 22, 11};int n = sizeof(arr) / sizeof(arr[0]);printf("原始数组: \n");printArray(arr, n);// 调用直接排序算法selectionSort(arr, n);printf("\n排序后的数组: \n");printArray(arr, n);return 0;
}

在这段代码中,swap 函数用于交换数组中两个元素的值,而 selectionSort 函数实现了直接排序算法。主要的思路是在未排序的部分中找到最小元素的索引,然后与当前位置的元素进行交换,通过不断进行这样的操作,实现整个数组的排序。

二、时空复杂度

时间复杂度:

直接排序算法的时间复杂度主要由两层循环决定。

外层循环:外层循环的次数是 n-1,其中 n是数组的长度。这是因为在进行 n-1次选择后,剩下的最后一个元素已经有序了。

内层循环:内层循环用于在未排序的部分中寻找最小元素的索引。在最坏情况下,每次选择都需要遍历剩余未排序的元素。内层循环的次数是n,n-1,n-2,…,1。其平均时间复杂度为O(n^2)

综合考虑外层和内层循环(只要考虑n的次数大的复杂度),直接排序的时间复杂度为O(n^2)

平均/最好/最差时间复杂度均为O(n^2)

空间复杂度:

直接排序是一种原地排序算法,它只需要常数级别的额外空间来存储少量的辅助变量,如循环中的索引和临时变量。因此,直接排序的空间复杂度为 O(1),即常数级别的额外空间。

http://www.rdtb.cn/news/14473.html

相关文章:

  • 网站后台基本功能杭州做搜索引擎网站的公司
  • 做的好的c2c网站上海百度关键词优化公司
  • 网站开发产品经理招聘2022年列入传销组织最新骗法
  • 注册公司费用深圳揭阳市seo上词外包
  • 买了域名之后怎么做网站百度资源平台
  • 网站的策划方案优化大师官网入口
  • 嘉兴网站制作设计免费b站推广网站破解版
  • 苏州企业网站建设网络服务应用关键词优化
  • 网站排名下降原因中国人民银行网站
  • WordPress怎么自动发文章seo免费资源大全
  • 凡客网站做SEO能被收录吗新能源汽车公司
  • java 企业网站开发竞价广告点击软件
  • 网站建设保教友情链接交换网站
  • 薛城做网站淄博百度推广
  • wordpress动态水印谷歌seo排名技巧
  • wordpress怎么迁移到空间南通百度网站快速优化
  • 校园网站建设培训简讯重庆seo排名方法
  • go语言 网站开发长沙网站seo优化公司
  • wordpress 视频站模板下载百度网络营销推广
  • 网站竞价seo综合
  • 灰色网站怎么做seo友情链接平台广告
  • 专业做婚庆的网站有哪些深圳有实力的seo公司
  • 国外seo查询天津外贸seo推广
  • 广州网站建设公司奇亿网站建设做任务赚佣金的平台
  • 如何自己做个简单网站互联网去哪里学
  • 苹果手机怎么做ppt下载网站网站服务器查询工具
  • 做网站与全网营销搜索推广排名优化seo网络推广招聘
  • 品牌网站建设策北京谷歌seo
  • 做微商货源网站赚钱吗百度人工客服24小时电话
  • 企业网站开发哪家专业百度seo排名帝搜软件