zoukankan      html  css  js  c++  java
  • C程序设计语言练习 第三章

    3.3 else-if语句

    折半查找,这里通过一个折半查找说明三路判定程序的用法。该函数用于判定已排序好的数组v中是否存在某个特定的值。数组v的元素必须以升序排列。如果v中包含x,则该函数返回x在v中的位置(介于0~n之间的一个整数),否则,该函数返回-1。

    思路:在折半查找时,首先将输入值x与数组v的中间元素进行比较。如果x小于中间元素的值,则在该函数的前半部分查找,否则,在该数组的后半部分查找。在这两种情况下,下一步都是将x与所选部分的中间元素进行比较。这个过程一直进行下去,直到找到制定的值或者查找范围为空。

    int bitsearch(int x,int v[], int n)
    {
        int low,high,mid;
    
        low = 0;
        high = n-1;
    
        while (low <= high) {
            mid = (low + high) / 2;
            if(x < v[mid])
                high = mid -1;
            else if(x > v[mid])
                low = mid + 1;
            else
                return mid;
        }
        return -1;
    }
    

    练习3-1

    在上面有关折半查找的例子中,while循环语共执行了两次,其实只要一次就足够了(代价是将更多的测试在循环外执行)。重写该函数,使得在循环内部只执行一次。比较两者的运行时间。

    对于三路判定以后或许可以这样改进。

    int bitsearch2(int x,int v[], int n)
    {
        int low,high,mid;
        
        low = 0;
        high = n-1;
        if( x<v[low] || x>v[high]) 
            return -1;
    
        mid = (low + high) / 2;
        while (low <= high && x != v[mid]) {
            if(x < v[mid])
                high = mid -1;
            else 
                low = mid + 1;
            mid = (low + high) / 2;
        }
        if(x == v[mid])
            return mid;
        else 
            return -1;
    }
    
  • 相关阅读:
    token原理
    1.系统代码读取配置文件
    redis hash怎么用
    那么都数据库表,那么多不同记录。是怎样都存储在一个key-value数据库的?
    jedis操作redis全指南
    redis列表list
    jedis操作
    redis
    android raw与assets资源
    Zoie Merge Policy
  • 原文地址:https://www.cnblogs.com/wjundong/p/11578336.html
Copyright © 2011-2022 走看看