c語言選擇排序函數(shù)法 選擇排序法c++語言

c語言怎樣通過函數(shù)調用實現(xiàn)選擇排序法

c語言通過函數(shù)調用實現(xiàn)選擇排序法:

公司主營業(yè)務:網(wǎng)站設計、做網(wǎng)站、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出城關免費做網(wǎng)站回饋大家。

1、寫一個簡單選擇排序法的函數(shù)名,包含參數(shù)。int SelectSort(int * ListData,int ListLength);

2、寫兩個循環(huán),在循環(huán)中應用簡單選擇插入排序:

int SelectSort(int * ListData,int ListLength)

{

int i , j ;

int length = ListLength;

for(i=0;i=length-2;i++)

{

int k = i;

for(j=i+1;j=length-1;j++)

{

if(ListData[k]ListData[j])

{

k=j;

}

}

if(k!=i)

{

int tmp = ListData[i];

ListData[i] = ListData[k];

ListData[k] = tmp;

}

}

return 0;

}

3、對編好的程序進行測試,得出測試結果:

int main()

{

int TestData[5] = {34,15,6,89,67};

int i = 0;

printf("排序之前的結果\n");

for(i = 0;i5;i++)

printf("|%d|",TestData[i]);

int retData = SelectSort(TestData,5);

printf("排序之后的結果:\n");

for(i = 0;i5;i++)

printf("|%d|",TestData[i]);

return 0;

}

4、簡單選擇排序中,需要移動的記錄次數(shù)比較少,主要的時間消耗在對于數(shù)據(jù)的比較次數(shù)?;旧希诒容^的時候,消耗的時間復雜度為:n*n。

選擇排序法c語言

