本文目錄一覽:
- 1、c語言排序程序
- 2、c語言的兩種排序?
- 3、c語言,數組排序,返回序號
c語言排序程序
#include stdio.h
void main()
{
int a[10];
int i,j,t;
for(i=0;i=9;i++)
scanf(“%d”,a[i]);
for(i=0;i9;i++)
for(j=i+1;j10;j++)
{
if(a[i]a[j])
{ /*交換從這裡開始*/
t=a[i];
a[i]=a[j];
a[j]=t;}
} /*交換到這裡結束*/
for(i=0;i=9;i++)
printf(“%d “,a[i]);
printf(“\n”);/*下一次循環時換行*/
}
也沒有多大的錯誤
小心點,C是分語句執行的,到了“;”就是一條語句,除非你用“{}”,這樣可以將幾個語句合併為一條語句。可以簡單這麼理解。
c語言的兩種排序?
1、選擇排序法
要求輸入10個整數,從大到小排序輸出
輸入:2 0 3 -4 8 9 5 1 7 6
輸出:9 8 7 6 5 3 2 1 0 -4
代碼:
#includelt;stdio.hgt;
int main(int argc,const char*argv[]){
int num[10],i,j,k,l,temp;
//用一個數組保存輸入的數據
for(i=0;ilt;=9;i++)
{
scanf(“%d”,numlt;igt;);
}
//用兩個for嵌套循環來進行數據大小比較進行排序
for(j=0;jlt;9;j++)
{
for(k=j+1;klt;=9;k++)
{
if(num[j]lt;num[k])//num[j]lt;num[k]
{
temp=num[j];
num[j]=num[k];
num[k]=temp;
}
}
}
//用一個for循環來輸出數組中排序好的數據
for(l=0;llt;=9;l++)
{
printf(“%d”,num[l]);
}
return 0;
}
2、冒泡排序法
要求輸入10個整數,從大到小排序輸出
輸入:2 0 3-4 8 9 5 1 7 6
輸出:9 8 7 6 5 3 2 1 0-4
代碼:
#includelt;stdio.hgt;
int main(int argc,const char*argv[]){
//用一個數組來存數據
int num[10],i,j,k,l,temp;
//用for來把數據一個一個讀取進來
for(i=0;ilt;=9;i++)
{
scanf(“%d”,numlt;igt;);
}
//用兩次層for循環來比較數據,進行冒泡
for(j=0;jlt;9;j++)
{
for(k=0;klt;9-j;k++)
{
if(num[k]lt;num[k+1])//num[k]lt;num[k+1]
{
temp=num[k];
num[k]=num[k+1];
num[k+1]=temp;
}
}
}
//用一個for循環來輸出數組中排序好的數據
for(l=0;llt;=9;l++)
{
printf(“%d”,num[l]);
}
return 0;
}
擴展資料:
return 0代表程序正常退出。return是C++預定義的語句,它提供了終止函數執行的一種方式。當return語句提供了一個值時,這個值就成為函數的返回值。
return語句用來結束循環,或返回一個函數的值。
1、return 0,說明程序正常退出,返回到主程序繼續往下執行。
2、return 1,說明程序異常退出,返回主調函數來處理,繼續往下執行。return 0或return 1對程序執行的順序沒有影響,只是大家習慣於使用return(0)退出子程序而已。
c語言,數組排序,返回序號
思路:在數值進行排序時,下標也同時移動。這就要求二者要聯動。為此創建一個PAIR結構體,將此二者關聯在一起。用庫里的快排函數qsort可以省略排序的麻煩,並指定qsort按PAIR中數值大小為標準排序結構體數組,這樣排序結果中的結構體數組下標和值還是保持開始時的對應關係。
#includeSTDIO.H
#includestring.h
#includestdlib.h
#define N 8
typedef struct
{
int cj;//數值
int px;//下標
}PAIR;
//qsort的輔助比較函數
int compare(const void *p, const void *q)
{
PAIR t1= *(PAIR* )p;
PAIR t2= *(PAIR* )q;
return(t1.cjt2.cj);
}
int main()
{
PAIR a[N]={};
int cj[N]={};
int px[N]={};
printf(“請輸入%d個整數:”, N);
for (int i=0;iN;i++)
{
scanf(“%d”,(a[i].cj));
a[i].px=i+1;
//數組
cj[i] = a[i].cj;
px[i] = a[i].px;
}
qsort((void *)a,N, sizeof(PAIR), compare);
printf(“\n排好序的整數為:”);
for (i=0;iN;i++)
{
printf(“%d “,a[i].cj);
cj[i]=a[i].cj;
}
printf(“\n對應原來的下標:”);
for (i=0;iN;i++)
{
printf(“%d “,a[i].px);
px[i] = a[i].px;
}
putchar(‘\n’);
return 0;
}
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/291933.html