首页 > 其他分享 >23暑假友谊赛No.2

23暑假友谊赛No.2

时间:2023-07-26 19:55:08浏览次数:47  
标签:cnt const cout 23 int cin long No.2 友谊赛

A-雨

#include <bits/stdc++.h>

using namespace std;

#define int long long

void solve() {
    vector<int> a(4);
    int x;
    for( auto &i : a )
        cin >> i;
    cin >> x;
    for( auto i : a)
        cout << max( x - i , 0ll ) << " ";
    return;
}

int32_t main() {
    ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
    int t = 1 ;
    while (t--)
        solve();
    return 0;
}

B-吻

化简就是\(n^2\)

#include <bits/stdc++.h>

using namespace std;

#define int long long

const int mod = 998244353;


void solve() {
    int n;
    cin >> n;
    n %= mod;
    n = n * n % mod;
    cout << n;
    return;
}

int32_t main() {
    ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
    int t = 1 ;
//    cin >> t;
    while (t--)
        solve();
    return 0;
}

C-失

把每个字符串按照与答案串不同的字符数量排序即可

#include <bits/stdc++.h>

using namespace std;

#define int long long

const int mod = 998244353;
typedef pair<int, string> pis;
int operator ^ ( const string & a , const string & b ){
    if( a.size() != b.size() ) return 0;
    int cnt = 0;
    for( int i = 0 ; i < b.size() ; i ++ )
        cnt += (a[i] == b[i]);
    return cnt;
}

void solve() {
    string s;
    int n;
    cin >> s >> n;
    vector<pis> cnt(n);
    for( auto &[k,v] : cnt )
        cin >> v , k = s ^ v;
    sort( cnt.begin(), cnt.end() , [](const pis &x , const pis &y ){
        if( x.first != y.first ) return x.first > y.first;
        return x.second < y.second;
    }) ;
    for( int i = 0 ; cnt[i].first == cnt[0].first && i < n ; i ++ )
        cout << cnt[i].second << "\n";
    return;
}

int32_t main() {
    ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
    int t = 1 ;
//    cin >> t;
    while (t--)
        solve();
    return 0;
}

D-吹

可知如果使得绝对值最大,这每个数的取值只有\(1,B_i\)两种。

然后可以跑一个dp 就好了

#include <bits/stdc++.h>

using namespace std;

#define int long long

const int mod = 998244353;

int32_t main() {
    ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
    int n;
    cin >> n;
    vector<int> a(n+1);
    for( int i = 1 ; i <= n ; i ++ ) cin >> a[i];
    vector<array<int,2>> f(n+1);
    for( int i = 2  ; i <= n ; i ++ ){
        f[i][1] = max( f[i-1][0] + abs( a[i] - 1 ) , f[i-1][1] + abs( a[i] - a[i-1] ) );
        f[i][0] = max( f[i-1][0] , f[i-1][1] + abs( a[i-1] - 1 ) );
    }
    cout << max( f[n][0] , f[n][1] );
    return 0;
}

E-唤

一个很经典的贪心,首先4,5,6都是只能单独放的,产生的缝隙可以用来放1,2

  1. 放一个 6,没有缝隙
  2. 放一个 5,还可以放11个1
  3. 放一个 4,还可以放5个2
  4. 一个盒子最多可以放 4 个3
    1. 放 4 个 3,没有缝隙
    2. 放 3 个 3,还可以放 1 个 2、5 个 1
    3. 放 2 个 3,还可以放 3 个 2、6 个 1
    4. 放 1 个 3,还可以放 5 个 2、7 个 1
  5. 一个盒子最多可以放 9 个 2,每少放 1 个 2 就可以多放 4 个 1
  6. 一个盒子最多放 36 个 1

首先尽可能的放 3,4,5,6,并统计缝隙的数量,然后在放 2,2 放的时候有限放缝隙,如果放不下在占用新的盒子,1 同理

#include <bits/stdc++.h>

using namespace std;

#define int long long

