7月30日模拟赛赛后总结

\[7月30日 \ \ 模拟赛 \ \ 赛后总结 \\ 2024年7月30日 \\ by \ \ \ hcy
\]

洛谷同步:点我

一、做题情况

  • 第一题比赛 \(100pts\) ,赛后\(AC\)

  • 第二题比赛 \(20pts\) ,赛后\(AC\)

  • 第三题比赛 \(0pts\) ,赛后\(AC\)

  • 第四题比赛 \(30pts\) ,赛后\(30pts\)

  • 比赛得分 \(150/400 \ pts\) ,赛后补题 \(330 / 400 \ pts\)

    二、比赛概况

    T1一道水题,花了15 min切掉了,预期分数:\(100pts\),实际分数:\(100pts\)

    T2看了眼题目,不敢直接用 map,怕被卡常,先离散化一下,再进行双指针,不知道为啥 \(WA\ 20pts\) ,很奇怪。 预期分数:\(100pts\) 实际分数:\(20pts\) ,用时30 min

    T3看起来像ZJOI2022的题(实则不是),看了眼题目,觉得有点难,先做T4,T4看着有些像线段树,但是不知道怎么写,只好写个暴力。 预期分数:\(30pts\) 实际分数:\(30pts\) ,用时30 min

    回来看T3,花了10 min才把题目读懂,正解不知道怎么写,只好自己整些歪魔邪道 预期分数:? 感觉 \(50pts\) 实际:\(0pts\) (不幸用C++98[XYD没写C++指的是C++98,以为是C++20],greater不能用,惨遭 \(CE\) 爆 \(0\))

三、题解报告

T1:

题面:

报数游戏Ⅱ

时间限制: 1s

空间限制: 512MiB

【题目描述】

外星幼儿园的小朋友按照老师的要求玩报数游戏Ⅱ,每个人手里有一张小纸条,上面写着一个数字,每个人都按照顺序报数,报数的方式是这样的 :

每个人听自己的前面一个人报数字的大小,加上自己纸条上的数字求和,并报出自己的数字。

对于第一个人来说,他听到的数字是由老师报出来的。

如果你是老师,请在确保每位同学报的数字是正数的情况下,报出一个最小的正数作为起始值。

【输入格式】

第一行有一个整数 \(n\),输入有多少个同学排队 第二行输入一个数组 \(nums\),数组长度为 \(n\),数字用空格分隔,代表同学按照报数字的顺序排好队以后,每个同学手里小纸条上的数字。

【输出格式】

输出一行,共一个数字,输出符合条件的起始值。

【样例输入1】

5

-3 2 -3 4 2

【样例输出1】

5

【样例解释1】

在你选择5作为起始值时,五名同学的报数均为正数,为 \([2,4,1,5,7]\)。

【数据范围】

对于 \(20\%\) 的数据来说: \(1 \le n \le 100,-100 \le nums_i \le 100\)

对于 \(100\%\) 的数据来说: \(1 \le n \le 10^5, -10^9 <= nums_i <= 10^9\)

做法:

一道 前缀和 板子题,只要加点数学,都可以做吹来。

