新聞中心
C語(yǔ)言 排序 函數(shù)
一群菜鳥(niǎo)不懂的亂說(shuō)。 我把樓主的代碼改了一些,如下 #includestdio.hint input(int data[], int argc, int *n)
創(chuàng)新互聯(lián)建站主要從事網(wǎng)站建設(shè)、成都做網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)麻山,十年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專(zhuān)業(yè),歡迎來(lái)電咨詢建站服務(wù):18980820575
{
int i;
printf("請(qǐng)輸入要輸入數(shù)的個(gè)數(shù)");
scanf("%d", n);
if(*n argc) {
printf("segment fault!");
return -1;
}
for(i = 0; i *n; i++) {
printf("輸入的第%d個(gè)數(shù).", i+1);
scanf("%d", data+i); //canf("%d", data[i]);
}
printf("輸入的數(shù)是:\n");
for(i = 0; i *n; i++) {
printf("%5d\n", data[i]);
}
return 0;
}void sort(int n, int data[])
{
int i, j, temp;
for(i = 0; i n-1; i++) {
for(j = i+1; j n; j++)
if(data[i] data[j]) {
temp = data[i];
data[i] = data[j];
data[j] = temp;
}
}
printf("排序后的結(jié)果如下:\n");
for(i = 0; i n; i++)
printf("%5d\n", data[i]);
}int main()
{
int data[100];
int n;
if(input(data, 100, n) == -1)
return -1;
sort(n, data);
return 0;
}
對(duì)于以上代碼,做出如下解釋?zhuān)海?)C語(yǔ)言的參數(shù)有形參和實(shí)參的說(shuō)法,形參在傳遞到函數(shù)內(nèi)的時(shí)候,復(fù)制一個(gè)副本給函數(shù),在函數(shù)內(nèi)部和外部是兩個(gè)完全不同的變量,函數(shù)結(jié)束,空間也被釋放,所以不能在函數(shù)內(nèi)部來(lái)改變外部的值。所以要像樓主這樣用一個(gè)函數(shù)給一個(gè)變量賦值,要用實(shí)參int input(int data[], int argc, int *n)中的int *n就是實(shí)現(xiàn)形式,這種辦法把n的地址傳遞給函數(shù)。當(dāng)然,在調(diào)用函數(shù)的時(shí)候也同樣要傳遞地址指針類(lèi)型(n)。(2)if(*n argc) {
printf("segment fault!");
return -1;
}這一段是我加進(jìn)去的,因?yàn)榘凑諛侵鞯囊馑迹琩ata數(shù)組的長(zhǎng)度也要傳遞進(jìn)去,但是意思何在?所以只好加了這一段,并把函數(shù)改為有類(lèi)型的,以檢驗(yàn)是否有數(shù)據(jù)溢出。(3)scanf("%d", data+i); //scanf("%d", data[i]);這里我改動(dòng)的主要原因是為了提升程序速度,scanf("%d", data[i]);同樣可以運(yùn)行,但是尋址一次,又回頭要地址,這樣繞了一圈,沒(méi)有必要。 對(duì)于樓主提幾點(diǎn)建議:(1)C語(yǔ)言的精髓在于指針,剛才說(shuō)到的實(shí)參,就是用指針的概念實(shí)現(xiàn)的。scanf("%d", data+i); 一行,同樣也是把數(shù)組頭指針加上偏移地址,得到所要的地址。(2)C語(yǔ)言編程的時(shí)候特別要注意數(shù)據(jù)的溢出,這是所有初學(xué)者頭疼的問(wèn)題之一。建議在一開(kāi)始就養(yǎng)成習(xí)慣,經(jīng)常檢驗(yàn)數(shù)組的邊界。(3)void main一看就知道是看潭浩強(qiáng)的書(shū)長(zhǎng)大的程序員。建議我們都用int main(){ return 0; }的形式,可以看看C語(yǔ)言之父KR的書(shū)。主函數(shù)的返回值是告訴操作系統(tǒng),這個(gè)函數(shù)是正常退出(返回0),還是異常退出(非0,經(jīng)常是-1)。(4)在做實(shí)際項(xiàng)目的時(shí)候,程序經(jīng)常是要回頭看的,也經(jīng)常是要給別人看以達(dá)到維護(hù)的目的的。除了要養(yǎng)成良好的文檔書(shū)寫(xiě)習(xí)慣以外(學(xué)習(xí)軟件工程以后你就會(huì)掌握),還要養(yǎng)成良好的編程風(fēng)格,這里我建議看《thinking in C++》,并按照里面例題的風(fēng)格,養(yǎng)成自己的習(xí)慣。
c語(yǔ)言怎么用自定義函數(shù)排序
#include stdio.h
#include string.h#define NUM 3
struct student
{
char name[20]; /*姓名*/
long num; /*12位學(xué)號(hào)*/
double sum; /*總分*/
};
void Create_Students(struct student stu[NUM])
{
struct student *p;
printf("請(qǐng)輸入學(xué)生姓名 學(xué)號(hào)(12位) 總分:\n");
for( p = stu; p stu+NUM; p++)
{
scanf("%s %d %lf",p-name,p-num,p-sum); }
}
void Order_Students(struct student stu[NUM])//起泡法
{
int i,j;
struct student temp;
for(i=NUM-1;i=0;i--)
for(j=0;ji;j++)
if(stu[j].sumstu[j+1].sum)
{
temp = stu[j];
stu[j] = stu[j+1];
stu[j+1]=temp;
}
}
void main()
{
int i=1;
struct student *p;
struct student stu[NUM];
Create_Students(stu);
Order_Students(stu);
printf("%-20s %-13s %-6s %4s\n","姓名","學(xué)號(hào)(12位)","總成績(jī)","名次");
for(p=stu;pstu+NUM;p++,i++)
{
printf("%-20s %-13.0d %-8.2f %2d\n",p-name,p-num,p-sum,i);
}
}//你參考參考,嘿
C語(yǔ)言中的排序函數(shù)是什么
include cstdlib 或 #include stdlib.h
qsort(void* base, size_t num, size_t width, int(*)compare(const void* elem1, const void* elem2))
參數(shù)表
*base: 待排序的元素(數(shù)組,下標(biāo)0起)。
num: 元素的數(shù)量。
width: 每個(gè)元素的內(nèi)存空間大小(以字節(jié)為單位)。可用sizeof()測(cè)得。
int(*)compare: 指向一個(gè)比較函數(shù)。*elem1 *elem2: 指向待比較的數(shù)據(jù)。
比較函數(shù)的返回值
返回值是int類(lèi)型,確定elem1與elem2的相對(duì)位置。
elem1在elem2右側(cè)返回正數(shù),elem1在elem2左側(cè)返回負(fù)數(shù)。
控制返回值可以確定升序/降序。
產(chǎn)生隨機(jī)數(shù)的函數(shù)也是rand(),不是rank().
C語(yǔ)言,寫(xiě)一個(gè)函數(shù),void sort(float a[ ],int n)功能為對(duì)數(shù)組a中的n個(gè)數(shù)進(jìn)行升序排列?
#includestdio.h
float sort(float a[],int n)
{
float t;
for(int i=0;in;i++)
for(int j=0;jn-1-i;j++)
if(a[j]a[j+1])
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
for(int i=0;in;i++)
printf("%.f ",a[i]);
}
int main()
{
float a[20]={12,0,63,8,13,101,123,15,77,65,68,156,15,28,31,62,56,60,22,23};
sort(a,20);//引用
return 0;
}
分享標(biāo)題:c語(yǔ)言+自動(dòng)排序的函數(shù),c語(yǔ)言實(shí)現(xiàn)排序
分享地址:http://www.ef60e0e.cn/article/hdhhci.html