首页 > 其他分享 >Codeforces Round 697 (Div. 3)

Codeforces Round 697 (Div. 3)

时间:2023-11-22 21:57:05浏览次数:50  
标签:typedef const 697 int double Codeforces long Div define

A. Odd Divisor

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=1e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;

void solve() {
    int n;cin>>n;
    while(n%2==0)n/=2;
    if(n==1)cout<<"NO\n";
    else cout<<"YES\n";
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int T=1;
    cin>>T;
//    init();
    while(T--){
        solve();
    }
    return 0;
}

B. New Year's Number

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=1e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;

void solve() {
    int n;cin>>n;
    int cnt=n/2020;
    n%=2020;
    if(n>cnt)cout<<"NO\n";
    else cout<<"YES\n";
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int T=1;
    cin>>T;
//    init();
    while(T--){
        solve();
    }
    return 0;
}

C. Ball in Berland

简单的的容斥一下,先统计每个点连接的边的数量,然后枚举每一条边,容斥掉所有与他相邻的边即可。

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=1e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;

void solve() {
    int a,b,k;cin>>a>>b>>k;
    vector<int>cnt(a+b+5,0);
    vector<PII>ve(k);
    for(int i=0,x;i<k;++i){
        cin>>x;
        ve[i].first=x;
        cnt[x]++;
    }
    for(int i=0,x;i<k;++i){
        cin>>x;
        ve[i].second=x+a;
        cnt[x+a]++;
    }
    int ans=0;
    for(int i=0;i<k;++i){
        ans+=k-cnt[ve[i].first]-cnt[ve[i].second]+1;
    }
    cout<<ans/2<<'\n';
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int T=1;
    cin>>T;
//    init();
    while(T--){
        solve();
    }
    return 0;
}

D. Cleaning the Phone

这道题因为\(b\)的取值只有两种,首先把所有的手机按照\(b\)分类,对于每一种我们其实都可以谈心的选择\(a\)更大的,所有直接排序,然后求前缀和,这样枚举其中\(b=1\)的选多少个,可以直接二分出\(b=2\)的应该选多少个,这样就可以计算出最优解。

#include<bits/stdc++.h>

using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int, int> PII;
typedef pair<string, int> PSI;
typedef pair<string, string> PSS;
const int N = 1e5 + 5, INF = 0x3f3f3f3f, Mod = 1e9 + 7, mod = 998244353;
const double eps = 1e-6;

void solve() {
    int n, m;
    cin >> n >> m;
    vector<int> a(n);
    for (int i = 0; i < n; ++i)cin >> a[i];
    vector<int> f2, f1;
    for (int i = 0, x; i < n; ++i) {
        cin >> x;
        if (x == 1)f1.push_back(a[i]);
        else f2.push_back(a[i]);
    }

    if (accumulate(a.begin(), a.end(), 0ll) < m) {
        cout << "-1\n";
        return;
    }
    int ans = 1e9;
    sort(f1.begin(), f1.end(), greater<int>());
    sort(f2.begin(), f2.end(), greater<int>());
    for (int i = 1; i < f1.size(); ++i)f1[i] += f1[i - 1];
    for (int i = 1; i < f2.size(); ++i)f2[i] += f2[i - 1];
    for (int i = 0; i < f1.size(); ++i) {
        int c = m - f1[i];
        if (c <= 0) {
            ans = min(ans, i + 1);
            break;
        }
        if (f2.empty() or f2.back() < c) continue;
        int t = lower_bound(f2.begin(), f2.end(), c) - f2.begin();
        ans = min(ans, i + 2 * t + 3);
    }
    if (!f2.empty() and f2.back() >= m) {
        int t = lower_bound(f2.begin(), f2.end(), m) - f2.begin();
        ans = min(ans, t * 2 + 2);
    }
    cout << ans << '\n';
}

signed main() {
    ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    int T = 1;
    cin >> T;
//    init();
    while (T--) {
        solve();
    }
    return 0;
}

E. Advertising Agency

先不考虑方案数,我们其实可以贪心的直接选粉丝最多的。

