bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

C語言數據結構折半查找(二分查找)-創新互聯

折半查找:

也稱二分查找,它是一種效率較高的查找方法,但是,折半查找要求線性表必須采用順序存儲結構,而且表中元素按關鍵字有序排列。

創新互聯是一家專注于網站制作、成都網站建設與策劃設計,斗門網站建設哪家好?創新互聯做網站,專注于網站建設10年,網設計領域的專業建站公司;建站業務涵蓋:斗門等地區。斗門做網站價格咨詢:13518219792

查找過程:
從表的中間記錄開始,如果給定值和中間記錄的關鍵字相等,則查找成功;如果給定值大于或者小于中間記錄的關鍵字,則在表中大于或小于中間記錄的那一半中查找,這樣重復操作,直到查找成功,或者在某一步查找區間為空,則代表查找失敗。

折半查找每一次查找都使查找范圍縮小一半,與順序查找相比,很顯然會提高查找效率。

數據元素的定義:
typedef int KeyType ;

typedef struct {KeyType key;        //關鍵字域
}ElemType;

typedef struct {ElemType *R;        //存放查找表中元素的數組
    int length;         //記錄查找表中的長度
}SSTable;
創建查找表:
void Create_List(SSTable *ss){int length;
    printf("請輸入元素個數:");
    scanf("%d",&length);
    ss->length = length;
    ss->R = (ElemType *)malloc((length + 1) * sizeof(ElemType)); //分配內存
    printf("請依次輸入元素:");
    for(int i = 1;i<= length;i++){scanf("%d",&ss->R[i].key);
    }
}
排序:

由于上面寫的表并非是順序表,而且為了程序的開放性,設定多一個排序,給表排序。這里利用冒泡排序。

冒泡排序:
是一種最簡單的交換排序方法,它通過兩兩比較相鄰記錄的關鍵字,如果為逆序,則進行交換,從而使關鍵字小的記錄如氣泡一般逐漸往上“漂浮”,或者使關鍵字大的記錄如石頭一般逐漸往下沉。

void Bubble(SSTable *ss,int length){printf("排序后的結果:");
    ss->R[0] = ss->R[1];//哨兵初始值
    for(int i=0;i//冒泡排序,循環遍歷
        for(int j=1;jif(ss->R[j].key >ss->R[j+1].key) {//交換數值
                int temp;
                temp=ss->R[j].key;
                ss->R[j].key=ss->R[j+1].key;
                ss->R[j+1].key=temp;
            }
        }
    }
    for(int i = 1;i<= ss->length;i++){printf("%d  ",ss->R[i].key);
    }
}

最后輸出排序結果,檢驗。

折半查找

置查找區間初值,low為1,high為表長。

當low<=high 時,循環執行:
mid取low和high的中間值;
將給定值x與中間位置記錄的關鍵字進行比較,若相等則查找成功,返回中間位置mid;
若不相等,則利用中間位置記錄將表對分前、后兩個子表。

唯一注意的是,循環條件是 low<=high,而不是low

int Search(SSTable *ss,int x){int low = 1,high,mid;
    high = ss->length;
    while (low<= high){mid = (low + high) / 2;
        if (ss->R[mid].key == x){return mid;
        }
        else if (ss->R[mid].key< x){low = mid;
        }
        else if(ss->R[mid].key >x){high = mid;
        }
    }
}
完整代碼:
#include#includetypedef int KeyType ;

typedef struct {KeyType key;        //關鍵字域
}ElemType;

typedef struct {ElemType *R;        //存放查找表中元素的數組
    int length;         //記錄查找表中的長度
}SSTable;

//創建查找表
void Create_List(SSTable *ss){int length;
    printf("請輸入元素個數:");
    scanf("%d",&length);
    ss->length = length;
    ss->R = (ElemType *)malloc((length + 1) * sizeof(ElemType)); //分配內存
    printf("請依次輸入元素:");
    for(int i = 1;i<= length;i++){scanf("%d",&ss->R[i].key);
    }
}

//排序
void Bubble(SSTable *ss,int length){printf("排序后的結果:");
    ss->R[0] = ss->R[1];//哨兵初始值
    for(int i=0;i//冒泡排序,循環遍歷
        for(int j=1;jif(ss->R[j].key >ss->R[j+1].key) {//交換數值
                int temp;
                temp=ss->R[j].key;
                ss->R[j].key=ss->R[j+1].key;
                ss->R[j+1].key=temp;
            }
        }
    }
    for(int i = 1;i<= ss->length;i++){printf("%d  ",ss->R[i].key);
    }
}

//二分查找法
int Search(SSTable *ss,int x){int low = 1,high,mid;
    high = ss->length;
    while (low<= high){mid = (low + high) / 2;
        if (ss->R[mid].key == x){return mid;
        }
        else if (ss->R[mid].key< x){low = mid;
        }
        else if(ss->R[mid].key >x){high = mid;
        }
    }
}

int main() {SSTable ss;
    int x,location;
    Create_List(&ss);
    Bubble(&ss,ss.length);
    while (1){printf("\n請輸入需要查找的元素:");
        scanf("%d",&x);
        Search(&ss,x);
        location = Search(&ss,x);
        if (location == 0){printf("查找失敗!\n");
        } else{printf("數據在查找表中的位置為:%d\n",location);
        }
    }
    return 0;
}

在主函數也給一個while的死循環,方便多次查找,不用查找一次運行一次代碼。

這個代碼出現一個bug,就是會在查找時候出現卡住,出不了結果的情況
在查找78時候,一直沒有顯示出結果。查找無表內元素時候,也出現這樣情況。
希望有大佬幫幫忙看看什么情況 嘻嘻~
如果有錯,望指出更正。向大家學習!

最后:這是我一次數據結構作業。

你是否還在尋找穩定的海外服務器提供商?創新互聯www.cdcxhl.cn海外機房具備T級流量清洗系統配攻擊溯源,準確流量調度確保服務器高可用性,企業級服務器適合批量采購,新人活動首月15元起,快前往官網查看詳情吧

分享標題:C語言數據結構折半查找(二分查找)-創新互聯
分享路徑:http://vcdvsql.cn/article4/jjooe.html

成都網站建設公司_創新互聯,為您提供電子商務全網營銷推廣面包屑導航虛擬主機手機網站建設網站維護

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

手機網站建設