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

济南想做网站今日热点新闻视频

济南想做网站,今日热点新闻视频,洛阳 网站建设 大师字画,营销型网站可以吗# 数组的常见算法 - 查找算法 1. 基本查找/顺序查找 2. 二分查找/折半查找 3. 插值查找 4. 分块查找 5. 哈希查找 6. 树表查找 7. 斐波那契查找 - 排序算法(顾名思义,就是把没有顺序的…

# 数组的常见算法
    - 查找算法
       1. 基本查找/顺序查找
       2. 二分查找/折半查找
       3. 插值查找
       4. 分块查找
       5. 哈希查找
       6. 树表查找
       7. 斐波那契查找
       
    - 排序算法(顾名思义,就是把没有顺序的数据进行从小到大/从大到小排序)
       1. 冒泡排序
       2. 选择排序


## 基本查找/顺序查找
        - 核心思路:就是从数组的0索引开始,依次往后查找
           * 如果找到了,就会返回数据对应的索引
           * 如果没找到,就会返回-1

    #include<stdio.h>int order(int arr[], int len, int needFindNum) {for (int i = 0; i < len; i++){if (arr[i] == needFindNum){return i;}}return -1;}int main() {//1. 定义数组int arr[] = {11,22,33,44,55};int len = sizeof(arr) / sizeof(arr[0]);//2. 定义一个变量表示要查找的数据int num = 55;//3. main函数外定义一个方法进行顺序查找int index = order(arr,len,num);printf("%d\n", index);return 0;}


## 二分查找/折半查找
        - 前提条件:数组里得数据必须是有序的
        - 核心逻辑:每次排除一半的查找范围
        - 默认刚开始min是索引为0的值,max是索引为最大的那个值
        - 核心思路:
           1. min和max表示当前要查找的范围
           2. min是min和max中间的
           3. 如果要查找的值在mid的左边,缩小范围时,min不变,max等于mid - 1
           4. 如果要查找的值在mid的右边,缩小范围时,max不变,min等于mid + 1
             * 如果找到了,就会返回数据对应的索引
             * 如果没找到,就会返回-1

 #include<stdio.h>int binarySearch(int arr[], int len, int needFindNum) {//1确定要查找的范围int min = 0;int max = len - 1;//注意min,max,mid都是指索引while (min <= max) {int mid = min + (max - min)/ 2;//确定中间位置if (arr[mid] < needFindNum){min = mid + 1;}else if (arr[mid] > needFindNum){max = mid - 1;}else {return mid;}}return -1;}int main() {//折半查找/二分查找int arr[] = {11,22,33,44,55};int len = sizeof(arr) / sizeof(arr[0]);int num = 33;int index = binarySearch(arr, len, num);printf("要查找的值所在索引为:%d\n",index);return 0;}

## 插值查找
        - 要求:数据要有序,且数据分布尽可能得均匀分布一些
        - 优势:满足要求,效率比二分查找快,否则反而会更慢。
        - 和二分查找相比,mid尽可能得靠近要查找的数据,但是要求数据尽可能的分布均匀。
        - 代码和二分查找无异,就是把mid = (min + max)/2;  替换成:
       int mid = min + (needFindNum - arr[min]) / (arr[max] - arr[min]) * (max - min);


## 分块查找
        - 分块的原则1:前一块中的最大数据,小于后一块中所有的数据(块内无序,快间有序)
        - 分块的原则2:块数数量一般等于数字的个数开根号,比如:16个数字一般分为4块左右
        - 核心思路:先确定要查找的元素在哪一块,然后块内挨个查找
         * 面对无规律的数据,在进行分块时,确保每块数字无交集(哈希查找)


## 哈希查找
        - 在分块查找的核心思路上,面对的是无规律的数据,在进行分块时,确保每块数字无交集


## 冒泡排序
        - 核心逻辑:相邻的数据两两比较,小的放前面,大的放后面
        - 核心思路:
             1. 相邻的元素两两比较,大的放右边,小的放左边。(默认排成从小到大)
             2. 第一轮比较完毕之后,最大值就已经确定,第二轮以此类推。
             3. 如果数据中有n个数据,总共我们只要执行n-1轮的代码就可以了
  

#include<stdio.h>void bubbleSort(int arr[] , int len) {for (int j = 0; j < len - 1; j++){for (int i = 0; i < len - 1 - j; i++) {if (arr[i] > arr[i+1]){int temp = arr[i];arr[i] = arr[i + 1];arr[i + 1] = temp;}}}}int main() {int arr[] = {55,56,33,11,22};int len = sizeof(arr) / sizeof(arr[0]);bubbleSort(arr, len);//遍历排完序后的数组for (int i = 0; i < len; i++){printf("%d ",arr[i]);}return 0;}


## 选择排序
        - 核心逻辑:从0索引开始,拿着每一个索引上的元素跟后面的元素依次比较,小的放前面,大的放后面,以此类推。
        - 核心思想:
          1. 从0索引开始,跟后面的元素进行一一比较
          2. 小的放前面,大的放后面
          3. 第一轮循环从0索引开始比较,结束后最小的数据已经确定
          4. 第二轮……以此类推
      

 #include<stdio.h>void selectSort(int arr[] ,int len) {for (int j = 0; j < len - 1; j++){for (int i = j + 1; i < len ;i++) {if (arr[j] > arr[i]){int temp = arr[j];arr[j] = arr[i];arr[i] = temp;}}}}int main() {int arr[] = { 55,56,33,11,22 };int len = sizeof(arr) / sizeof(arr[0]);selectSort(arr,len);//遍历排好序的数组for (int i = 0; i < len; i++){printf("%d ",arr[i]);}return 0;}

http://www.hkea.cn/news/144224/

相关文章:

  • 长沙营销型网站制作费用seo图片优化
  • 学生诚信档案建设网站seo数据分析
  • 北京住房城乡建设厅网站首页1688官网入口
  • 网站建设需要懂什么软件徐州百度seo排名优化
  • wordpress网站样式网站排名查询
  • 郑州网站建设推销外贸网站推广与优化
  • 当当网站开发系统说明搜索引擎排名google
  • 国外男女直接做的视频网站企业邮箱登录入口
  • 成都可以做网站的公司百度手机助手最新版下载
  • 赤峰网站建设招聘市场营销互联网营销
  • 网站开发后端需要哪些技术友情链接检索数据分析
  • 金华竞价排名 金华企业网站建设常见的网络营销平台有哪些
  • p2p网站开发关键词seo是什么意思
  • 自己免费怎么制作网站合肥今天的最新消息
  • 今日头条新闻10条简短seo网络优化招聘信息
  • 赣州人才网官方网站关键词seo优化软件
  • cad做兼职区哪个网站郑州网络营销公司排名
  • 宁夏银川做网站的公司有哪些网络营销分类
  • 换物网站为什么做不起来中国免费广告网
  • 可以显示一张图片的网站怎么搭建搜索引擎优化策略
  • 精品课程网站建设论文今天的新闻最新消息
  • 检查网站收录问题蚌埠seo外包
  • 建站展示网站优化网
  • 秦皇岛网站建设价格深圳seo公司
  • 广告型网站建设广州营销网站建设靠谱
  • 包头学做网站平台开发
  • 个人如何做微商城网站指数分布的分布函数
  • 北京网站设计哪家公司好建站工具
  • 深圳外贸网络推广seo诊断书案例
  • Java做网站的基本框架优化关键词规则