华不注 2022-01-22 20:31 采纳率: 91.7%
浏览 49
已结题

给定10个整数序列,按规则排序

题目:给定10个整数序列,按规则排序
规则如下:1.奇数在前,偶数在后
2.奇数从大到小排序
3.偶数从小到大排序
输入:4 7 3 13 11 12 0 47 34 98
输出:47 13 11 7 3 0 4 12 34 98

img

(一本通上的题,做的时候出了点问题,求解)
多谢!

  • 写回答

2条回答 默认 最新

  • 爱音斯坦牛 全栈领域优质创作者 2022-01-22 22:16
    关注
    
    #include<stdio.h>
    #include<math.h>
    int main()
    {
    int a[10],b[10],c[10];//定义三个数组
        int i,j=0,k=0,n,m,p;
        for(i=0;i<10;i++){        //进入循环并进行判断    
            scanf("%d",&a[i]);
            if(a[i]%2!=0){    //判断出奇数并将其放在另一个数组中
                b[j]=a[i];
                j++;
            }else if(a[i]%2==0){   //判断出偶数并将其放在另一个数组中
                c[k]=a[i];
                k++;
            }
        }
        
        for(i=0;i<=k;i++){      
            for(p=1;p<k;p++){
                if(c[p]<c[p-1]){  //判断大小并进行排序
                    m=c[p];
                    c[p]=c[p-1];
                    c[p-1]=m;
                }
            }
        }            
    for(i=0;i<=j;i++){       
            for(p=1;p<j;p++){
                if(b[p]>b[p-1]){  //判断大小并进行排序
                    n=b[p];
                    b[p]=b[p-1];
                    b[p-1]=n;
                }
            }
        }    
     
        for(i=0;i<j;i++){        
            printf("%d ",b[i]);  //输出排列好的奇数数组
        }
        for(i=0;i<k;i++){          
            printf("%d ",c[i]);  //输出排列好的偶数数组
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月1日
  • 已采纳回答 1月24日
  • 创建了问题 1月22日

悬赏问题

  • ¥15 怎样才能让鼠标沿着线条的中心线轨迹移动
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?
  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)
  • ¥65 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?