快排實現時候的一個邏輯錯誤

来源:http://www.cnblogs.com/wswang/archive/2016/01/11/5121824.html
-Advertisement-
Play Games

1 #include"header_file.h" 2 using namespace std; 3 4 void swap(int a,int b) 5 { 6 int t; 7 t=a; 8 a=b; 9 b=t;10 }11 12 void quick_s...


 

 1 #include"header_file.h"
 2 using namespace std;
 3 
 4 void swap(int a,int b)
 5 {
 6     int t;
 7     t=a;
 8     a=b;
 9     b=t;
10 }
11 
12 void quick_sort(int a[],int low,int high)
13 {
14     
15     if(low>=high)
16         return;
17         
18     int first;
19     int last;
20     first=low;
21     last=high;
22     
23     int x;
24     x=a[low];
25     
26 
27     while(low<high)
28     {
29         while(low<high&&a[high]>=x)
30         {
31             high--;
32         }    
33         swap(a[low],a[high]);
34         
35         cout<<i<<"      "<<low<<" low"<<"  "<<high<<endl;
36         
37         while(low<high&&a[low]<=x)
38         {
39             low++;
40         }
41         swap(a[high],a[low]);
42         cout<<i<<"      "<<low<<" high"<<"  "<<high<<endl;
43     }
44     if(first<low-1)
45         quick_sort(a,first,low-1);
46     if(last>low+1)
47         quick_sort(a,low+1,last);
48 }
49 
50 int main(void)
51 {
52     int a[7]={4,3,6,7,2,1,5};
53     quick_sort(a,0, sizeof(a) / sizeof(a[0]) - 1);
54     
55     cout<<"test"<<endl;
56     for(int i=0;i<7;i++)
57         cout<<a[i]<<" ";
58 }

執行程式會發現在演算法排序的地方無限迴圈,想了半天才知道是33和41行的位置,不管while迴圈是否執行都會執行swap語句。邏輯錯誤!

只能換種方法,改成大家最常見的那種就好了

 1 void quick_sort(int a[],int low,int high)
 2 {
 3     
 4     if(low>=high)
 5         return;
 6         
 7     int first;
 8     int last;
 9     first=low;
10     last=high;
11     
12     int x;
13     x=a[low];
14     
15 
16     while(low<high)
17     {
18         while(low<high&&a[high]>=x)
19         {
20             high--;
21         }    
22         a[low]=a[high];
23         
24     //    cout<<i<<"      "<<low<<" low"<<"  "<<high<<endl;
25         
26         while(low<high&&a[low]<=x)
27         {
28             low++;
29         }
30         a[high]=a[low];
31     //    swap(a[high],a[low]);
32     //    cout<<i<<"      "<<low<<" high"<<"  "<<high<<endl;
33     }
34     a[low]=x;
35     
36     if(first<low-1)
37         quick_sort(a,first,low-1);
38     if(last>low+1)
39         quick_sort(a,low+1,last);
40 }

這裡就不是交換了,直接賦值,然後最後給a[low]賦值。

 

很低級的錯誤

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 三層菜單,根據用戶所選數字,進入子菜單。一級一級呈現。 1 menu = { 2 'Beijing': { 3 "ChaoYang": { 4 "CBD": ['CICC', 'CCTV'], 5 "JinRongJie": [...
  • 在AN65209中 有一些應用筆記集錦,希望對大家有用。當然AN65209這篇應用筆記很重要,希望大家一定要看!!!一定要看!!!!
  • 註:在看這篇文章之前,如果對CopyOnWriteArrayList底層不清楚的話,建議先去看看CopyOnWriteArrayList源碼解析。http://www.cnblogs.com/java-zhao/p/5121944.html1、對於CopyOnWriteArraySet需要掌握以下幾...
  • 1 /*1.在Main.storyboard中找到,ScrollView和PageControl並添加到ViewController中。 2 2.在ScrollView中添加ImageView,新手引導頁有幾個圖片就添加幾個,然後設置ImageView的image,就是準備好的圖片。 3 3.要設....
  • 原文發表在我的 "博客主頁" ,轉載請註明出處! 建議三十四:掌握字元串的基本用法 編程有兩件事,一件是處理數值,另一件是處理字元串,在商業應用編程來說,處理字元串的代碼超過八成,所以需要重點掌握。 首先有個小技巧,python遇到未閉合的小括弧時會自動將多行代碼拼接為一行,同時把相鄰的兩個字...
  • P6spy是一個JDBC Driver的包裝工具,p6spy通過對JDBC Driver的封裝以達到對SQL語句的監聽和分析,以達到各種目的。P6spy1.3 sf.net http://sourceforge.net/projects/p6spy/?source=directoryWSJdbcDa...
  • 1.去oracl官網下載jdk http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads-1880260.html.2.安裝jdk,jre(java運行環境,包含Java程式的開發和調試工具,包含jdk的源代碼) 安...
  • 註:在看這篇文章之前,如果對ArrayList底層不清楚的話,建議先去看看ArrayList源碼解析。http://www.cnblogs.com/java-zhao/p/5102342.html1、對於CopyOnWriteArrayList需要掌握以下幾點創建:CopyOnWriteArrayL...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...