.example-btn{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.example-btn:hover{color:#fff;background-color:#47a447;border-color:#398439}.example-btn:active{background-image:none}div.example{width:98%;color:#000;background-color:#f6f4f0;background-color:#d0e69c;background-color:#dcecb5;background-color:#e5eecc;margin:0 0 5px 0;padding:5px;border:1px solid #d4d4d4;background-image:-webkit-linear-gradient(#fff,#e5eecc 100px);background-image:linear-gradient(#fff,#e5eecc 100px)}div.example_code{line-height:1.4em;width:98%;background-color:#fff;padding:5px;border:1px solid #d4d4d4;font-size:110%;font-family:Menlo,Monaco,Consolas,"Andale Mono","lucida console","Courier New",monospace;word-break:break-all;word-wrap:break-word}div.example_result{background-color:#fff;padding:4px;border:1px solid #d4d4d4;width:98%}div.code{width:98%;border:1px solid #d4d4d4;background-color:#f6f4f0;color:#444;padding:5px;margin:0}div.code div{font-size:110%}div.code div,div.code p,div.example_code p{font-family:"courier new"}pre{margin:15px auto;font:12px/20px Menlo,Monaco,Consolas,"Andale Mono","lucida console","Courier New",monospace;white-space:pre-wrap;word-break:break-all;word-wrap:break-word;border:1px solid #ddd;border-left-width:4px;padding:10px 15px} 排序算法是《數(shù)據(jù)結構與算法》中最基本的算法之一。排序算法可以分為內部排序和外部排序,內部排序是數(shù)據(jù)記錄在內存中進行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部的排序記錄,在排序過程中需要訪問外存。常見的內部排序算法有:插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數(shù)排序等。以下是選擇排序算法:

選擇排序是一種簡單直觀的排序算法,無論什么數(shù)據(jù)進去都是 O(n?) 的時間復雜度。所以用到它的時候,數(shù)據(jù)規(guī)模越小越好。唯一的好處可能就是不占用額外的內存空間了吧。

1. 算法步驟

首先在未排序序列中找到最?。ù螅┰?,存放到排序序列的起始位置。

再從剩余未排序元素中繼續(xù)尋找最?。ù螅┰兀缓蠓诺揭雅判蛐蛄械哪┪?。

重復第二步,直到所有元素均排序完畢。

2. 動圖演示

代碼實現(xiàn) JavaScript 代碼實現(xiàn) 實例 function selectionSort ( arr ) {

var len = arr. length ;

var minIndex , temp ;

for ( var i = 0 ; i

c語言,使用函數(shù)的選擇法排序

void?selectionsort(int?a[],int?m)

{

int?i,j;

int?k;

int?tmp;

for(i?=?0;?i??m-1;?i++)//控制循環(huán)次數(shù),n個數(shù)需要n-1次循環(huán)

{

k?=?i;

for(j?=?i+1;?j??m?;?j++)

{

if(a[j]??a[k])

k?=?j;

}

//i不等于k是就證明a[i]不是最小的,

//i等于k時證明a[i]就是本輪比較過程中最小的值

if(i?!=?k)

{

tmp?=?a[i];

a[i]?=?a[k];

a[k]?=?tmp;

}

}

}

C語言sort函數(shù)如何使用

C語言中沒有預置的sort函數(shù)。如果在C語言中,遇到有調用sort函數(shù),就是自定義的一個函數(shù),功能一般用于排序。

一、可以編寫自己的sort函數(shù)。

如下函數(shù)為將整型數(shù)組從小到大排序。

void?sort(int?*a,?int?l)//a為數(shù)組地址,l為數(shù)組長度。

{

int?i,?j;

int?v;

//排序主體

for(i?=?0;?i??l?-?1;?i?++)

for(j?=?i+1;?j??l;?j?++)

{

if(a[i]??a[j])//如前面的比后面的大,則交換。

{

v?=?a[i];

a[i]?=?a[j];

a[j]?=?v;

}

}}

對于這樣的自定義sort函數(shù),可以按照定義的規(guī)范來調用。

二、C語言有自有的qsort函數(shù)。

功 能: 使用快速排序例程進行排序

頭文件:stdlib.h

原型: void qsort(void *base,int nelem,int width,int (*fcmp)(const void *,const void *));

參數(shù):

1 待排序數(shù)組首地址

2 數(shù)組中待排序元素數(shù)量

3 各元素的占用空間大小

4 指向函數(shù)的指針,用于確定排序的順序

這個函數(shù)必須要自己寫比較函數(shù),即使要排序的元素是int,float一類的C語言基礎類型。

以下是qsort的一個例子:

#includestdio.h

#includestdlib.h

int?comp(const?void*a,const?void*b)//用來做比較的函數(shù)。

{

return?*(int*)a-*(int*)b;

}

int?main()

{

int?a[10]?=?{2,4,1,5,5,3,7,4,1,5};//亂序的數(shù)組。

int?i;

qsort(a,n,sizeof(int),comp);//調用qsort排序

for(i=0;i10;i++)//輸出排序后的數(shù)組

{

printf("%d\t",array[i]);

}

return?0;

}

擴展資料:

sort函數(shù)的用法(C++排序庫函數(shù)的調用)

對數(shù)組進行排序,在c++中有庫函數(shù)幫我們實現(xiàn),這們就不需要我們自己來編程進行排序了。

(一)為什么要用c++標準庫里的排序函數(shù)

Sort()函數(shù)是c++一種排序方法之一,學會了這種方法也打消我學習c++以來使用的冒泡排序和選擇排序所帶來的執(zhí)行效率不高的問題!因為它使用的排序方法是類似于快排的方法,時間復雜度為n*log2(n),執(zhí)行效率較高!

(二)c++標準庫里的排序函數(shù)的使用方法

I)Sort函數(shù)包含在頭文件為#includealgorithm的c++標準庫中,調用標準庫里的排序方法可以不必知道其內部是如何實現(xiàn)的,只要出現(xiàn)我們想要的結果即可!

II)Sort函數(shù)有三個參數(shù):

(1)第一個是要排序的數(shù)組的起始地址。

(2)第二個是結束的地址(最后一位要排序的地址的下一地址)

(3)第三個參數(shù)是排序的方法,可以是從大到小也可是從小到大,還可以不寫第三個參數(shù),此時默認的排序方法是從小到大排序。

Sort函數(shù)使用模板:

Sort(start,end,排序方法)

下面就具體使用sort()函數(shù)結合對數(shù)組里的十個數(shù)進行排序做一個說明!

例一:sort函數(shù)沒有第三個參數(shù),實現(xiàn)的是從小到大

#includeiostream

#includealgorithm

using namespace std;

int main()

{

int a[10]={9,6,3,8,5,2,7,4,1,0};

for(int i=0;i10;i++)

couta[i]endl;

sort(a,a+11);

for(int i=0;i10;i++)

couta[i]endl;

return 0;

}

編譯器

GCC,GNU組織開發(fā)的開源免費的編譯器

MinGW,Windows操作系統(tǒng)下的GCC

Clang,開源的BSD協(xié)議的基于LLVM的編譯器

Visual C++?:: cl.exe,Microsoft VC++自帶的編譯器

集成開發(fā)環(huán)境

CodeBlocks,開源免費的C/C++ IDE

CodeLite,開源、跨平臺的C/C++集成開發(fā)環(huán)境

Orwell Dev-C++,可移植的C/C++IDE

C-Free

Light Table

Visual Studio系列

Hello World

參考資料:百度百科-sort函數(shù)

C語言中的選擇排序法是什么?

選擇排序(Selection sort)是一種簡單直觀的排序算法。工作原理是每一次從待排序的數(shù)據(jù)元素中選出最?。ɑ蜃畲螅┑囊粋€元素,存放在序列的起始位置,直到全部待排序的數(shù)據(jù)元素排完。

以下是一個實現(xiàn)選擇排序的例子:

#define?SWAP(x,?y,?t)??((t)?=?(x),?(x)?=?(y),?(y)?=?(t))

//將list中的n個數(shù)據(jù),通過選擇排序算法排序。

void?selete_sort(int?list[],?int?n)

{

int?i,?j,?min,?temp;

for?(i?=?0;?i??n?-?1;?i++){

min?=?i;

for?(j?=?i?+?1;?j??n;?j++)//找出最小元素的下標。

if?(list[j]??list[min])

min?=?j;

SWAP(list[i],?list[min],?temp);//交換最小元素到當前起始位置。

}

}

當前題目:c語言選擇排序函數(shù)法 選擇排序法c++語言
文章轉載:http://muchs.cn/article6/docdoog.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、標簽優(yōu)化、網(wǎng)站設計、虛擬主機商城網(wǎng)站、網(wǎng)站導航

廣告

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

網(wǎng)站優(yōu)化排名