个人体感难度:\(\color{#FE4C61}\text{入门}\)

附:AC代码

#include <bits/stdc++.h>
#define int long long
using namespace std ;
int n , a [100010] , b [100010] , mi ;
signed main () {
ios::sync_with_stdio (false) ;
cin.tie (NULL) ; cout.tie (NULL) ;
cin >> n ;
for (int i = 1 ; i <= n ; i ++) cin >> a [i] ;
for (int i = 1 ; i <= n ; i ++) b [i] = b [i - 1] + a [i] ;
mi = LONG_LONG_MAX ;
for (int i = 1 ; i <= n ; i ++) mi = min (mi , b [i]) ;
if (mi >= 0) cout << 1 ;
else cout << 1 + (- mi) ;
return 0 ;
}

T2:

题面:

百万富翁的第二次实验

时间限制: 1s

空间限制: 512MiB

【题目描述】

马克吐温有一本非常著名的小说《百万英镑》,这本小说中主角最后归还了百万英镑给两位富翁。但结果就是两位富翁依然有无穷的问题需要进行社会实验,于是,他们打算进行第二次社会实验。那就是不同财富值的人在一场舞会上会发生什么事情。为了满足自己的好奇,百万富翁们邀请了全伦敦所有人来自己的舞会。舞会开始后他们就后悔了,因为来的人太多了,而且很多人的财富都相同,统计起来太费事了。所以百万富翁们找到你,希望你根据来舞会的时间,找出在一段时间内,来舞会的所有人财富值都互不相同的人数。

【输入格式】

第一行输入一个 \(n\) 表示有 \(n\) 个人参与舞会。

按照时间顺序输入 \(n\) 个人的财富值。

【输出格式】

输出在一段时间内参加舞会的所有人财富值都互不相同的人数的最大值。

【样例】

Input 1

7

2 3 4 5 5 6 7

Output 1

4

【数据范围】

对于 \(100\%\) 的数据:

每个人的财富值不超过 \(100000000000\)。

\(0 \le n \le 1000000\)。

做法:

得用 unordered_map ,map 会被卡掉 \(70pts\),用个双指针,轻松做出

个人体感难度:\(\color{#FFC116}\text{普及/提高-}\)

附:AC代码

#include <bits/stdc++.h>
#define int long long
#pragma G++ optimize (2)
#pragma G++ optimize (3)
using namespace std ;
int n , l , r , ans , a [1000010] ;
unordered_map <int , int> f ;
signed main () {
ios::sync_with_stdio (false) ;
cin.tie (NULL) ; cout.tie (NULL) ;
cin >> n ;
for (int i = 1 ; i <= n ; i ++) cin >> a [i] ;
l = 1 ; r = 1 ;
while (r <= n) {
if (f [a [r]]) {
ans = max (ans , r - l) ;
while (l < r && f [a [r]]) {
f [a [l]] = 0 ;
l ++ ;
}
}
f [a [r]] = 1 ;
r ++ ;
}
cout << max (ans , r - l) ;
return 0 ;
}

T3:

题面:

做法:

用贪心推出(但需要花许多经历),进行预处理,然后就是道 二分 板子题,不用多说。

个人体感难度:\(\color{#52C41A}\text{普及+/提高}\)

附:AC代码

#include <bits/stdc++.h>
#define int long long
#pragma G++ optimize (2)
#pragma G++ optimize (3)
using namespace std ;
int n , T , x , y , a [500010] , l , r , mid , bao , b [500010] , c [500010] ;
signed main () {
ios::sync_with_stdio (false) ;
cin.tie (NULL) ; cout.tie (NULL) ;
cin >> n >> T ;
for (int i = 1 ; i <= n ; i ++) cin >> a [i] ;
sort (a + 1 , a + 1 + n , greater ()) ;
for (int i = 1 ; i <= n ; i ++) {
b [i] = b [i - 1] + a [i] ;
c [i] = c [i - 1] + a [i] * (n - i + 1) ;
}
while (T --) {
cin >> x >> y ;
l = 1 ; r = min (x , n) ;
while (l <= r) {
mid = l + r >> 1 ;
if (c [mid] + (x - n) * b [mid] >= y) bao = mid , r = mid - 1 ;
else l = mid + 1 ;
}
if (c [bao] + (x - n) * b [bao] >= y) cout << bao << "\n" ;
else cout << "-1\n" ;
}
return 0 ;
}

T4:

题面:

统计区间

时间限制: 3s

空间限制: 512MiB

【题目描述】

有一个长度为 \(n\) 的数列 \(a\),\(a\) 的值在 \([1,n]\) 中,现在要统计区间中出现的数都恰好出现 \(2\) 次的区间数。

【输入格式】

第一行一个整数 \(n\)。

第二行 \(n\) 个整数表示 \(a\)。

【输出格式】

一行一个整数 \(cnt\),表示满足条件的区间数。

【样例】

Input 1

7

5 3 5 5 4 4 3

Output 1

4

【样例解释】

样例中合法的区间有:\([3,4],[5,6],[3,6],[2,7]\)。

【数据范围】

对于 \(30\%\) 的数据:\(n\le10^3\).

对于 \(100\%\) 的数据:\(n\le10^6\).

做法:

下面AC代码是另一种做法

个人体感难度:\(\color{#3498DB}\text{提高+/省选-}\)

附:AC代码

#include<bits/stdc++.h>
#define L(i, j, k) for (int i = (j); i <= (k); i++)
#define R(i, j, k) for (int i = (j); i >= (k); i--)
#define sz(a) ((int) (a).size())
#define ll long long
#define vi vector < int >
#define ull unsigned long long
using namespace std;
const int N = 1 << 20;
int n, a[N];
int lst[N], llst[N];
ull w[N], pre[N], ret;
ll ns;
unordered_map < ull, int > mp;
mt19937_64 orz(time(0) ^ clock());
int main () {
ios :: sync_with_stdio(false);
cin.tie(0); cout.tie(0);
cin >> n ;
L(i, 1, n) cin >> a[i];
L(i, 1, n) w[i] = orz();
int p = 0;
mp[0] += 1;
L(i, 1, n) {
while (p < llst[a[i]]) mp[pre[p]] -= 1, ++p;
llst[a[i]] = lst[a[i]], lst[a[i]] = i;
pre[i] = pre[i - 1] ^ w[a[i]], ns += mp[pre[i]], mp[pre[i]] += 1;
}
cout << ns << '\n';
return 0;
}

四、赛后总结

这把死得真惨,T2未知 \(WA\) ,T3用C++98惨遭 \(CE\) 。下次不知道会不会这样。

7月30日CSP-S模拟赛赛后总结的更多相关文章

  1. 2016年12月30日 星期五 --出埃及记 Exodus 21:25

    2016年12月30日 星期五 --出埃及记 Exodus 21:25 burn for burn, wound for wound, bruise for bruise.以烙还烙,以伤还伤,以打还打 ...

  2. 11月30日《奥威Power-BI智能分析报表制作方法》腾讯课堂开课啦

    这么快一周就过去了,奥威公开课又要与大家见面咯,上节课老师教的三种报表集成方法你们都掌握了吗?大家都知道,学习的结果在于实际应用,想要熟练掌握新内容的要点就在于去应用它.正是基于这一要点,每一期的课程 ...

  3. 2016年11月30日 星期三 --出埃及记 Exodus 20:21

    2016年11月30日 星期三 --出埃及记 Exodus 20:21 The people remained at a distance, while Moses approached the th ...

  4. 2016年10月30日 星期日 --出埃及记 Exodus 19:15

    2016年10月30日 星期日 --出埃及记 Exodus 19:15 Then he said to the people, "Prepare yourselves for the thi ...

  5. 2016年6月30日 星期四 --出埃及记 Exodus 14:27

    2016年6月30日 星期四 --出埃及记 Exodus 14:27 Moses stretched out his hand over the sea, and at daybreak the se ...

  6. 10 月 30 日新款 Mac mini 有望与新款 iPad Pro 一起发布

    苹果最新款的 Mac mini 是在 2014 年 10 月推出的版本,到现在已经过了 4 年.分析师郭明錤和彭博社的 Mark Gurman 都表示苹果会在今年晚些时候发布新款 Mac mini. ...

  7. 北京Uber优步司机奖励政策(3月30日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  8. 北京Uber优步司机奖励政策(1月30日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  9. 北京Uber优步司机奖励政策(12月30日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  10. 成都Uber优步司机奖励政策(3月30日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

随机推荐

  1. 数据标注工具 doccano

    目录 安装 运行 doccano 使用 doccanno 上传数据 定义标签 添加成员 开始标注 导出数据 查看数据 统计 数据标注工具 Label-Studio 安装 打开命令行(cmd.termi ...

  2. OpenSSL静态库交叉编译

    一.编译前环境准备 使用的内核:4.15.0-118-generic(命令:uname -r可以查看) 交叉编译器:aarch64-linux-gnu-gcc openssl源码:openssl-1. ...

  3. Freertos学习:03-任务

    --- title: rtos-freertos-03-任务 EntryName: rtos-freertos-03-task date: 2020-06-20 09:15:07 categories ...

  4. Coap 协议学习:具体协议介绍具体

    协议框架 CoAP默认运行在UDP上,但它也支持运行在SMS,TCP等数据传输层上.本文主要是基于UDP上的CoAP协议介绍 1.消息模型 Messages COAP协议通信是通过在UDP上传输消息类 ...

  5. ABP框架开发实例教程-获取前端样式和脚本

    1.运行生成的ABP框架,设置WEB.MVC项目为启动项目,点击开始运行,界面如下,样式和脚本文件不存在,所以导致界面无法正常显示,这个我研究ABP遇到的第二个坑,第一个坑是生成数据库. 2.为什么没 ...

  6. Webpack5

    Webpack是一款模块打包工具,可以把多个文件打包成一个或几个文件,它不仅能打包JS文件, 还能打包css, image等静态资源.当然,在默认情况下,它只打包JS文件和JSON文件,因为它只认识J ...

  7. 常用 Java 组件和框架分类

    WEB 容器 Tomcat https://tomcat.apache.org/ Jetty https://www.jetty.com/ JBoss https://www.jboss.org/ R ...

  8. Java核心字符串String进阶

    字符串对象 字符串是对象,不是简单数据类型 封装在java.lang包,自动导入 创建字符串对象 常见创建一个字符串对象有下面2个方法 String str=new String("chen ...

  9. 洛谷P1832

    #include<iostream> #include<utility> using namespace std; typedef long long ll; #define ...

  10. VirtualBox Ubuntu 22.04 Server联网、与主机互联

    使用 VirtualBox 7.0安装了两个Ubuntu 22.04 Server虚拟机,想要实现: 主机与虚拟机互联 虚拟机之间互联,且互联的IP应为静态 虚拟机可以联网 解决方法 每个虚拟机配置两 ...