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;
    }
    
  • 相关阅读:
    继承
    对象和封装
    类的无参、带参方法
    类和对象
    数组
    循环结构
    选择结构
    变量、数据类型和运算符
    快捷键
    MyEclipse与JDK的配置
  • 原文地址:https://www.cnblogs.com/wjundong/p/11578336.html
Copyright © 2011-2022 走看看