The 3rd Universal CupStage 15: Chengdu, November 2-3, 2024(2024ICPC 成都)

news2024/11/16 17:58:23

Problem L. Recover Statistics

题目意思:

给定a, b, c三个值,确保构造的数列中包含满足题目的数量

解题思路:

100 中 选择a 50个, b45个, c4个。

#include <iostream>

using namespace std;

using ll = long long;

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);
    int a, b, c;
    cin >> a >> b >> c;
    cout << 100 << endl;
    for(int i = 0; i < 50; i ++)
        cout << a << " ";
    for(int i = 0; i < 45; i ++)
        cout << b << " ";
    for(int i = 0; i < 4; i ++)
        cout << c << " "; 
    cout << c + 1;
    return 0;
}

Problem A. Arrow a Row

题目意思:

n次操作,构造出给定字符串,每次操作可以覆盖之前的操作。

解题思路:

每次把一个字符变为满足题意的字符,n次之内操作就可以完成构造

#include <iostream>
#include <string>
#include <vector>

using namespace std;

void solve(){
    string s;
    cin >> s;
    int len = s.size();
    if(len < 5 || s[0] == '-'){
        cout << "No\n";
        return ;
    }
    for(int i = len - 1; i >= len - 3; i --){
        if(s[i] == '-'){
            cout << "No\n";
            return ;
        }
    }
    int f = 0;
    for(int i = 0; i < len; i ++)
    {
        if(s[i] == '-')
            f = 1;
    }
    if(f == 0){
        cout << "No\n";
        return ;
    }
    vector<pair<int, int>> res;
    int end = len - 1;
    for(int i = len - 3; i >= 0; i --){
        if(s[i] == '>'){
            res.push_back({1, end + 1});
            end --;
        }else
            break;
    }
    end ++;
    for(int i = 1; i < end - 3; i ++){
        if(s[i] == '>')
            res.push_back({i + 1, end - i + 1});
    }
    if(res.size() <= len){
        cout << "Yes ";
        cout << res.size() << endl;
        for(auto [x, y] : res)
            cout << x << " " << y << endl;
    }else
        cout << "No\n"; 
}

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);
    int n;
    cin >> n;
    while(n --){
        solve();
    }
    return 0;
}

Problem G. Expanding Array

题目意思:

每次在相邻的两个数之间做运算,再将新构成的数插入到两数之间,再次做一样的运算,可做无限次运算,问最多能构成多少个不同的数。

解题思路:

利用等式 a ^ b = c => b = a ^ c, 通过这条性质可以无线构造出相邻的. 

a & ( a ^ b ) ^ a = a & a ^ (a & b ) ^ a  = a & b

0 ^ x = x

#include<iostream>
#include<vector>
#include<set>

using namespace std;

using ll = long long;

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);

    int n;
    cin >> n;
    vector<int> a(n);
    set<int> cnt;
    for(auto &x : a)    cin >> x;

    for(int i = 0; i < n - 1; i ++){
        cnt.insert(a[i]);
        int t1 = a[i] | a[i + 1];
        int t2 = a[i] & a[i + 1];
        int t3 = a[i] ^ a[i + 1];
        int t4 = t1 ^ a[i];
        int t5 = t1 ^ a[i + 1];
        cnt.insert(t1); 
        cnt.insert(t2);
        cnt.insert(t3);
        cnt.insert(t4);
        cnt.insert(t5);
    }
    cnt.insert(0);
    cnt.insert(a[n - 1]);
    cout << cnt.size() << endl;
    return 0;
}

Problem B. Athlete Welcome Ceremony

题目意思:

        给定一个字符串和a, b, c的数量,问能构成多少种不同的长度为x的序列。

解题思路:

        计数dp.

        由于题目范围很小,我们很显然可以枚举所有满足cnt个问号,abc的数量,根据题目限制,相邻的两个字符不能相同。状态定义为dp[x][y][z][p],1 - i 中以p结尾的字符,并且保证当前的和上一层的不重复。我们可以用滚动数组来实现。

        对于每次询问,我们直接找出f[x][y][z]即可。

#include <bits/stdc++.h>
using namespace std;
#define int long long
const int N = 2e5 + 10, INF = 0x3f3f3f3f;
const int mod = 1e9 + 7;
#define pb push_back
#define  vi vector<int>
#define  vii vector<pair<int, int>>
#define ff first 
#define ss second 
// ++   ~!    */+-    <<>>    <>  ==   &^|   &&|| =
 
int dp[310][310][310][3]; // ijkz  对前i个字符,使用了j个a字符,k个b字符,第i个字符是 z + 'a'的方案数
int f[310][310][310]; // 有i个a,j个b,k个c的方案数
 
