Codeforces Round 889 (Div. 2)A~C1题解

A. Dalton the Teacher 

题目分析:

模拟,写出两个就能找出规律:坐在自己位子上的小孩会不高兴,所以统计下来cnt

发现cnt为奇数是(cnt+1)/2次就能换成要求,偶数就是cnt/2

#include<bits/stdc++.h>
#pragma GCC optimize(3)
#define INF 0x3f3f3f3f
#define endl "\n"
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
typedef long long ll;
using namespace std;
const int N =2e5+7;
int main(){IOS
    int t;cin>>t;
    while(t--)
    {
        ll cnt=0;
        int n;cin>>n;
        int x;
        for(int i=1;i<=n;i++)
        {cin>>x;
        if(x==i)cnt++;
            
        }
        if(cnt%2)
        {
            cout<<(cnt+1)/2<<endl;
            
        }else cout<<cnt/2<<endl;
    }
    
    
    
return 0;
}

B. Longest Divisors Interval

题目分析:给你一个1e18大小的数n,让你 找出最长的连续数列满足这个数列每个都是n的除数

1e18为long long 类型,假设l=1,r=26,long long 就会爆掉,所以,连续序列的长度最多不超过25,同理,越往后面,数字越大,也即只需要在1~25范围内找连续数列就行

#include<bits/stdc++.h>
#pragma GCC optimize(3)
#define INF 0x3f3f3f3f
#define endl "\n"
#define IOS ios::sync_with_stdio(false);cin.tie(0);
typedef long long ll;
using namespace std;
const int N =2e5+7;
int a[N];
struct ss {
    int a,b;
}stu[N];
int main(){IOS
    int t;cin>>t;
    while(t--)
    {
        ll n;cin>>n;
        ll ans=0;
        for(int i=1;i<=25;i++){
            ll tmp=0;
            while(n%i==0){
                i++;
                tmp++;
            }
            ans=max(ans,tmp);
        }cout<<ans<<endl;
    }
    
    
    
return 0;
}

C1. Dual (Easy Version) 

题目分析:每次将 aj 加到 ai上,最终在不超过50次的操作下,使得整个序列变为不递减序列

特殊情况:全正 or 全负 两种情况处理起来差不多,后加前 or 前加后  最多 19次操作

其余情况不好处理,考虑往特殊情况上转,也即找到最大的数和最小的数相加,若小于零,则将最小的数加上全序列变为全负,否则变为全正,最多19次操作

#include<bits/stdc++.h>
#pragma GCC optimize(3)
#define INF 0x3f3f3f3f
#define endl "\n"
#define IOS ios::sync_with_stdio(false);cin.tie(0);
typedef long long ll;
using namespace std;
typedef pair<int ,int >pii;
const int N =2e5+7;
int a[N];
struct ss {
    int a,b;
}stu[N];
vector<pii>ans;
int main(){IOS
    int t;cin>>t;
    while(t--)
    {
        int n;cin>>n;
        cin>>a[1];
        int mas=a[1];
        int mins=a[1];
        int masidx=1;
        int minsidx=1;
        for(int i=2;i<=n;i++)
        {
            cin>>a[i];
            if(a[i]>mas){
                mas=a[i];
                masidx=i;
            }
            if(a[i]<mins){
                mins=a[i];
                minsidx=i;
            }
           
        }
        if(mins+mas<0)
        {
            for(int i=1;i<=n;i++)
            {
                if(i!=minsidx){
                  ans.push_back({i,minsidx});
                }
            }
            
            for(int i=n-1;i>=1;i--){
                ans.push_back({i,i+1});
            }
        }else {
            for(int i=1;i<=n;i++)
            {
                if(i!=masidx){
                  ans.push_back({i,masidx});
                }
            }
            for(int i=2;i<=n;i++)
            {
                ans.push_back({i,i-1});
            }
            
        }
        cout<<n*2-2<<endl;
       for(auto x:ans)
       {
           cout<<x.first<<" "<<x.second<<endl;
           ans.pop_back();
       }
        
    }

return 0;
}

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,根据提供的引用内容,我无法理解你具体想要问什么问题。请提供更清晰明确的问题,我将竭诚为你解答。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Codeforces Round 860 (Div. 2)题解](https://blog.csdn.net/qq_60653991/article/details/129802687)[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: 33.333333333333336%"] - *2* [【CodeforcesCodeforces Round 865 (Div. 2) (补赛)](https://blog.csdn.net/t_mod/article/details/130104033)[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: 33.333333333333336%"] - *3* [Codeforces Round 872 (Div. 2)(前三道](https://blog.csdn.net/qq_68286180/article/details/130570952)[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: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值