A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© yuyang 中级黑马   /  2015-1-5 23:44  /  824 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

//
//  main.c
//  05折半查找到 代码实现
//
//  Created by apple on 15-1-5.
//  Copyright (c) 2015年 itcast. All rights reserved.
//

#include <stdio.h>
/**
* 使用折半查找来查找一个数
*
*  @param arr 数组
*  @param len 数组的长度
*
*  @return 要查找的数的位置,如果查不到返回 -1
*/
int searchItem(int arr[],int len,int key)
{
   
    //先要定义变量
    int low,high=len-1,mid;
   
    //循环
    while(low<=high)
    {
        
        
        //计算 mid 的位置
        mid = (low+high)/2;
        
        //判断 key a[mid],右半区查找
        if(key>arr[mid])
        {
            //key > a[mid]  low = mid +1
            low = mid +1;
        }
        else if(key<arr[mid])
        {
            //key < a[mid] high = mid -1
            high = mid-1;
        }
        else
        {
            //key == a[mid]  return mid
            return mid;
        }
        
        
    }
    return -1;

}
int insertItemLoc(int arr[],int len,int key)
{
    //先要定义变量
    int low=0,high=len-1,mid;
    //循环
    while(low<=high)
    {
        //计算mid的位置
        mid = (low+high)/2;
        if(key>arr[mid])
        {
            //判断key a[mid]右半区查找
            low = mid+1;
        }
        else if(key<arr[mid])
        {
            high = mid-1;
        }
        else
        {
            return mid +1;//插入数的时候插入的位置
        }
    }
    return low;//如果插入的数数组里没有择该插入的位置
}

int main(int argc, const char * argv[])
{
   
   
    int a[]={3,4,12,20,21,23,28,45,67,100};
    //查找20 key=20;
   
   
  // int loc = searchItem(a,10,20);
    int loc = insertItemLoc(a,10,20);
    printf("%d\n",loc);
}

1 个回复

正序浏览
折半查找!
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马