這是c語言求二分插入排序的程序,c語言兩種排序方法

本文目錄一覽:

C語言怎麼用二分查找插入排序

進行二分查找的前提是數組已排序,這裡假定數組遞增排序。

每次查找都將待查找數num與處於數組中間位置a[mid]的數進行比較,num a[mid]則在mid之前的元素中進行查找,反之在mid之後的元素中進行查找。

在函數中使用low, mid, high來對待查找的範圍來進行標記。

參考代碼如下:

/*整數查找*/

void binsearch( int num, int a[], int length )        /*num為待查找數字,length為數組a的長度*/

{

    int low, mid, high;

    low = 0;

    high = length – 1;

    while( low = high )

    {

        mid = ( low + high ) / 2;

        if( a[mid]  num )

            high = mid – 1;

        else if( a[mid]  num )

            low = mid + 1;

        else

            return mid;

    }

    return -1        /*未查找到num返回-1*/

}

C語言二分法插入已排序的數組中

#includestdlib.h

void sort(int a[],int n){ /*排序函數,要使用二分法查找就必須對數組進行排序*/

int i,k;

for(i=0;in;i++){

int min=i;

for(k=i+1;kn;k++)

if(a[min]a[k])min=k;

if(i!=min){

a[min]+=a[i];/*這裡是運用加減法交換兩個數*/

a[i]=a[min]-a[i];

a[min]-=a[i];

}

}

}int find(int a[],int n,int key){/*二分法查找;參數:數組名,數組長度,查找關鍵字*/

int min=0,max=n-1;/*二分法查找頭尾變量*/

while(minmax){/*如果最頭的變量值大於最尾變量的值,則查找不到,查找失敗*/

int cen = (min+max)/2;

if(a[cen]==key) return cen;/*如果查到,則返回關鍵字在排序數組的下標*/

if(cen==min || cen==max)break;/*如果中間變量等於頭尾任一個變量,同樣查找失敗*/ if(a[cen]key) max=cen;

else min=cen; }

return -1;

}

void main(){/*主程序只是為了證明兩個函數的可行性,可以自己編寫*/

int a[]={14,10,25,36,87,95,10,12,13,8},i;

sort(a,10);

i=find(a,10,11);

if(i!=-1)

printf(“be found”);

else

printf(“no found”);

getch();

}

這是C語言求二分插入排序的程序,有問題,求教,急急急!!!

#include stdio.h

int main()

{

    int a[11]; //a[0]作為哨兵,從a[1]到a[10]是真正數據

    int low,mid,high;

    int x;

    int i,j,n;

    n=10;

    for(i=1; i=n; i++)

    {

        a[i]=0;

    }

    i=1;

    printf(“\n要插入的數是 (還有%d個):”,n+1-i);

    scanf(“%d”,x);

    a[i]=x;

    printf(“x=%d\n”,x);

    printf(“排列後 “);

    for(j=1; j=n; j++)

    {

        printf(” %d”,a[j]);

    }

    printf(“\n”);

    for(i=2;  i=n; i++)

    {

        printf(“\n要插入的數是 (還有%d個):”,n+1-i);

        scanf(“%d”,x);

        a[i]=x;

        a[0]=a[i]; //a[0]作為哨兵

        low=1;

        high=i-1;

        while(low=high)

        {

            mid=(low+high)/2;

            if(a[mid]  a[0])

            {

                high=mid-1;

            }

            else

            {

                low=mid+1;

            }

        }

        //通過上述的折半查找,得出high值

        //數據往後移動

        for(j=i-1 ; j=high+1 ; j–)

        {

            a[j+1]=a[j];

        }

        //a[0]就是x,將x插入正確的位置

        a[high+1]=a[0];

        printf(“\nx=%d\n”,x);

        printf(“排列後 “);

        for(j=1; j=n; j++)

        {

            printf(” %d”,a[j]);

        }

        printf(“\n”);

    }

    printf(“\n我是答案;”);

    for(i=1; i=n; i++)

    {

        printf(” %d”,a[i]);

    }

    return 0;

}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/154184.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-15 03:25
下一篇 2024-11-15 03:25

相關推薦

  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智能、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29
  • python強行終止程序快捷鍵

    本文將從多個方面對python強行終止程序快捷鍵進行詳細闡述,並提供相應代碼示例。 一、Ctrl+C快捷鍵 Ctrl+C快捷鍵是在終端中經常用來強行終止運行的程序。當你在終端中運行…

    編程 2025-04-29
  • Python程序文件的拓展

    Python是一門功能豐富、易於學習、可讀性高的編程語言。Python程序文件通常以.py為文件拓展名,被廣泛應用於各種領域,包括Web開發、機器學習、科學計算等。為了更好地發揮P…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python購物車程序

    Python購物車程序是一款基於Python編程語言開發的程序,可以實現購物車的相關功能,包括商品的添加、購買、刪除、統計等。 一、添加商品 添加商品是購物車程序的基礎功能之一,用…

    編程 2025-04-29
  • 爬蟲是一種程序

    爬蟲是一種程序,用於自動獲取互聯網上的信息。本文將從如下多個方面對爬蟲的意義、運行方式、應用場景和技術要點等進行詳細的闡述。 一、爬蟲的意義 1、獲取信息:爬蟲可以自動獲取互聯網上…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • Vb運行程序的三種方法

    VB是一種非常實用的編程工具,它可以被用於開發各種不同的應用程序,從簡單的計算器到更複雜的商業軟件。在VB中,有許多不同的方法可以運行程序,包括編譯器、發布程序以及命令行。在本文中…

    編程 2025-04-29
  • Python一元二次方程求解程序

    本文將詳細闡述Python一元二次方程求解程序的相關知識,為讀者提供全面的程序設計思路和操作方法。 一、方程求解 首先,我們需要了解一元二次方程的求解方法。一元二次方程可以寫作: …

    編程 2025-04-29

發表回復

登錄後才能評論