當前位置:首頁 » 編程語言 » 排序函數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;
}

熱點內容
活動上線前伺服器配置要注意什麼 發布:2025-05-15 16:38:43 瀏覽:947
王者榮耀安卓區怎麼免費轉蘋果 發布:2025-05-15 16:18:02 瀏覽:762
威朗pro高配都有哪些配置 發布:2025-05-15 15:57:09 瀏覽:957
資料庫分頁查詢數據 發布:2025-05-15 15:45:13 瀏覽:521
phpmyadmin上傳限制 發布:2025-05-15 15:39:52 瀏覽:431
如何給手機配置真正的電腦 發布:2025-05-15 15:39:52 瀏覽:765
抽腳本命令 發布:2025-05-15 15:39:45 瀏覽:660
sok編程 發布:2025-05-15 15:33:21 瀏覽:41
lms演算法程序 發布:2025-05-15 15:31:53 瀏覽:570
資料庫二級映射 發布:2025-05-15 15:14:09 瀏覽:478