然后对于多个粉丝一样多的有三种情况

  1. 全部都选
  2. 全部都不选
  3. 选一部分

可以发现,多种方案数发生的情况只有 3 一种,且最多只会有一种粉丝数量的博主。所以贪心找到然后组合数算一下就好了。

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=1e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;
int pow(int x,int y){
    int res=1;
    while(y){
        if(y&1)res=res*x%Mod;
        x=x*x%Mod;
        y>>=1;
    }
    return res;
}
int inv(int x){return pow(x,Mod-2);}
int C(int x,int y){
    y=min(y,x-y);
    int res=1;
    for(int i=x,j=1;j<=y;--i,++j)res=res*i%Mod*inv(j)%Mod;
    return res;
}
void solve() {
    int n,k;cin>>n>>k;
    map<int,int>mp;
    for(int i=0,x;i<n;++i){
        cin>>x;
        mp[-x]++;
    }
    for(auto [x,y]:mp){

        if(y<k)k-=y;
        else{
            cout<<C(y,k)<<'\n';
            return ;
        }
    }
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int T=1;
    cin>>T;
//    init();
    while(T--){
        solve();
    }
    return 0;
}

F. Unusual Matrix

首先把其实状态和最终状态做异或,然后把新得到的矩阵变成全 0 即可

首先可以通过翻转列的形式暴力把第一行翻转为全 0 的,然后只需判断剩下的行是否是全 0 或全 1就好

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int NN=1e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;

void solve() {
    int n;cin>>n;
    vector<string>ve(n);
    for(int i=0;i<n;++i)cin>>ve[i];
    string s;
    for(int i=0;i<n;++i){
        cin>>s;
        for(int j=0;j<n;++j)ve[i][j]='0'+(int)(s[j]!=ve[i][j]);
    }
    for(int i=0;i<n;++i){
        if(ve[0][i]!='1'){
            for(int j=0;j<n;++j){
                if(ve[j][i]=='0')ve[j][i]='1';
                else ve[j][i]='0';
            }
        }
    }
    bool ok=true;
    for(int i=1;i<n;++i){
        for(int j=1;j<n;++j){
            if(ve[i][j]!=ve[i][j-1]){
                ok=false;break;
            }
        }
        if(!ok)break;
    }
    if(ok)cout<<"YES\n";
    else cout<<"NO\n";
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int T=1;
    cin>>T;
//    init();
    while(T--){
        solve();
    }
    return 0;
}

G. Strange Beauty

\(f[x]\)是选择一个满足条件的集合,且最大的数是\(x\)最多可以放多少个数,那么集合中的数字一定都是\(x\)的因子,如果在继续加数字,只要满足是\(x\)的倍数就是集合中所有数字的倍数。

显然对于每个数字如果选择肯定是全部都选最优,所以可以统计\(cnt[x]\)表示\(x\)出现的次数

那么转移方程就是\(f[x]= cnt[x] + max( f[y])\)其中\(y\)是\(x\)的因子,这样的话全局\(max(f[x])\)就是能够选择最多的数字,在这种情况下\(n-max(f[x])\)就是删除的最少的数字

但是现在这种转移方程我们需要枚举因子因此复杂度是\(O(n\sqrt n)\),无法通过

其实优化方式非常简单,只要变成枚举倍数复杂度是就变成了\(O(n\ln n)\),再随便加一点优化就好了。

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=2e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;

void solve() {
    int n;cin>>n;
    vector<int>cnt(N),f(N);
    for(int i=0,x;i<n;++i)cin>>x,cnt[x]++;
    for( int i = 1 ; i < N ; i ++ ){
        f[i] += cnt[i];
        for( int j = i + i ; j < N ; j += i ) f[j] = max( f[j] , f[i] );
    }
    cout << n - *max_element(f.begin(), f.end()) << "\n";
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int T=1;
    cin>>T;
//    init();
    while(T--){
        solve();
    }
    return 0;
}

标签:typedef,const,697,int,double,Codeforces,long,Div,define
From: https://www.cnblogs.com/PHarr/p/17850393.html