void solve()
{
    int n, m;
    cin >> n >> m;
    string s;cin >> s;
    s = ' ' + s;
    vector<int> cnt(n + 1);
    for (int i = 1; i <= n; i++)cnt[i] = cnt[i - 1] + (s[i] == '?');
 
    // 先初始化一下方案数
    if (s[1] == '?')
        dp[1][1][0][0] = dp[1][0][1][1] = dp[1][0][0][2] = 1;
    else
        dp[1][0][0][s[1] - 'a'] = 1;
    
 
    for (int i = 2; i <= n; i++)
    {
        for (int ca = 0; ca <= cnt[i]; ca++)
        {
            for (int cb = 0; cb + ca <= cnt[i]; cb++)
            {
                
                if (s[i] != '?')
                {
                    int num = dp[i - 1][ca][cb][0] + dp[i - 1][ca][cb][1] + dp[i - 1][ca][cb][2]; //上一层总方案数
                    dp[i][ca][cb][s[i] - 'a'] = (num - dp[i - 1][ca][cb][s[i] - 'a']) % mod; // 去掉上一层一样的,其他结尾字母为0
                    continue;
                }
                if (ca)
                {
                    int num = dp[i - 1][ca - 1][cb][1] + dp[i - 1][ca - 1][cb][2]; 
                    dp[i][ca][cb][0] = num % mod;
                }
                if (cb)
                {
                    int num = dp[i - 1][ca][cb - 1][0] + dp[i - 1][ca][cb - 1][2];
                    dp[i][ca][cb][1] = num % mod;
                }
                if (cnt[i] - ca - cb)
                {
                    int num = dp[i - 1][ca][cb][0] + dp[i - 1][ca][cb][1];
                    dp[i][ca][cb][2] = num % mod;
                }
 
            }
        }
    }
 
    // 先获得特定i j k对应的方案数
    for(int i = 0; i <= cnt[n]; i ++) 
        for (int j = 0; i + j <= cnt[n]; j++)
        {
            int num = dp[n][i][j][0] + dp[n][i][j][1] + dp[n][i][j][2];
            f[i][j][cnt[n] - i - j] = num % mod; 
        }
     // 获得i j k有富余的情况对应的方案数 三维前缀和
    for (int i = 0; i <= 300; i++) {
        for (int j = 0; j <= 300; j++) {
            for (int k = 0; k <= 300; k++) {
                if (i > 0) f[i][j][k] += f[i - 1][j][k];
                if (j > 0) f[i][j][k] += f[i][j - 1][k]; 
                if (k > 0) f[i][j][k] += f[i][j][k - 1]; 
                if (i && j)f[i][j][k] += mod - f[i - 1][j - 1][k];
                if (k && j)f[i][j][k] += mod - f[i][j - 1][k - 1];
                if (i && k)f[i][j][k] += mod - f[i - 1][j][k - 1];
                if (i && j && k)f[i][j][k] += f[i - 1][j - 1][k - 1];
                f[i][j][k] %= mod;
            }
        }
    }
 
    while (m --) 
    {
        int x, y, z; cin >> x >> y >> z;
        cout << f[x][y][z] << '\n';
    }
}
 
signed main()
{
    ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    
    int t = 1;
    //cin >> t;
    while (t--) solve();
 
    return 0;
}
/*   /\_/\
*   (= ._.)
*   / >  \>
*/

Problem I. Good Partitions

题目意思:

        给定一个数组,平均分割k段,每一段保证相邻的两个元素不是递增的,求满足条件的k。

同时可以单点修改,再p位置修改为v。

解题思路:

        1.满足条件的分割点就是if(a[i] > a[i + 1])那么i就是分割点。

        2.求出分割点的gcd,找出他因子的个数,就是分割方法的总数。

        3.为了支持单点修改,每次修改完会有4种结果,并且只会对位置p之后的结果会有影响,我们用线段树来维护即可。

#include<bits/stdc++.h>

using namespace std;

using ll = long long;
using ld = long double;
using pii = pair<int, int>;
using ull = unsigned long long;

struct node{
    int l, r;
    ll val;
};
const int N = 2e5 + 10;
int cnt[N];
int gcd(ll a, ll b)
{
    return b ? gcd(b, a % b) : a;
}

class SegmentTree {

public:
    int n;
    vector<node> c;
    vector<int> a;
public:

    SegmentTree (int x){
        n = x << 2;
        c.resize(n);
        a.resize(x + 1);
    }


    void build(int k, int l, int r){
        c[k] = {l, r, 0};
        if(l != r){
            int mid = (l + r) / 2;
            build(k << 1, l, mid);
            build(k << 1 | 1, mid + 1, r);
        }
    }

    void pushup(int k){
        c[k].val = gcd(c[k << 1].val, c[k << 1 | 1].val);
    }

