码迷,mamicode.com
首页 > 编程语言 > 详细

C语言查找算法

时间:2014-10-12 20:10:18      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:io   ar   数据   sp   art   问题   amp   ef   bs   

/**

 查找(数组)

 1> 顺序查找 : 就是遍历数组每一个元素同该元素比较,但是问题是效率比较低

 2> 折半查找 : 条件是数组必须是有顺序的

 */

#include <stdio.h>

#define n 2

int main()

{

    // 折半查找

        /*

         思路:将该元素同中间元素比较,如果有则存在,否则,判断该元素在哪半部分,继续查找;

         */

    

    // 任意输入整数x,在有顺序的数组中查找是否有同x值相同的元素

    // 定义输入数据

    int x = -1;

    // 数组array

    int array[10] = {2, 10, 19, 22, 34, 36, 55, 67, 76, 88};

    scanf("%d", &x);

    // 定义开始元素下标start, 尾标end, 中间元素下标mid

    int start = 0;

    int end = 9;

    int mid = (start + end)/2;

    while (array[mid] != x && (end > start)){

          if (x < array[mid]) {         

            end = mid - 1;

        }else{

            

            start = mid + 1;

        }

        mid = (start + end)/2;

    }

    printf("%d\n", mid);

    return 0;

}

C语言查找算法

标签:io   ar   数据   sp   art   问题   amp   ef   bs   

原文地址:http://www.cnblogs.com/-boy/p/4020803.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!