AtCoder Beginner Contest 355 A~F

A.Who Ate the Cake?(思维)

题意

已知有三个嫌疑人,有两个证人,每个证人可以指出其中一个嫌疑人不是罪犯,如果可以排除两个嫌疑人来确定犯人,输出犯人的身份,如果无法确定,输出"-1"

分析

如果输入两个人的编号相同,则无法确定犯人,如果不同,则 6 − A − B 6 - A - B 6AB为犯人的编号。

代码

#include <bits/stdc++.h>
using namespace std;

void solve() {
    int a, b;
    cin >> a >> b;
    if (a == b) cout << -1 << endl;
    else cout << 6 - a - b << endl;
}
int main () {
    solve();
    return 0;
}

B.Piano 2(桶数组)

题意

给出一个包含 n n n个数字的数组 A A A以及一个包含 m m m个数字的数组 B B B,将 A A A数组和 B B B数组中的数字放入数组 C C C中,并对放入的数字进行排序。

问:数组 C C C中是否存在相邻两项,这两项均属于数组 A A A(保证数组 A A A和数组 B B B中所有数字均是独立的,即不会出现相同的数字)。

分析

使用标记数组对出现在 A A A数组中的数字进行标记,然后将数组 A A A和数组 B B B中元素放入vector中并排序。

然后依次检查vector中相邻两项是否均被标记,如果均被标记,输出Yes,如果结束循环还是没找到,输出No

代码

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 3e5 + 5e2;

int n, m,a[N], b[N], vis[N];
vector<int> C;

void solve() {
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        cin >> a[i];
        C.emplace_back(a[i]);
        vis[a[i]] = 1;
    }
    for (int i = 1; i <= m; i++) {
        cin >> b[i];
        C.emplace_back(b[i]);
    }
    sort(C.begin(), C.end());
    for (int i = 1; i < n + m; i++) {
        if (vis[C[i - 1]] == 1 && vis[C[i]] == 1) {
            cout << "Yes" << endl;
            return;
        }
    }
    cout << "No" << endl;
}
int main () {
    solve();
    return 0;
}

C.Bingo 2(模拟)

题意

给出一个 N × N N \times N N×N的网格,将对这个网格执行 T T T个回合操作,每个回合会选择网格上的一个点(使用一个数字代表坐标)进行标记。

当满足以下几种条件之一,即获得了胜利:

  • 存在某一行上所有的格子均被标记

  • 存在某一列上所有的格子均被标记

  • 两条对角线上所有的格子均被标记

问:最早执行多少个回合后,就赢下了这场比赛,如果结束所有操作后还未获胜,输出-1.

分析

为了便于处理,将输入的数字 A i A_i Ai先减去 1 1 1,然后通过 A i / n , A i A_i / n, A_i Ai/n,Ai % n n n的方式即可得到行号和列号(此时的行号和列号从 0 0 0开始)。

然后考虑三个条件怎么进行判断:

  • 行和列:使用数组记录每行每列被标记的节点数量

  • 主对角线:主对角线元素行号和列号均相等,判断当前网格的行号和列号,如果相同即进行标记

  • 副对角线:副对角线的行列号之和为 n − 1 n - 1 n1,判断当前网格的行列号之和是否为 n − 1 n - 1 n1,如果是就进行标记

每轮标记完成后,判断是否满足以上三个条件,如果满足则输出当前轮次,并结束程序。

如果循环正常结束,输出-1

代码

#include <bits/stdc++.h>
using namespace std;
const int N = 3e5 + 5e2;

int n, k, r[N], c[N], d[5], a[N];

void solve() {
    cin >> n >> k;
    for (int i = 1; i <= k; i++) {
        cin >> a[i];
        a[i]--;
        int row = a[i] / n, colum = a[i] % n;
        r[row]++;
        c[colum]++;
        if (row == colum) d[0]++;
        if (row + colum == n - 1) d[1]++;
        if (r[row] == n || c[colum] == n || d[0] == n || d[1] == n) {
            cout << i << endl;
            return;
        }
    }
    cout << -1 << endl;
}
int main () {
    solve();
    return 0;
}

