abc--cf训练日常总结
ABC
最近遇到好多思维和位运算的题目不会做,特地过来总结一些小小的知识点。
- 思维题目
https://atcoder.jp/contests/abc353/tasks/abc353_c
这道题目要求我们计算连续的两个相邻的数组元素之和。我一开始用暴力,后面换了种错误的思路就wa了。
其实这道题目是求和,然后找到和大于1e8的数减去1e8就欧克了。所以我们只需要找到有多少个和大于1e8的数减去
数量X1e8就可以了。这里可以思考一下,题目的式子中每个元素加了多少遍?

正确答案是每个元素加了(n-1)遍,发现这个规律后,这样我们就能求出总和,现在只有一个问题,有多少和是大于1e8的呢?
这个我们不难想到,利用二分就可以找到下标,然后减去1e8的数量即可。
代码如下:
点击查看代码
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const ll MOD = 100000000;
ll n,m;
const ll N =3e5+9;
ll a[N],v[N];
ll ans=0,sum=0,pd=0;
/*
每个数字都相当于加了(n-1)遍
,但是如果出现俩个数相加大于1e8
,就要减一个1e8,我们只要将所有的数*n-1·
然后在计算一下剪掉1e8的个就行,排序
,然后二分或者lower_bound都行
*/
int check(int x){
ll l=0,r=n+1;
while(l+1!=r){
ll mid = (l+r) >> 1;
if(a[mid]>=x) r=mid;
else l=mid;
}
return r;
}
int main(){
ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
cin>>n;
for(int i=1;i<=n;i++) {
cin>>a[i];
sum+=(n-1)*a[i];
}
sort(a+1,a+n+1);
ans=sum;
for(int i=1;i<n;i++){
if(a[i]+a[n]<MOD) continue;
int res=check(MOD-a[i]);
if(res<=i)res=i+1; if(res>n) continue;
ans-=(n-res+1)*MOD;
}
cout<<ans;
return 0;
}
继续的跟在上面的题是这道。
https://atcoder.jp/contests/abc353/tasks/abc353_d
如果你观察发现这两道题是连在一起的。
乍一眼一看感觉跟上面题目差不多啊也是加起来,只不过是单纯的物理加起来前面加上后面,有没有什么联系呢?
题面如下:

