以下是一個使用C語言編寫一維數(shù)組排序函數(shù)并在主函數(shù)中調(diào)用的示例代碼,采用的是從小到大排序的方式,可以根據(jù)需要進(jìn)行修改:
創(chuàng)新互聯(lián)公司專注于義安企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),商城網(wǎng)站制作。義安網(wǎng)站建設(shè)公司,為義安等地區(qū)提供建站服務(wù)。全流程按需開發(fā),專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)
```c
#include stdio.h
// 排序函數(shù),參數(shù)為待排序數(shù)組和數(shù)組長度
void sort(int arr[], int len) {
int i, j, tmp;
// 冒泡排序
for (i = 0; i len - 1; i++) {
for (j = 0; j len - i - 1; j++) {
if (arr[j] arr[j + 1]) { // 相鄰元素比較,如果前面的大于后面的,則交換位置
tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
}
}
}
}
int main() {
int arr[] = { 3, 1, 5, 7, 2, 4, 6 };
int len = sizeof(arr) / sizeof(int);
int i;
// 輸出排序前的數(shù)組
printf("排序前:
");
for (i = 0; i len; i++) {
printf("%d ", arr[i]);
}
printf("
");
// 調(diào)用排序函數(shù)進(jìn)行排序
sort(arr, len);
// 輸出排序后的數(shù)組
printf("排序后:
");
for (i = 0; i len; i++) {
printf("%d ", arr[i]);
}
printf("
");
return 0;
}
```
在上面的代碼中,我們定義了一個`sort`函數(shù),實現(xiàn)了一維數(shù)組排序,并接受待排序數(shù)組和數(shù)組長度為參數(shù)。排序的算法采用的是冒泡排序,每次比較相鄰元素的大小并交換它們的位置,直到排序完成。
在主函數(shù)中,我們聲明了一個待排序的一維數(shù)組`arr`,并計算了數(shù)組長度。然后,我們輸出了排序前的數(shù)組,并調(diào)用`sort`函數(shù)進(jìn)行排序。最后,我們輸出排序后的數(shù)組。
需要注意的是,排序函數(shù)的實現(xiàn)方式可以有多種,根據(jù)實際需求和數(shù)據(jù)類型的不同,選擇合適的排序算法可以提高排序的效率和準(zhǔn)確性。在調(diào)用排序函數(shù)時,需要確保輸入的參數(shù)正確和合法,避免出現(xiàn)數(shù)組越界等錯誤。
樓上的用的是C++
若單純的用C那就是這樣
#includestdio.h
#define
"NO.%d
%d
%d
%d
%d
%3.2f
%3.2f\n",1+i,stu[i].num,stu[i].mat,stu[i].ENG,stu[i]點抗 ,stu[i].aver,stu[i].total//宏定義節(jié)約時間
struct
student
{
int
num;
int
mat;
int
ENG;
int
com;
float
aver;
float
total;
}stu[10];//定義結(jié)構(gòu)體變量
void
main()
{
int
i;
void
take_turn_print(struct
student
stu1[10])
;
float
sum(int
x,int
y,int
z);//聲明求和函數(shù)
for(i=0;i10;i++)
scanf("%d%d%d%d",stu[i].num,stu[i].mat,stu[i].ENG,stu[i]點抗 );
for(i=0;i10;i++)
{
stu[i].total=sum(stu[i].mat,stu[i].ENG,stu[i]點抗 );//調(diào)用求和函數(shù)
stu[i].aver=stu[i].total/3;
}
take_turn_print(stu);//調(diào)用排序
打印函數(shù)
}
void
take_turn_print(struct
student
stu1[10])
{
void
change(int
*x,int
*y);//聲明換位函數(shù)
void
change1(float
*x,float
*y);//聲明換位函數(shù)
int
i,j;
for(j=0;j9;j++)//冒泡排序
為理解簡單
就沒用別的排序方法
哈哈
{
for(i=0;i9-j;i++)
{
if(stu1[i].averstu1[i+1].aver)
{
change(stu1[i].num,stu1[i+1].num);//
值交換
change(stu1[i].mat,stu1[i+1].mat);//
值交換
change(stu1[i].ENG,stu1[i+1].ENG);//
值交換
change(stu1[i]點抗 ,stu1[i+1]點抗 );//
值交換
change1(stu1[i].aver,stu1[i+1].aver);//
值交換
change1(stu1[i].total,stu1[i+1].total);//
值交換
}
}
}
for(i=0;i10;i++)
printf(print);//打印
}
void
change(int
*x,int
*y)
{
int
i;
i=*x;
*x=*y;
*y=i;//利用指針做變量替換
}
void
change1(float
*x,float
*y)
{
float
i;
i=*x;
*x=*y;
*y=i;//利用指針做變量替換
}
float
sum(int
x,int
y,int
z)
{
float
i;
i=(float)(x+y+z);
return(i);
}
前幾天也是幫同學(xué)做這樣的題
一模一樣
看來你也是WH大學(xué)的
C語言中沒有預(yù)置的sort函數(shù)。如果在C語言中,遇到有調(diào)用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ī)范來調(diào)用。
二、C語言有自有的qsort函數(shù)。
功 能: 使用快速排序例程進(jìn)行排序
頭文件: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語言基礎(chǔ)類型。
以下是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);//調(diào)用qsort排序
for(i=0;i10;i++)//輸出排序后的數(shù)組
{
printf("%d\t",array[i]);
}
return?0;
}
擴(kuò)展資料:
sort函數(shù)的用法(C++排序庫函數(shù)的調(diào)用)
對數(shù)組進(jìn)行排序,在c++中有庫函數(shù)幫我們實現(xiàn),這們就不需要我們自己來編程進(jìn)行排序了。
(一)為什么要用c++標(biāo)準(zhǔn)庫里的排序函數(shù)
Sort()函數(shù)是c++一種排序方法之一,學(xué)會了這種方法也打消我學(xué)習(xí)c++以來使用的冒泡排序和選擇排序所帶來的執(zhí)行效率不高的問題!因為它使用的排序方法是類似于快排的方法,時間復(fù)雜度為n*log2(n),執(zhí)行效率較高!
(二)c++標(biāo)準(zhǔn)庫里的排序函數(shù)的使用方法
I)Sort函數(shù)包含在頭文件為#includealgorithm的c++標(biāo)準(zhǔn)庫中,調(diào)用標(biāo)準(zhǔn)庫里的排序方法可以不必知道其內(nèi)部是如何實現(xiàn)的,只要出現(xiàn)我們想要的結(jié)果即可!
II)Sort函數(shù)有三個參數(shù):
(1)第一個是要排序的數(shù)組的起始地址。
(2)第二個是結(jié)束的地址(最后一位要排序的地址的下一地址)
(3)第三個參數(shù)是排序的方法,可以是從大到小也可是從小到大,還可以不寫第三個參數(shù),此時默認(rèn)的排序方法是從小到大排序。
Sort函數(shù)使用模板:
Sort(start,end,排序方法)
下面就具體使用sort()函數(shù)結(jié)合對數(shù)組里的十個數(shù)進(jìn)行排序做一個說明!
例一: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ù)