D.Intersecting Intervals(双指针)

题意

给出 N N N个区间 [ l i , r i ] [l_i, r_i] [li,ri],问存在多少对区间相交。

分析

考虑相交比较困难,但考虑不相交就很容易了。

不难想到,只要是右边界小于当前区间的左边界的所有区间,那么必然不会与当前区间相交,此时不在乎这个区间的左边界到底是多少,因此,可以使用两个数字存储左右边界,并单独对两个数组排序。

然后从小往大遍历左边界数组,使用双指针在右边界数组中维护所有小于当前左边界的数量,这个数量就是不会与当前区间相交的区间数量。

使用区间总对数减去每个区间不会相交的区间数量即可。

hint: 本题 n n n较大,需要使用long long类型存储答案。

代码

#include <bits/stdc++.h>
using namespace std;
const int N = 5e5 + 5e2;

int l[N], r[N]; 

void solve() {
    ll n;
    cin >> n;
    for (int i = 0; i < n; i++) {
        cin >> l[i] >> r[i];
    }
    sort(l, l + n);
    sort(r, r + n);
    int j = 0;
    ll ans = (n - 1) * n / 2;
    for (int i = 0; i < n; i++) {
        while (r[j] < l[i]) {
            j++;
        }
        ans -= j;
    }
    cout << ans << endl;
}
int main () {
    solve();
    return 0;
}

E.Guess the Sum(BFS)

题意

本题是一个交互题

