當前位置:首頁 » 編程語言 » 排序函數c語言

排序函數c語言

發布時間: 2025-05-15 13:06:28

c語言,用選擇法對10個數排序,按正負數分開輸出

選擇排序:大循環i依次取元素和後面所有元素比較,找出其中最值,和當前i的元素交換。一次大循環交換一次。

程序思路:

一、排序函數:根據傳參,實現降序升序兩種功能。

二、數組輸出:根據傳參,實現正數和負數輸出兩種功能。

下面是代碼:


#include <stdio.h>

void px(int nums[],int len,int t);//排序

void showNums(int nums[],int len,int t);//輸出

int main()

{

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

printf("原數組:8,7,-1,2,-5,4,9,-3,-6,1 ");

printf("升序排列後: ");

px(nums,10,1);

printf("|---正數為:");

showNums(nums,10,1);

printf("|---負數為:");

showNums(nums,10,0);

//--------------------------------

printf("降序排列後: ");

px(nums,10,0);

printf("|---正數為:");

showNums(nums,10,1);

printf("|---負數為:");

showNums(nums,10,0);


}

void showNums(int nums[],int len,int t)//t=1輸出正數,t=0輸出負數

{

int i;

for(i=0;i<len;i++)

if((t && nums[i]>0)||(!t && nums[i]<0))

printf("%d ",nums[i]);

printf(" ");

}

void px(int nums[],int len,int t)//t=1升序,t=0降序

{

int i,j,k,m;

for(i=0;i<len-1;i++)

{

m=nums[i],k=i;

for(j=i+1;j<len;j++)

if((t && m>nums[j])||(!t && m<nums[j])) m=nums[j],k=j;

m=nums[i],nums[i]=nums[k],nums[k]=m;

}

}

⑵ 如何用函數實現三個數的排序(用的是C語言)

一:全局變數

#include<stdio.h>

inta,b,c;//定義三個全局變數

voidsort()//不需要參數
{
intt;
if(a>b)
{
t=a;a=b;b=t;
}
if(b>c)
{
t=b;b=c;c=t;
}
if(a>b)
{
t=a;a=b;b=t;
}
}

intmain()
{
printf("輸入:");
scanf("%d%d%d",&a,&b,&c);
sort();
printf("排序:%d<%d<%d ",a,b,c);
return0;
}

熱點內容
oracle測試sql 發布:2025-07-08 03:16:54 瀏覽:972
php壁紙源碼 發布:2025-07-08 03:04:26 瀏覽:320
android應用層 發布:2025-07-08 02:42:32 瀏覽:301
大唐存儲銷量 發布:2025-07-08 02:41:11 瀏覽:582
腳本怎麼打開 發布:2025-07-08 02:41:06 瀏覽:822
貴州電信iPtv升級伺服器地址 發布:2025-07-08 02:38:48 瀏覽:412
電腦怎麼鏈接本地伺服器 發布:2025-07-08 02:34:22 瀏覽:147
android調試webview 發布:2025-07-08 02:26:28 瀏覽:358
壓縮袋鞋子 發布:2025-07-08 02:21:30 瀏覽:752
為什麼安卓打吃雞感覺有延遲 發布:2025-07-08 02:09:32 瀏覽:168