    void modify(int k, int x, int v){
        if(c[k].l == c[k].r) c[k].val = v;
        else{
            int mid = c[k].l + c[k].r >> 1;
            if(x <= mid ) modify(k << 1, x, v);
            else modify(k << 1 | 1, x, v);

            pushup(k);
        }
    }
};

void solve(){
    int n, m;
    cin >> n >> m;
    SegmentTree s(n);
    s.build(1, 1, n);
    for(int i = 1; i <= n; i ++){
        cin >> s.a[i];
    }
    for (int i = 1; i < n; i++)
    {
        if (s.a[i] > s.a[i + 1]) s.modify(1, i, i);
        else s.modify(1, i, 0);
    }
    int ans = s.c[1].val;
    if(ans == 0) cout << n << endl;
    else cout << cnt[ans] << endl;

    int p, v;
    while(m --){
        cin >> p >> v;
        s.a[p] = v;
        if(s.a[p - 1] > s.a[p]) s.modify(1, p - 1, p - 1);
        else s.modify(1, p - 1, 0);

        if(p < n){
            if(s.a[p] > s.a[p + 1]) s.modify(1, p, p);
            else s.modify(1, p, 0);
        }

        int ans = s.c[1].val;
        if(ans == 0) cout << n << endl;
        else cout << cnt[ans] << endl;
    }
}

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);
    for (int i = 1; i <= 200001; i++)
        for (int j = 1; j * i <= 200001; j++)
            cnt[i * j] ++;
    int t = 1;
    cin >> t;
    while(t --)
        solve();
    return 0;
}

Problem J. Grand Prix of Ballance

签到模拟

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2241655.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

机器学习 - 为 Jupyter Notebook 安装新的 Kernel

https://ipython.readthedocs.io/en/latest/install/kernel_install.html 当使用jupyter-notebook --no-browser 启动一个 notebook 时&#xff0c;默认使用了该 jupyter module 所在的 Python 环境作为 kernel&#xff0c;比如 C:\devel\Python\Python311。 如果&#xff0c…

SwiftUI-基础入门

开发OS X 图形应用界面时有三种实现方式&#xff1a;XIB、Storyboard、SwiftUI。Storyboard基于XIB做了优化&#xff0c;但XIB基本被放弃了&#xff0c;而SwiftUI是苹果公司后来开发的一套编程语言&#xff0c;用来平替Objective-C。虽然现在Swift 6 还是有些不完善的地方&…

androidstudio入门到放弃配置

b站视频讲解传送门 android_studio安装包&#xff1a;https://developer.android.google.cn/studio?hlzh-cn 下载安装 开始创建hello-world 1.删除缓存 文件 下载gradle文件压缩&#xff1a;gradle-8.9用自己创建项目时自动生成的版本即可&#xff0c;不用和我一样 https://…

如何在pycharm中 判断是否成功安装pytorch环境

1、在电脑开始端&#xff0c;找到 2、打开后 在base环境下 输入conda env list 目前我的环境中没有pytorch 学习视频&#xff1a;【Anaconda、Pytorch、Pycharm到底是什么关系?什么是环境?什么是包?】https://www.bilibili.com/video/BV1CN411s7Ue?vd_sourcefad0750b8c6…

昆明华厦眼科医院举办中外专家眼科技术研讨会

9月13日&#xff0c;“睿智迭代&#xff0c;增效赋能”Menicon Z Night中外专家研讨会在昆明华厦眼科医院成功举办。此次会议由目立康公司与昆明华厦眼科医院携手共筑&#xff0c;标志着双方合作迈向新的高度。 昆明华厦眼科医院总经理王若镜首先发表了热情洋溢的致辞&#xff…

HarmonyOS ArkUI(基于ArkTS) 开发布局 (上)

一 ArkUI(基于ArkTS)概述 基于ArkTS的声明式开发范式的方舟开发框架是一套开发极简、高性能、支持跨设备的UI开发框架&#xff0c;提供了构建应用UI所必需的能力 点击详情 特点 开发效率高&#xff0c;开发体验好 代码简洁&#xff1a;通过接近自然语义的方式描述UI&#x…

【STM32】项目实战——OV7725/OV2604摄像头颜色识别检测(开源)

本篇文章分享关于如何使用STM32单片机对彩色摄像头&#xff08;OV7725/OV2604&#xff09;采集的图像数据进行分析处理&#xff0c;最后实现颜色的识别和检测。 目录 一、什么是颜色识别 1、图像采集识别的一些基本概念 1. 像素&#xff08;Pixel&#xff09; 2. 分辨率&am…

SpringCloud-使用FFmpeg对视频压缩处理