相关文章

  • [Codeforces] CF1475C Ball in Berland 题解
    BallinBerland-洛谷题意在毕业典礼上,有​个男孩和​个女孩准备跳舞,不是所有的男孩和女孩都准备结伴跳舞。现在你知道​个可能的舞伴,你需要选择其中的两对,以便使没有人重复地出现在舞伴里,求可能的数量。思路暴力最朴素,也是简单的方法,就是通过暴力组合进行配对。#include......
  • 切换div块内容以及切换点击事件
    今天想不用写好几个div块然后切换点击事件一直修改div中的内容于是写除了这个切换功能,以此记录遇到的问题也为大家解决一个难题。现在是这样的然后写jsfunctionChangeSale(){$("#img_one").attr("src","此处写图片地址");$('.hkeep_name').html("人名");......
  • Codeforces Round 905 (Div. 2)
    \(A.Chemistry\)https://codeforces.com/contest/1888/submission/233505834\(B.Raspberries\)https://codeforces.com/contest/1888/submission/233506474\(C.YouAreSoBeautiful\)题意:给定一个长\(n\)的序列\(a\)。对于区间\([l,r]\),如果\(a\)没有其它子序列(......
  • Codeforces Round 910 E
    tilian我们发现可以通过交换相邻两个的方式让字典序小的任意移动我们目标串t要是t[0]为c我们肯定是找到第一个合法的c的位置每次去找合法并且最优的那么哪些是不合法的呢比如我比c小的a,b位置还在第一个c前肯定就不能用了我们用26个set维护这个过程即可voidsolve()......
  • Codeforces Round 909 (Div. 3)
    CodeforcesRound909(Div.3)A.GamewithIntegers题意:给定一个数\(x\),\(A,B\)两人轮流进行操作,\(A\)先操作。每次给\(x\)加一或者减一,操作完后\(x\%3==0\)者获胜。判断获胜者。解题思路:判断\(A\)操作完是否能获胜,如果不能,那么一定是\(B\)获胜。代码:#include<bit......
  • codeforces 50题精选训练
    本章节参考:2020,2021年CF简单题精选-题单-洛谷|计算机科学教育新生态(luogu.com.cn) T1:首先,很容易观察到点的一些特征:-都在第一象限;-点的分布越来越稀疏。以样例为例:   还有无限个点没有画出来。根据点的分布越来越稀疏的特性,能不能发现收集点的规......
  • Codeforces Round 905 (Div. 3) ABCDEG1
    CodeforcesRound905(Div.3)ABCDEG1A.Morning思路:签到,直接模拟。//AConemoretimes//nndbk#include<bits/stdc++.h>usingnamespacestd;typedeflonglongll;constintmod=1e9+7;constintN=2e5+10;intmain(){ios::sync_with_stdio(fal......
  • Educational Codeforces Round 99 (Rated for Div. 2)
    https://codeforces.com/contest/1455很久没有vp了,感觉思维又僵化了A题直接看样例,直接猜是长度。B题首先如果是\(x=\frac{n(n+1)}{2}\),那么就是n否则如果\(x=\frac{n(n+1)}{2}+y\),分成两类y=n,ans=n+2,y<n,我们总可以找到前面一个替换,然后恰好的到n,选取z=n-y即可C题感觉比B......
  • Educational Codeforces Round 156 (Rated for Div. 2) ABCD
    EducationalCodeforcesRound156(RatedforDiv.2)ABCDA.SumofThree题意:给定正整数\(n\),判断是否存在正整数\(a\),\(b\),\(c\)满足:\(a+b+c=n\)。\(a\),\(b\),\(c\)均不是\(3\)的倍数。如存在,输出YES并构造一组方案,否则输出NO。思路:法一:我们分类讨论。根据......
  • Codeforces Round 904 (Div. 2)
    \(A.SimpleDesign\)https://codeforces.com/contest/1884/submission/233628914\(B.HauntedHouse\)https://codeforces.com/contest/1884/submission/233629446\(C.MediumDesign\)https://codeforces.com/contest/1884/submission/233632930\(D.Counting......