void solve() {
    int s;
    cin >> s;
    vector<int> k(7), t(7);
    for (int i = 1; i <= 6; i++) cin >> k[i];
    s -= k[6];
    if (s < 0) {
        cout << "No\n";
        return;
    }

    s -= k[5], t[1] += 11 * k[5];
    if (s < 0) {
        cout << "No\n";
        return;
    }

    s -= k[4], t[2] += 5 * k[4];
    if (s < 0) {
        cout << "No\n";
        return;
    }

    s -= k[3] / 4, k[3] %= 4;
    if (k[3] > 0) {
        s-- , k[3] = 4 - k[3];
        if (k[3] == 1) t[2] += 1, t[1] += 5;
        else if (k[3] == 2) t[2] += 3, t[1] += 6;
        else t[2] += 5, t[1] += 7;
    }
    if (s < 0) {
        cout << "No\n";
        return;
    }

    if (t[2] >= k[2]) t[2] -= k[2], k[2] = 0, t[1] += 4 * t[2];
    else k[2] -= t[2];
    s -= k[2] / 9 , k[2] %= 9;
    if( k[2] > 0){
        s -- , k[2] = 9 - k[2];
        t[1] += 4*k[2];
    }
    if (s < 0) {
        cout << "No\n";
        return;
    }
    if( t[1] >= k[1] ) k[1] = 0;
    else k[1] -= t[1];
    s -= ( k[1] + 35 ) / 36;
    if (s < 0) {
        cout << "No\n";
        return;
    }
    cout << "Yes\n";
    return;
}

int32_t main() {
    ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
    int t = 1;
    cin >> t;
    while (t--)
        solve();
    return 0;
}

F-冰

首先题目的字符串可以转化成二进制串,再进一步转换成十进制数\([0,65535]\),题目的限制就转化成相邻数\(x\&y=0\)

\(f[i][j]\)表示前\(i\)个数,且最后一个数是\(j\)的方案数,对于数字\(a_i\)有三种情况

  1. 不选\(a_i\),则\(f[i][j] =f[i-1][j]\)
  2. 只选\(a_i\),则\(f[i][a_i]=1\)
  3. 选\(a_i\)也选前面的数,则\(f[i][a_i]=\sum f[i][j],j\in\{0\le j\le 65535\and a_i\&j=0\}\)

这样我们可以用滚动数组优化掉一层,在枚举前一个数选什么即可

#include <bits/stdc++.h>

using namespace std;

#define int long long

const int mod = 998244353;

int32_t main() {
    ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
    int n , m;
    cin >> n >> m;
    vector<int> s(n);
    for( int i = 0 ; i < n ; i ++ ){
        string str;
        cin >> str;
        for( int j = 0 ; j < m ; j ++ )
            if( str[j] == 'o' ) s[i] = (s[i] << 1) | 1;
            else s[i] = s[i] << 1;
    }

    m = ( 1 << m ) - 1 ;
    vector<int> f( m+1 );

    for( auto i : s ){
        for( int j = 0 ; j <= m ; j ++ )
            if( (j & i) == 0 ) (f[i] += f[j]) %= mod;
        f[i] = (f[i]+1) % mod;

    }
    int sum = 0;
    for( int i = 0 ; i <= m ; i ++ )
        sum = (sum + f[i]) % mod;
    cout << sum << "\n";

    return 0;
}

上述的代码复杂度\(O(n2^m)\),无法通过。

注意到题目保证了\(n2^\frac{m}{2}<5.12\times10^7\)

则考虑是否可以用\(\sqrt{2^m}\)的枚举

首先我们把16位二进制数拆分成两半,高 8 位和低 8 位,\(f[i][x][y]\)前\(i\)个且最后一个数高位是\(x\),低位是与\(y\)相与为0 的数的方案数

那么此时对于一个数高位是\(x\),低位是\(y\),贡献就是\(ans=1+\sum f[i-1][x’][y],x’\in\{0\le x’\le255\and x’\&x=0\}\)

这样还要考虑更新\(f[i][x][y’] += ans ,y’\in\{0\le y’\le255\and y’\&y=0\}\)

这样枚举其实就是把二进制数分段分段枚举了,能这么做的理由是\(\&\)操作本身不牵扯到位与为之间的操作只受到相同位的影响。

#include <bits/stdc++.h>

using namespace std;

#define int long long

const int mod = 998244353;
const int M = 256;

int32_t main() {
    ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
    int n, m, res = 0;
    cin >> n >> m;
    string s;
    vector f(M, vector<int>(M, 0));
    for (int x, y, ans; n; n--) {
        cin >> s, x = 0 , ans = 1;
        for (auto i: s)
            if (i == 'o') x = (x << 1) | 1;
            else x = x << 1;
        y = x % M, x /= M;
        for (int i = 0; i < M; i++)
            if ((x & i) == 0) ans = (ans + f[i][y]) % mod;
        res = (res + ans) % mod;
        for (int i = 0; i < M; i++)
            if ((i & y) == 0) f[x][i] = (f[x][i] + ans) % mod;
    }
    cout << res << "\n";
    return 0;
}

