c语言,用选择法对10个数排序,按正负数分开输出?

2025-03-07 07:44:55120 次浏览

最佳答案

选择排序:大循环i依次取元素和后面所有元素比较,找出其中最值,和当前i的元素交换。一次大循环交换一次。

程序思路:

一、排序函数:根据传参,实现降序升序两种功能。

二、数组输出:根据传参,实现正数和负数输出两种功能。

下面是代码:

#include

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\n");

    printf("升序排列后:\n");

    px(nums,10,1);

    printf("|---正数为:");

    showNums(nums,10,1);

    printf("|---负数为:");

    showNums(nums,10,0);

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

    printf("降序排列后:\n");

    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

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

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

    printf("\n");

}

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

{

    int i,j,k,m;

    for(i=0;i

    {

        m=nums[i],k=i;

        for(j=i+1;j

            if((t && m>nums[j])||(!t && m

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

    }

}

声明:知趣百科所有作品均由用户自行上传分享,仅供网友学习交流。若您的权利被侵害,请在页面底部查找“联系我们”的链接,并通过该渠道与我们取得联系以便进一步处理。