在现代的视频处理系统中&#xff0c;压缩视频以减小存储空间、加快传输速度是一项非常重要的任务。FFmpeg作为一个强大的开源工具&#xff0c;广泛应用于音视频的处理&#xff0c;包括视频的压缩和格式转换等。本文将通过Java代码示例&#xff0c;向您展示如何使用FFmpeg进行视…

大数据学习14之Scala面向对象--至简原则

1.类和对象 1.1基本概念 面向对象&#xff08;Object Oriented&#xff09;是一种编程思想&#xff0c;面向对象主要是把事物给对象化&#xff0c;包括其属性和行为。面向对象编程更贴近实际生活的思想&#xff0c;总体来说面向对象的底层还是面向过程&#xff0c;面向过程抽象…

pipx安装提示找不到包

执行&#xff1a; pipx install --include-deps --force "ansible6.*"WARNING: Retrying (Retry(total4, connectNone, readNone, redirectNone, statusNone)) after connection broken by NewConnectionError(<pip._vendor.urllib3.connection.HTTPSConnection …

‘conda‘ 不是内部或外部命令,也不是可运行的程序或批处理文件,Miniconda

下载了conda&#xff0c;但是在cmd里执行conda --version会显示’conda’ 不是内部或外部命令&#xff0c;也不是可运行的程序或批处理文件。 原因是环境变量里没有添加conda&#xff0c;无法识别路径。 需要在系统环境变量里添加如下路径&#xff1a; 保存之后重新打开cmd&am…

【Qt】使用QString的toLocal8Bit()导致的问题

问题 使用Qt发送一个Http post请求的时候&#xff0c;服务一直返回错误和失败信息。同样的url以及post参数&#xff0c;复制黏贴到postman里就可以发送成功。就感觉很神奇。 原因 最后排查出原因是因为参数中含有汉字而导致的编码问题。 在拼接post参数时&#xff0c;使用了…

设计一致性的关键:掌握 Axure 母版使用技巧

设计一致性的关键&#xff1a;掌握 Axure 母版使用技巧 前言 在快节奏的产品开发周期中&#xff0c;设计师们一直在寻找能够提升工作效率和保持设计一致性的方法。 Axure RP&#xff0c;作为一款强大的原型设计工具&#xff0c;其母版功能为设计师们提供了一个强大的解决方案…

鸿蒙next ui安全区域适配(刘海屏、摄像头挖空等)

目录 相关api 团结引擎对于鸿蒙的适配已经做了安全区域的适配&#xff0c;也考虑到了刘海屏和摄像机挖孔的情况&#xff0c;在团结引擎内可以直接使用Screen.safeArea 相关api 团结引擎对于鸿蒙的适配已经做了安全区域的适配&#xff0c;也考虑到了刘海屏和摄像机挖孔的情况&am…

Android OpenGL ES详解——实例化

目录 一、实例化 1、背景 2、概念 实例化、实例数量 gl_InstanceID 应用举例 二、实例化数组 1、概念 2、应用举例 三、应用举例——小行星带 1、不使用实例化 2、使用实例化 四、总结 一、实例化 1、背景 假如你有一个有许多模型的场景&#xff0c;而这些模型的…

前端传数组 数据库存Json : [1,2,3]格式

一、前端正常传数组&#xff0c;但是value.toString() 即可 const empIds ref([1,2,3]) empIds.value empIds.value.toString() await updateApiRules(empIds.value) // 接口传参 二、后端用String类型接收后转换 String[] empIds updateDO.getEmpId().split("&#x…

《Java核心技术 卷I》用户图形界面鼠标事件

鼠标事件 如果只希望用户能够点击按钮或菜单&#xff0c;那么就不需要显式地处理鼠标事件&#xff0c;鼠标操作将由用户界面中的各种组件内部处理&#xff0c;不过&#xff0c;如果希望用户能使用鼠标画图&#xff0c;就需要捕获鼠标移动&#xff0c;点击和拖动事件。 本节&am…

贪心算法入门(三)

相关文章 贪心算法入门&#xff08;一&#xff09;-CSDN博客 贪心算法入门&#xff08;二&#xff09;-CSDN博客 1.什么是贪心算法&#xff1f; 贪心算法是一种解决问题的策略&#xff0c;它将复杂的问题分解为若干个步骤&#xff0c;并在每一步都选择当前最优的解决方案&am…

企业知识中台:构建智慧企业的核心

在当今数字化时代&#xff0c;企业知识中台已成为构建智慧企业的核心。它不仅是企业知识资产的集中地&#xff0c;也是推动企业创新和提高决策效率的关键。本文将分为四个部分&#xff0c;详细探讨知识中台的概念、重要性、构建步骤以及如何利用HelpLook工具搭建企业知识库。 …

基于Spring Boot的在线性格测试系统设计与实现(源码+定制+开发)智能性格测试与用户个性分析平台、在线心理测评系统的开发、性格测试与个性数据管理系统

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…