• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 8, 文章 - 1, 評論 - 14, 引用 - 0
            數據加載中……

            基礎排序查找算法

            二分查找:
             binarysearch考的比較多,它適用于已經排序的元素中的查找

             int binarySearch(int a[],int len,int value)
            {
                int low = 0;
                
            int high = len -1;    
                
                
            while(low<=high)   //注意搜索條件,有可能兩者會相等
                {
                    
            int mid = (low+high)/2;
                    
            if(a[mid]==value) return mid;
                    
            else if(a[mid]>value) high = mid -1;            
                    
            else low = mid + 1;    
                }
                
            return -1;
            }

            int main()
            {
                
            int a[] = {1,2,3,4,5,6,7,8,9,10};
                
            int rec = binarySearch(a,10,4);
                
            if(rec==-1)
                    printf(
            "Not found\n");
                
            else
                    printf(
            "value is found %d \n",rec);
                
            return 0;
            }
             
             快速排序
             對冒泡算法的擴展
             
              int partition(int a[],int low,int high)
            {
                int temp = a[low];
                
            while(low<high)
                {
                    while(low<high && a[high]>=temp) --high;
                    a[low] 
            = a[high];
                    
            while(low<high && a[low]<=temp)  ++low;
                    a[high] 
            = a[low];
                }
                
                a[low] 
            = temp;
                
            return low;
            }
                



            void Qsort(int a[],int begin,int end)
            {
                
            int rec;
                
            if(begin<end)
                {
                    rec 
            = partition(a,begin,end);
                    printf(
            "rec is %d\n",rec);                
                    Qsort(a,begin,rec
            -1);
                    Qsort(a,rec
            +1,end);
                }
            }

            int main()
            {
                
            int  a[] = {1,4,0,-3,90,7,9,23};
                Qsort(a,
            0,7);
                
            int i =0;
                
            for(;i<8;i++)
                    printf(
            "%d\t",a[i]);

                
            return 0;
            }
             
              
              

            posted on 2011-08-19 18:28 兵臨城下 閱讀(1850) 評論(4)  編輯 收藏 引用 所屬分類: 算法

            評論

            # re: 基礎排序查找算法[未登錄]  回復  更多評論   

            這種二分查找除了考試幾乎沒有一點實用價值。通常使用的二分查找用于找一個序列的上界或下界。請到我主頁上看看原地歸并排序,有二分查找的相關代碼。

            用第一個元素做支點進行劃分,請想一想當待排序序列為逆序時它將退化成冒泡排序,那會有多慢吧?就算用隨機序列,這種快速排序恐怕也慢的不能接受,請到我主頁上看看快速排序的前兩個版本怎么設計的,就算最慢的原始版本(第3個版本),相信也會比你的這種快排快得多。

            唉,可惡的中國計算機教育啊,誤人子弟一批又一批,不知道還會繼續多少批...
            2011-08-19 21:26 | Chipset

            # re: 基礎排序查找算法  回復  更多評論   

            不全啊
            2011-08-19 23:07 | 向振偉

            # re: 基礎排序查找算法  回復  更多評論   

            @Chipset

            這種二分查找除了考試幾乎沒有一點實用價值??????????????? 上層做多的人一般會這么回復
            2011-08-22 17:48 | 過路客

            # re: 基礎排序查找算法[未登錄]  回復  更多評論   

            @過路客
            除了考試這種二分查找哪里用上了,我見識短淺,拜托您舉個例子吧:-)

            當隨機查找一個值時通常用哈希,不需要二分查找,因為二分查找跟哈希比起來慢多了,如果各個元素之間需要保持相對順序的話(假設可能有重復的),通常是查找上界或下界,用的是樓主這個二分查找的變形版本(看看STL lower_bound和upper_bound以及equal_range),而這個既非找上界也非找下界的二分查找在實際應用中幾乎就是個廢物!
            2011-08-25 13:24 | Chipset
            久久久久亚洲精品天堂久久久久久 | 久久精品亚洲一区二区三区浴池| 国产69精品久久久久观看软件| 久久91精品国产91| 久久久久久亚洲精品影院| 国内精品久久久久久野外| 久久精品国产69国产精品亚洲| A级毛片无码久久精品免费| 一本大道久久香蕉成人网| 少妇久久久久久被弄高潮| 国产精品久久久久9999高清| 精品一久久香蕉国产线看播放| 亚洲精品第一综合99久久| 狠狠色婷婷综合天天久久丁香| 久久久噜噜噜久久中文字幕色伊伊| 中文字幕久久久久人妻| 精品久久久久久国产三级| 国产成年无码久久久免费| 精品久久久久久无码免费| A级毛片无码久久精品免费| 久久99精品久久久久久野外| 精品久久久噜噜噜久久久 | 久久99毛片免费观看不卡| 久久毛片免费看一区二区三区| www.久久热.com| 久久综合亚洲欧美成人| 热久久最新网站获取| 久久久精品视频免费观看| 夜夜亚洲天天久久| 精品久久久久久无码中文字幕一区| 无码国内精品久久人妻麻豆按摩| 91精品观看91久久久久久| 69SEX久久精品国产麻豆| 精品久久人人爽天天玩人人妻| 亚洲精品美女久久久久99小说 | 久久伊人精品青青草原高清| 国产精品成人久久久| 精品久久久久久久久久久久久久久| 久久久亚洲欧洲日产国码二区 | 久久久SS麻豆欧美国产日韩| 久久久久成人精品无码|