给出一个数字 N N N和区间 l , r l, r l,r,题目隐藏了一个数组 A = ( A 0 , A 1 , … , A 2 n − 1 A = (A_0, A_1, \ldots, A_{2^{n} - 1} A=(A0,A1,,A2n1,你的目标是知道 ( A l + A l + 1 + … + A r ) (A_l + A_{l + 1} + \ldots + A_{r}) (Al+Al+1++Ar) % 100 100 100的结果。

你可以按以下要求进行询问:

  • 选择两个非负整数 i , j i, j i,j,需要保证 2 i ( j + 1 ) ≤ 2 N 2^{i}(j + 1) \le 2^{N} 2i(j+1)2N,然后取 L = 2 i j , R = 2 i ( j + 1 ) − 1 L = 2^{i}j, R = 2^{i}(j + 1) - 1 L=2ij,R=2i(j+1)1,将 i , j i, j i,j告诉题目后,题目会返回 ( A L + A L + 1 + … + A R ) (A_L + A_{L + 1} + \ldots + A_{R}) (AL+AL+1++AR) % 100 100 100的结果

你需要在保证询问次数最小的情况下,找到要求的答案。

分析

由于可以通过查询大区间减去小区间的方式获得结果,因此直接通过倍增的方式进行查找不能保证操作次数最少。

例:当要查询的区间为 2 k ∼ 2 k + 1 − 2 2^{k} \sim 2^{k + 1} - 2 2k2k+12时,通过查询区间 2 k ∼ 2 k + 1 − 1 2^{k} \sim 2^{k + 1} - 1 2k2k+11减去区间 2 k + 1 − 1 ∼ 2 k + 1 − 1 2^{k + 1} - 1 \sim 2^{k + 1} - 1 2k+112k+11的方式只需要两次询问,而直接使用倍增进行询问所需的次数无法保证两次询问即查询完整个区间数字总和。

因此,可以将本题中所有可能的询问包含的两个点之间建双向边,那么问题就被转化为了 L ∼ R + 1 L \sim R + 1 LR+1之间的最短路(这里为什么取 R + 1 R + 1 R+1呢?因为当移动到 R + 1 R + 1 R+1时,才能保证第 R R R个元素也被计算到了),使用 B F S BFS BFS搜索最短路,然后通过记录的移动步数反推出最短路径,将最短路径上经过的所有路径上的连接的点作为询问,即可获得最后的答案。

hint: 注意最优走法并不一定都是从左往右走的,可能通过先向右走一大步再回头的方式完成,对于往回走的询问,需要从结果中减去。

代码

#include <bits/stdc++.h>
using namespace std;
const int N = 1e6 + 5e2;
int ask(int i, int j) {
    int sign = 1;
    if (i > j) {
        swap(i, j);
        sign *= -1;
    }
    int l = log2(j - i), r = i >> l;
    cout << "? " << l << ' ' << r << endl;
    cout.flush();
    int ans;
    cin >> ans;
    return sign * ans;
}
int n, l, r, dist[N];
vector<int> G[N];

queue<int> Q;
void bfs(int start) {
    Q.push(start);
    dist[start] = 1;
    while (!Q.empty()) {
        int u = Q.front();
        Q.pop();
        for (auto v : G[u]) {
            if (dist[v] == 0) {
                dist[v] = dist[u] + 1;
                Q.push(v);
            }
        }
    }
}

void solve() {
    cin >> n >> l >> r;
    r++;
    for (int i = 0; i <= n; i++) {
        for (int j = 0; j < (1 << n); j += (1 << i)) {
            G[j].push_back(j + (1 << i));
            G[j + (1 << i)].push_back(j);
        }
    }
    bfs(l);
    int ans = 0;
    while (r != l) {
        for (auto v : G[r]) {
            if (dist[r] == dist[v] + 1) {
                ans = (ans + ask(v, r) + 100) % 100;
                r = v;
                break;
            }
        }
    }
    cout << "! " << ans << endl;
}

int main () {
    solve();
    return 0;
}

F.MST Query(并查集)

题意

给出一个包含 N N N个点和 N − 1 N - 1 N1条边的带权无向连通图,你将对这个图进行 Q Q Q次操作,每次的操作如下:

  • 给出三个数字 u i , v i , w i u_i, v_i, w_i ui,vi,wi,在点 u i u_i ui v i v_i vi之间连一条边权为 w i w_i wi的边。

  • 计算当前图上的最小生成树权值

分析

由于图上边权的范围很小 ( w i ≤ 10 ) (w_i \le 10) (wi10),因此,可以维护权值为 1 ∼ 10 1 \sim 10 110 10 10 10张图,每张图上边权相等。

将每次加边操作视为往对应边权(以及更高的边权)的图上建边,如果建边之前该图上这两个点不属于同一个集合,那么当前边建立后,最小生成树的权值就会减少,减少多少呢?就得看最低多少权值,对应的图上这两个点才属于同一个集合。

从当前权值开始遍历到 10 10 10,执行到第一个连通的权值对应的图后,即可从维护的权值中减去这个遍历到的权值,然后加上当前建边的权值,即得到了最新的最小生成树权值。

hint: 每次建边时,需要在所有权值大于等于当前边权的图中建边。

代码

#include <bits/stdc++.h>
using namespace std;
const int N = 2e5 + 5e2;

int n, q, f[15][N];

int find(int w, int x) {
    return f[w][x] == x ? x : f[w][x] = find(w, f[w][x]);
}

int merge(int u, int v, int w) {
    int fu = find(w, u),
        fv = find(w, v);
    if (fu == fv) return 1;
    f[w][fu] = fv;
    return 0;
}

void solve() {
    cin >> n >> q;
    for (int i = 1; i <= n; i++) {
        for (int j = 0; j <= 10; j++) {
            f[j][i] = i;
        }
    }
    int sum = 0;
    for (int i = 1; i < n; i++) {
        int u, v, w;
        cin >> u >> v >> w;
        for (int j = w; j <= 10; j++) {
            merge(u, v, j);
        }
        sum += w;
    }
    while (q--) {
        int u, v, w;
        cin >> u >> v >> w;
        sum += w;
        for (int j = w; j <= 10; j++) {
            if (merge(u, v, j)) {
                sum -= j;
                break;
            }
        }
        cout << sum << endl;
    }
}

int main () {
    solve();
    return 0;
}

赛后交流

在比赛结束后,会在交流群中给出比赛题解,同学们可以在赛后查看题解进行补题。

群号: 704572101,赛后大家可以一起交流做题思路,分享做题技巧,欢迎大家的加入。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

PostgreSQL基本使用

参考文档&#xff1a;PostgreSQL基本使用与数据备份_postgresql 数据备份-CSDN博客 一、数据库的操作 1. 本机登录 2.创建新用户来访问 PostgreSQL 3 重启数据库服务 4.创建数据库并查看数据库 5.连接数据并删除数据库 6.建表插入数据&#xff0c;查看数据库下所有的表&#…

核函数的介绍

1.核函数的介绍&#xff1a; 1、用线性核等于没有用核。 2、多项式核&#xff1a;随着d越大&#xff0c;则 fai(X) 对应的维度将越高。&#xff08;可以通过d得到对应的fai(X)函数&#xff09;。 3、高斯核函数&#xff1a;无限维度。 4、tanh核。 2.如何选择核函数的参数&am…

【从零开始实现stm32无刷电机FOC】【理论】【2/6 SVPWM数学模型】

目录 线性调制区扇区pwm计算桥臂pwm计算纯c语言代码验证目标磁矢量为笛卡尔坐标系形式的推导结束 上一节&#xff0c;我们找到了一种控制线圈合成磁矢量的方法— SVPWM&#xff0c;但是仅停留在逻辑层面上。本节对SVPWM进行数学推导&#xff0c;给出最终的线圈控制函数。本节的…

勒索软件分析_Conti

0. Conti介绍 勒索软件即服务&#xff08;Ransomware as a Service&#xff0c;RaaS&#xff09;变体 Conti 推出还不到两年&#xff0c;已经进行了第七次迭代。Conti被证明是一种敏捷而熟练的恶意软件威胁&#xff0c;能够自主和引导操作&#xff0c;并具有无与伦比的加密速度…

SAP HCM WPBP的几个变量含义

WPBP起源 WPBP是SAP HCM的主数据的集合内表,集合、内表这两个名词如何理解,集合就是多个主数据的汇总,内表是ABAP的几个数据结构,就和我们EXCEL的多行一行。 wpbp数据来源 WPBP的主数据来源于SAP HCM 0000、0001、0007、0027、0008信息类型的汇总,SAP HCM是以时间轴为核心…

揭秘《庆余年算法番外篇》:范闲如何使用维吉尼亚密码解密二皇子密信

❤️❤️❤️ 欢迎来到我的博客。希望您能在这里找到既有价值又有趣的内容&#xff0c;和我一起探索、学习和成长。欢迎评论区畅所欲言、享受知识的乐趣&#xff01; 推荐&#xff1a;数据分析螺丝钉的首页 格物致知 终身学习 期待您的关注 导航&#xff1a; LeetCode解锁100…

有趣的css - 加减动态多选框

大家好&#xff0c;我是 Just&#xff0c;这里是「设计师工作日常」&#xff0c;今天分享的是用 css 实现一个适用树形菜单场景的加减动态多选框。 最新文章通过公众号「设计师工作日常」发布。 目录 整体效果核心代码html 代码css 部分代码 完整代码如下html 页面css 样式页面…

SQL SERVER 我没有消失,SQL SERVER下一个版本是2025 (功能领先大多数数据库)

开头还是介绍一下群&#xff0c;如果感兴趣PolarDB ,MongoDB ,MySQL ,PostgreSQL ,Redis, Oceanbase, Sql Server等有问题&#xff0c;有需求都可以加群群内有各大数据库行业大咖&#xff0c;可以解决你的问题。加群请联系 liuaustin3 &#xff0c;&#xff08;共2320人左右 1 …

github加速访问及资源一秒代理下载

如果你想加速打开github网页&#xff0c;可以采用以下方法&#xff0c;仅需一个插件。 1.代理加速访问 打开gitee网站&#xff0c;搜索dev-sidecar关键字&#xff0c;然后找到星星最多的项目 可以阅读项目说明&#xff0c;找到感兴趣的内容或是直接下载DevSidecar桌面应用程序…

C语言笔记21 •模拟atoi函数•

1.atoi的使用 atoi是将字符串转化为int类型数字的一个库函数 int main() { char str[] "123568"; int a; a atoi(str); /*将字符串转化为int型的数字*/ printf("%d\n", a); } 2.模拟atoi函数 #define _CRT_SECURE_NO_WARNINGS…

MyBatis-Plus 从入门到精通

MyBatis-Plus 从入门到精通 前言快速入门创建一个SpringBoot项目导入依赖配置数据库创建一个实体类创建一个mapper接口在SpringBoot启动类上配置mapper接口的扫描路径在数据库中创建表编写一个SpringBoot测试类 核心功能注解CRUD接口Mapper CRUD接口Service CRUD 接口条件构造器…

通过Kafka-Logger插件收集流量进行漏洞扫描

通过Kafka-Logger插件收集流量进行漏洞扫描 方案 可以通过APISIX kafka-logger 插件将日志作为 JSON 对象推送到 Apache Kafka 集群中&#xff0c;消费Kafka里的数据格式化后添加到MySQL。 方案详情 1、登录APISIX&#xff0c;启用内置的kafka-logger 插件&#xff1a; 2…

PyQt6--Python桌面开发(34.QStatusBar状态栏控件)

QStatusBar状态栏控件 self.statusBar.showMessage(q.text()菜单选项被点击了,5000)

当HR问你是否单身时,该怎么回答?

知识星球&#xff08;星球名&#xff1a;芯片制造与封测技术社区&#xff0c;星球号&#xff1a;63559049&#xff09;里的学员问&#xff1a;我是晶圆厂厂务工程师&#xff0c;最近在面试新工作&#xff0c;但是几乎每家HR都会问我同一个问题&#xff1a;你结婚没有&#xff1…

安全设计 | CISA:构建不可侵犯的代码,软件安全设计的未来之路

软件制造商在产品设计和开发过程中应采取安全设计原则和方法&#xff0c;以减少网络安全风险&#xff0c;并转变责任重心&#xff0c;使产品在设计时就内置安全特性&#xff0c;而不是依赖于后期的补丁和修复。为此CISA发布了《软件安全设计的原则和方法》&#xff0c;帮助软件…

Windows11平台在VS2022上通过CMake安装C++绘图库ROOT库

Root库是一个功能强大的开源软件框架&#xff0c;用于数据分析、可视化和存储。它最初是为高能物理实验设计的&#xff0c;但现在已经广泛应用于各种科学领域和工程应用中。Root库使用C编写&#xff0c;提供了许多用于数据处理和分析的工具和算法。它的核心功能包括数据存储、数…

6.Redis之String命令

1.String类型基本介绍 redis 所有的 key 都是字符串, value 的类型是存在差异的~~ 一般来说,redis 遇到乱码问题的概率更小~~ Redis 中的字符串,直接就是按照二进制数据的方式存储的. (不会做任何的编码转换【讲 mysql 的时候,知道 mysql 默认的字符集, 是拉丁文,插入中文…

等保2.0看这一篇就够了

一、等级保护介绍 1.1什么是等级保护 网络安全等级保护是指对国家重要信息、法人和其他组织及公民的专有信息以及信息和存储、传输、处理这些信息的信息系统分等级实行安全保护&#xff0c;对信息系统中使用的信息安全产品实行按等级管理&#xff0c;对信息系统中发生的信息安…

微火问答:全域外卖和本地生活服务是同个项目吗?

当前&#xff0c;本地生活赛道火爆程度不断升级&#xff0c;作为其主要板块之一的团购外卖也持续迸发出新的活力。而全域运营的出现无疑是给团购外卖这把正在熊熊燃烧的烈火&#xff0c;又添了一把新柴&#xff01; 所谓全域运营&#xff0c;简单来说&#xff0c;就是指所有领…

SAP-技巧篇实现GUI免密码登录

做为上千万的软件怎么会没有免密码登录呢 01 — 背景需求 如何实现SAP GUI免密码登录&#xff0c;不输入密码实现系统自动登录。 免责声明&#xff1a;谨慎设置&#xff0c;因免密登录导致数据泄密&#xff0c;作者概不负责。 02 — 实现 客户端要求&#xff1a;SAP G…