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

给定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 想问一下树莓派接上显示屏后出现如图所示画面,是什么问题导致的
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号