一开始我就掉入了思维陷阱,想着用上面的方法做,没有完全读懂题面,就直接做,这样很糟糕。
正确的想法是(每个元素出现的次数还是(n-1)遍相当于),所以小伙伴们以后写题千万别像我一样//
这道题的想法是什么呢?我们不用想着把没一个数一个一个算,这样肯定爆T。根据上面拿到题的思路可以知道每个数都是n-1次,
这里是前面的数直接加上后面的数,其实是什么呢?就是每一个数*后面元素的位数,这里设每一个元素为w,w后面一共不超过2×10
5个元素,我们知道了每个w有(n-1)个,这里要想到每个w都与后的元素位数有关,也就是说后面的所有元素的位数知道了,
我们就能算出(n-1)个w元素的和。怎么做呢,我们只需要统计w后面元素的位数,存放在一起,sum+=让w乘上pow(10,后面每一位元素的位数),让所有的w加起来就可以了,但是这里可能数很大,所以题目要求取模,所以我们要用快速幂。2s够了。
代码如下:
点击查看代码
#include<bits/stdc++.h>
#define int long long
#define y second
using namespace std;
typedef double D;
const int N = 3e5 + 10;
typedef pair<int, int> Pii;
int a[N];
int mod=998244353;
int n;
map<int,int>mp;
int ck(int x){
int res=0;
while(x){
res++;x/=10;
}
return res;
}
int qmi(int x,int k){
int res=1;
while(k){
if(k&1)res=res*x%mod;
x=x*x%mod;
k>>=1;
}
return res;
}
void solved()
{
cin>>n;
for(int i=1;i<=n;i++)cin>>a[i];
int sum=0;
for(int i=1;i<=n;i++){
mp[ck(a[i])]++;
}
for(int i=1;i<=n;i++){
sum+=(i-1)*a[i];
mp[ck(a[i])]--;
for(int j=1;j<=10;j++){
sum=sum+a[i]*qmi(10,j)%mod*mp[j]%mod;
sum%=mod;
}
}
cout<<sum<<"\n";
}
signed main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int t;
t=1;
while (t--)
{
solved();
}
return 0;
}
ABC356——C
https://atcoder.jp/contests/abc356/tasks/abc356_c
这道题,也很有意思,就是问我们有多少种钥匙满足题目的条件,我当时的想法是统计数量,如果它的值为不为0,说明
这个元素只能为一个,因为在某个判断中它一定是正确或错误的。这样我们只需要找到为0的数目统计数量就找到有多少种可能,
但是这种方法是错误的,wa了,我猜想是如果给的元素多于k个,是x的,那么有可能这个元素是正确的,而我判断是错的,我
直接锁死了它的值,就少判断了。
正确的方法是枚举回溯。我基本没有用过这个方法,可能是写的太少了。我们可以这样考虑。
把真key设置为1,假的设置为0,然后一个一个枚举,如果满足上面所有的条件,ans++,这里思路大家都会。
问题在于怎么实现,我们可以这么考虑:
设置一个递归函数,f(x);
一开始主函数中f(1);
然后在递归里面记录被使用vis[x]=true;
然后继续f(x+1);,后面要回溯。
所以我们要vis[x]=fasle;
然后继续f(x+1);当x的数量到n个后就开始判断满不满足上面所有的条件。
点击查看代码
cnt[x]=1;
f(x+1);
cnt[x]=0;
f(x+1);
完整代码如下:
点击查看代码
#include<bits/stdc++.h>
using namespace std;
int c[110];
int a[110][20];
char r[110];
int cnt[20];
int n,m,k;
int ans;
void f(int x){
if(x==n+1){
for(int i=1;i<=m;i++){
int cntt=0;
for(int j=1;j<=c[i];j++){
if(cnt[a[i][j]]==1)cntt++;
}
bool x;
if(cntt>=k)x=1;
else x=0;
if(r[i]=='x' && x==1)return;
if(r[i]=='o' && x==0)return;
}
ans++;
return;
}
//cout << x << " ";
cnt[x]=1;
f(x+1);
cnt[x]=0;
f(x+1);
}
int main(){
cin >> n >> m >> k;
for(int i=1;i<=m;i++){
cin >> c[i];
for(int j=1;j<=c[i];j++){
cin >> a[i][j];
}
cin >> r[i];
}
f(1);
cout << ans;
return 0;
}
还有题目正在补充中。。。。
abc--cf训练日常总结的更多相关文章
- 台州学院maximum cow训练记录
前队名太过晦气,故启用最大牛 我们的组队大概就是18年初,组队阵容是17级生詹志龙.陶源和16级的黄睿博. 三人大学前均无接触过此类竞赛,队伍十分年轻.我可能是我们队最菜的,我只是知道的内容最多,靠我 ...
- python调用NLPIR - ICTCLAS2013实现中文分词
环境:win7.VS2008.Python2.7.3 第一步:照着文档[2]将NLPIR库封装成Python的扩展: 第二步:新建一个名为“nlpir_demo”的目录,将第一步最后得到的名为“nlp ...
- 《You dont know JS》原生函数
原生函数 原生函数,即JavaScript的内建函数(built-in function).常用的原生函数有String().Number().Boolean().Array().Object().F ...
- NLPIR分词(c++接口整理)
C/C++接口——对应的各个函数 函数1-bool NLPIR_Init(const char * sInitDirPath=0, int encoding=GBK_CODE,constchar*sL ...
- CUGBACM Codeforces Tranning 3 题解
链接:http://acm.hust.edu.cn/vjudge/contest/view.action? cid=62515#overview 描写叙述:第三场CF训练了.这次做的挺搞笑的,我记得这 ...
- 集训队8月9日(组合计数+容斥原理+Mobius函数)
刷题数:4 今天看了组合计数+容斥原理+Mobius函数,算法竞赛进阶指南169~179页 组合计数 https://www.cnblogs.com/2462478392Lee/p/11328938. ...
- 2019新生赛 %%%xxh
笔记.md ...
- 「日常训练」ZgukistringZ(Codeforces Round #307 Div. 2 B)
题意与分析(CodeForces 551B) 这他妈哪里是日常训练,这是日常弟中弟. 题意是这样的,给出一个字符串A,再给出两个字符串B,C,求A中任意量字符交换后(不限制次数)能够得到的使B,C作为 ...
- 集训队日常训练20181117 DIV2
大佬们一顿操作猛如虎,拼命AC强啊 4262: 区间异或 Time Limit(Common/Java):1000MS/3000MS Memory Limit:65536KByteTotal ...
- 「日常训练」 Fire!(UVA-11624)
与其说是训练不如说是重温.重新写了Java版本的代码. import java.util.*; import java.math.*; import java.io.BufferedInputStre ...
随机推荐
- MQTT 实践总结
QMQX 文档:https://www.emqx.io/docs/zh/latest/ MQTT 入门:https://www.emqx.com/zh/mqtt-guide 通过案例理解 MQTT 主 ...
- go 通过指针修改结构体小写字段的值
package main import ( "fmt" "unsafe" ) type W struct { b int32 c int64 } func ma ...
- Android 13 - Media框架(8)- MediaExtractor(2)
关注公众号免费阅读全文,进入音视频开发技术分享群! 上一篇 MediaExtractor 笔记中我们学习了 extractor 以及 source 调用的层次结构,这一节我们会看一看部分的实现细节. ...
- 任务Task系列之使用CancellationToken取消Task
本文参考书籍<CLR via C#> Task的取消采用一种形如令牌(Token)的方式.首先先构建一个CancellationTokenSource实例,然后任务中执行的方法必须能接受一 ...
- C#命令行参数解析库System.CommandLine介绍
命令行参数 平常在日常的开发过程中,会经常用到命令行工具.如cmd下的各种命令. 以下为sc命令执行后的截图,可以看到,由于没有输入任何附带参数,所以程序并未执行任何操作,只是输出了描述和用法. 系统 ...
- 算法学习笔记(39): 2-SAT
SAT 问题,也就是可满足性问题 Boolean Satisfiability Problem,是第一个被证明的 NPC 问题. 但是特殊的 2-SAT 我们可以通过图论的知识在线性复杂度内求解,构造 ...
- vuex中的数据在页面刷新后数据消失
用sessionstorage 或者 localstorage 存储数据 存储: sessionStorage.setItem( '名', JSON.stringify(值) ) 使用: sessio ...
- 项目管理--PMBOK 读书笔记(13)【项目相关方管理】
1.相关方分矩阵 工具与技术 核查表 又叫检查表,计数表,收集属性数据,解决问题. 焦点小组&访谈: 特点:慢,焦点小组是一对多,访谈时多对多. 抽样统计&控制图: 控制图反应 ...
- 燕千云ITAM:解锁数字化时代下企业竞争新优势
数字化时代下,企业的IT资产管理(ITAM)尤为关键.企业通过在成长的每个阶段实施有效的IT资产管理策略,以确保资源的最优化利用和风险的有效控制,并在竞争激烈的市场环境中保持优势.然而实际实践中,企业 ...
- org.elasticsearch.client.transport.NoNodeAvailableException: None of the configured nodes are available es端口号及集群名称
org.elasticsearch.client.transport.NoNodeAvailableException: None of the configured nodes are availa ...