ccf真题|201612-1c++代码思路记录

题目

题目如上,需要认真读题,注意:题目要求输出的是中间数,不是我们熟知的中位数。中间数,简单来说就是:在已知的整数序列中,比它大的数的数量=比它小的数的数量。

样例

了解完题目之后,还需要注意下已给的样例,它们一般会提醒你有哪些不同情况。比如:

样例1:n为偶数时的特殊情况,顺序排列后,当中间两个数相等,中间数即为这个数。

样例2:n为偶数时的一般情况,如果数都不相等,则没有中间数,输出-1.

样例3:n为奇数时的特殊情况,顺序排列后,如果中间的数与前或后某数相等,则没有中间数,输出-1.


思路

思路一:

  1. 首先把给出的整数序列从小到大顺序排列

  1. 分为n为偶数和n为奇数两大类,再把其中没有中间数的特殊情况分类出来。

初步写出代码如下:

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n;
    cin>>n;
    int a[n];
    for(int i=1;i<=n;i++){//为了后边的temp更方便表示,这里i要从1开始 
        cin>>a[i];
    }
    sort(a,a+n+1);//将整数序列从小到大顺序排列 
    
    if(n%2==1){
        int temp=(n+1)/2;
        if(a[temp]!=a[temp+1]&&a[temp]!=a[temp-1]){
        cout<<a[temp];    
        }
        else{
            cout<<"-1";
        }
        
    }
    if(n%2==0){
        int temp=n/2;
        if(a[temp]==a[temp+1]){
            cout<<a[temp];
        }
        else{
            cout<<"-1";
        }
    } 
} 

但是很遗憾(qi)只有80😭

猜测肯定是哪种情况没有考虑到,就多加了一种n为奇数时,中间三个数都相等时也有中间数的情况,反而变成了50分,心累。换方法!

思路二:

这是从别的博主那学来的方法。真的是学到了!!这个方法比我的更清晰有效,不需要分奇数偶数两类情况分析。

  1. 首先从小到大顺序排列

  1. 找到中间的数

  1. 从中间的数开始往左找有几个比它小的,往右找比它大的,分别记录数值

  1. 最后比较数值

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n;
    cin>>n;
    int a[n];
    for(int i=0;i<n;i++){
        cin>>a[i];
    }
    sort(a,a+n);//将整数序列从小到大顺序排列 
    
   int mid=n/2;
   int leftnum=0,rightnum=0;
   if(n==1){
       cout<<a[0];
       return 0;
   }
   for(int i=mid-1;i>=0;i--){
       if(a[i]!=a[mid]) leftnum++;
   }
   for(int i=mid+1;i<n;i++){
       if(a[i]!=a[mid]) rightnum++;
   }
   if(leftnum==rightnum){
       cout<<a[mid];
   }
   else{
       cout<<"-1";
   }
} 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
引用是一段C++代码,用来解析CCF201612-2工资计算问题。这段代码通过计算各种收入范围和税率,然后根据输入的税前工资来计算出税后工资。具体步骤如下: 1. 首先定义了salaryrange数组存储各个收入范围,taxrate数组存储各个税率,以及range数组用来计算各种收入范围。 2. 通过循环计算range数组的值,range[i表示税前工资在salaryrange[i范围内的税后工资。 3. 输入税前工资t后,通过循环找到税前工资所在的收入范围i。 4. 如果i=0,表示税前工资在最低收入范围内,税后工资直接等于税前工资。 5. 如果i不等于0,表示税前工资在其他收入范围内,通过公式s = salaryrange[i-1 + (t - range[i-1]) * 100 / (100 - taxrate[i-1])计算税后工资。 6. 最后输出税后工资s。 根据这段代码的解析,可以计算出CCF201612-2工资计算问题的答案。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [CCF201612-2 工资计算(100分)](https://blog.csdn.net/tigerisland45/article/details/54799557)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [CCF201612-2 工资计算](https://blog.csdn.net/qq_40670344/article/details/97441803)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值