标签:cnt,const,cout,23,int,cin,long,No.2,友谊赛
From: https://www.cnblogs.com/PHarr/p/17583418.html

相关文章

  • 23暑假友谊赛No.2
    23暑假友谊赛No.2雨#include<bits/stdc++.h>usingnamespacestd;#defineintlonglong//#defineint__int128typedefpair<int,int>PII;typedefpair<string,int>PSI;typedefpair<string,string>PSS;constintN=50+5,INF=0x3f3f3f3f,Mod=1......
  • 2023年7月26日 天气:晴
        今天早上起来背了10个英语单词,然后学习了一个小时的java,写了一会英语阅读,然后和朋友出去打了两个小时的羽毛球,最后写了一会作业。    明天打算看一小时的电视剧,然后和朋友出去玩一会,打一两个小时的篮球,最后晚上练一小时的字,然后学习一小时的java。......
  • NOI 2023 录
    是不是没进集训队不配写回忆录啊,那就摆了吧。Day1我还是难以理解,我是怎样打出100+15+0的好成绩的。也许是因为T1复杂做法调了2.5h才过;也许是因为T2不会找规律也不会正经的dp转移顺序50分m^3暴力还写挂;也许是因为T3从头读错题面到最后也没写出一个正确的低分暴......
  • 行业追踪,2023-07-26,如果主力不骗人,化工原料和磷化工有第一波机会
    自动复盘2023-07-26凡所有相,皆是虚妄。若见诸相非相,即见如来。k线图是最好的老师,每天持续发布板块的rps排名,追踪板块,板块来开仓,板块去清仓,丢弃自以为是的想法,板块去留让市场来告诉你跟踪板块总结:成交额超过100亿排名靠前,macd柱由绿转红成交量要大于均线有必要给每个行......
  • NOI2023 游记
    把前面的复习实况删了,因为实在太摆了!前面在cdqz训了两场模拟赛,垫了两场底!!熟悉了下cdqz键盘,能打。Day0报道日。由于是第一个进去了,被拉着生产了很多照片/采访,开幕式好像重复利用了很多遍这些素材。领到了很多徽章,拉着学弟主动social了很多老哥!!虽然最后还是没有juju......
  • 暑假集训D3 2023.7.26 补题
    G.P6183[USACO10MAR]TheRockGameS题意:给定长度n,构造\(2^n\)个由X和O组成的字符串,使得第一个字符串和最后一个字符串只由O组成,并且相邻的字符串只有一处不同,不得有重复的字符串.BFS貌似做不了.看题解有佬用格雷码的知识.代码如下#include<stdio.h>#include<st......
  • 设计师2023常用的协同设计工具推荐
    组织结构越来越复杂,团队中的每个人都有独特的技能、经验和专业知识。我们怎样才能让团队更好地合作?在这种情况下,协同设计应运而生。UI的未来是协同设计!如果你想把握未来的设计趋势,不妨从使用高效的协同设计软件开始!本文帮助您盘点10款适合UI/UX设计师的协同设计软件1.即时设......
  • 20230726
    复赛完全背包定义:有n种物品和一个容量为v的背包,第i种物品体积为c[i],价值为w[i],每种物品有无穷件,问如何选取物品放入背包,可使价值总和最大。与01背包的区别:01背包一个物品只能选一件,而完全背包一个物品可以选多件例题时间:1s空间:128M题目描述:一个旅行者有一个最......
  • 2023-7-26 Dynamic替代部分反射的简单实现方式
    Dynamic与反射的使用【作者】长生实体类publicclassSchool{ publicintGetAge(){ return100;}}使用反射获取对象里的方法 Schoolschool=newSchool(); varmethod=typeof(School).GetMethod("GetAge"); intage=(int)method.Invoke(school,null); Console.W......
  • Day16(2023.07.26)
    行程9:00 到达上海市徐汇区宛平南路1099号城建大厦9:45  与客户进行漏扫方面交流11:30--13:00   吃饭休息13:30         管理方面交流16:30         下班......