在这么考下去可以去混女队了2333

两天总分rank14,退役稳稳的

的确就是没状态。满脑子都是《包围保卫王国》ddp/LCT/ST,没好好考试。

我太菜了写题也写不出来考试也考不好(显然《保卫王国》40分钟是调不出来的)

也不知道为什么特别想A了它。。。莫名的执念

也许所谓的OI也就是一念之间的问题吧。

T1:ZYB修围墙

答案有可能是偶数。扩展一面墙的时候相对的墙不一定要扩展。

边长为a时,6次扩展的收益分别为a,a-1,a,a,a,a

 #include<cstdio>
main(){
freopen("wall.in","r",stdin);freopen("wall.out","w",stdout);
int n,cnt=,i=;scanf("%d",&n);
for(;cnt<n;++i,cnt+=i/-(i%==));
printf("%d\n",i);
}

T2:ZYB和售货机

每个物品多数情况下只会被以最低的买入价格买入。这样形成建边关系。

然后如果图里没有环那么收益就是最低价买入后卖出。(40pts)

否则,对于环上的所有点,其中有一个必须以次低价买入。

统计一下这样的亏损,取环上最小的亏损值从答案里减去即可。

 #include<cstdio>
#include<iostream>
using namespace std;
#define S 100005
int f[S],c[S],d[S],a[S],n,mn[S],ord[S],al[S],fir[S],l[S],to[S],ec;long long ans;
int sta[S],top,sec[S];
void link(int a,int b){l[++ec]=fir[a];fir[a]=ec;to[ec]=b;}
void dfs(int p){
al[p]=;sta[++top]=p;
for(int i=fir[p];i;i=l[i])if(!al[to[i]])dfs(to[i]);
else if(to[i]==p)continue;
else if(al[to[i]]==){
int mn=<<,j=;sta[top+]=to[i];
while(sta[j]!=to[i])j++;
for(;j<=top;++j)
mn=min(mn,d[sta[j+]]-c[sta[j]]-max(,-sec[sta[j+]]+d[sta[j+]]));
ans-=mn;
}
al[p]=;top--;
}
int main(){
freopen("goods.in","r",stdin);freopen("goods.out","w",stdout);
scanf("%d",&n);
for(int i=;i<=n;++i)scanf("%d%d%d%d",&f[i],&c[i],&d[i],&a[i]),mn[i]=sec[i]=;
for(int i=;i<=n;++i)if(mn[f[i]]>c[i])mn[f[i]]=c[i],ord[f[i]]=i;
for(int i=;i<=n;++i)if(mn[i]<d[i])ans+=1ll*a[i]*(d[i]-mn[i]),link(ord[i],i);
for(int i=;i<=n;++i)if(sec[f[i]]>c[i]&&i!=ord[f[i]])sec[f[i]]=c[i];
for(int i=;i<=n;++i)if(!al[i])top=,dfs(i);
printf("%lld\n",ans);
}

样例的环是假的(不是最大收益环,有负收益)

所以提供一组AKT的极其简单的调试用hack数据:(干掉了我的考场40分代码)

input:


output:


T3:ZYB玩字符串

cbx没脸粘我代码。(不知道为什么他不让我只重复两遍)

cbx没脸粘我代码。

看懂题目并且打一个搜索就可以获得90分。(有哪个剪枝不明白是干什么用的的话可以去问我)

 #include<bits/stdc++.h>
using namespace std;
map<string,int>M;
int lim,n,len,cnt[],tcnt[],used[],fin;string s,chk,ans;
int gcd(int a,int b){return b?gcd(b,a%b):a;}
bool sch(int l,int num){
if(num+fin>lim)return false;
if(l==n)return true;
if(chk[]==s[l]){
used[num+]=;
if(sch(l+,num+))return true;
used[num+]=;
}
if(chk[used[num]]==s[l]){
used[num]++;int nt=;
if(used[num]==len)num--,fin++,nt=;
if(sch(l+,num))return true;
if(nt)num++,fin--;
used[num]--;
}
return false;
}
int main(){
freopen("string.in","r",stdin);freopen("string.out","w",stdout);
int t;scanf("%d",&t);
while(t--){
cin>>s;n=s.length();reverse(s.begin(),s.end());ans="";M.clear();
for(int i=;i<;++i)cnt[i]=;
for(int i=;i<n;++i)cnt[s[i]-'a']++;
int g=;
for(int pt=;pt<;++pt)g=gcd(g,cnt[pt]);
for(len=;len<=n;++len)if(n%len==){
lim=n/len;if(lim>g)continue;
for(int st=;st+len-<n;++st)if(s[st]==s[]&&s[n-]==s[st+len-]){
chk="";
for(int i=;i<;++i)tcnt[i]=;
for(int i=st;i<=st+len-;++i)chk+=s[i],tcnt[s[i]-'a']++;
if(M[chk])goto ed;M[chk]=;
for(int i=;i<;++i)if(cnt[i]&&(!tcnt[i]||cnt[i]%tcnt[i]||cnt[i]/tcnt[i]!=lim))goto ed;
for(int i=;i<=lim+;++i)used[i]=;fin=;
if(sch(,)){reverse(chk.begin(),chk.end());if(ans.empty())ans=chk;else ans=min(ans,chk);}ed:;
}
if(!ans.empty())break;
}cout<<ans<<endl;
}
}

除了测试点9一共190ms

考场上想到应该是个dp但是想不到定义。dp[i][j]表示[i,j]段除了前(j-i)%len位完美匹配了整串前缀以外剩下的位置也可以被完美消除。

考虑每一位加入的贡献。(我的字符串下标从0开始,s表示原串,chk表示当前)

dp[i][j]|=dp[i][j-1]&(s[j]==chk[(j-i)%len])。就是在最后多匹配了一位。

dp[i][j]|=dp[i][j-k*len]&dp[j-k*len+1][j]。就是后面有几个完整的段被吃掉了。

从含义上理解,这已经包含了所有情况。

初始状态就是所有空串都是合法的,其余都是0。

加上考场上的剪枝,效率极其优秀。

到底有多优秀,去看cbx卡成了什么样子吧。。。

cbx没脸粘我代码。

 #include<bits/stdc++.h>
using namespace std;
map<string,int>M;
int lim,n,len,cnt[],tcnt[];string s,chk,ans;
int gcd(int a,int b){return b?gcd(b,a%b):a;}
bool dp[][];
bool sch(){
for(int i=;i<n;++i)for(int j=i;j<n;++j)dp[i][j]=;
for(int i=;i<n;++i)dp[i][i-]=;
dp[][]=;
for(int i=;i<n;++i){
if(i)for(int j=;j<=i;++j)dp[j][i]|=dp[j][i-]&(s[i]==chk[(i-j)%len]);
if(s[i]==chk[len-])for(int j=;j<=i;++j)for(int k=;j<=i-k*len+;++k)
dp[j][i]|=dp[j][i-k*len]&dp[i-k*len+][i];
}
return dp[][n-];
}
int main(){
freopen("string.in","r",stdin);freopen("string.out","w",stdout);
int t;scanf("%d",&t);
while(t--){
cin>>s;n=s.length();ans="";M.clear();
for(int i=;i<;++i)cnt[i]=;
for(int i=;i<n;++i)cnt[s[i]-'a']++;
int g=;
for(int pt=;pt<;++pt)g=gcd(g,cnt[pt]);
for(len=;len<=n;++len)if(n%len==){
lim=n/len;if(lim>g)continue;
for(int st=;st+len-<n;++st)if(s[st]==s[]&&s[n-]==s[st+len-]){
chk="";
for(int i=;i<;++i)tcnt[i]=;
for(int i=st;i<=st+len-;++i)chk+=s[i],tcnt[s[i]-'a']++;
if(!ans.empty()&&chk>ans)goto ed;
if(M[chk])goto ed;M[chk]=;
for(int i=;i<;++i)if(cnt[i]&&(!tcnt[i]||cnt[i]%tcnt[i]||cnt[i]/tcnt[i]!=lim))goto ed;
if(sch())if(ans.empty())ans=chk;else ans=min(ans,chk);ed:;
}
if(!ans.empty())break;
}cout<<ans<<endl;
}
}

目前是54ms

[考试反思]1113csp-s模拟测试113:一念的更多相关文章

  1. [考试反思]0718 NOIP模拟测试5

    最后一个是我...rank#11 rank#1和rank#2被外校大佬包揽了. 啊...考的太烂说话底气不足... 我考场上在干些什么啊!!! 20分钟“切”掉T2,又27分钟“切”掉T1 切什么切, ...

  2. csp-s模拟测试112 & csp-s模拟测试113

    考前两天模拟. Day1直接炸飞,T1浪费的时间太长,对拍+调试了一个多小时但复杂度还不能过,最后5分钟想出来了解决方案但是已经打不出来了.T2读入出了事故RE0.T3打了假贪心. Day2心态几乎也 ...

  3. [考试反思]0814NOIP模拟测试21

    前两名是外校的240.220.kx和skyh拿到了190的[暴力打满]的好成绩. 我第5是170分,然而160分就是第19了. 在前一晚上刚刚爆炸完毕后,心态格外平稳. 想想前一天晚上的挣扎: 啊啊啊 ...

  4. [考试反思]1109csp-s模拟测试106:撞词

    (撞哈希了用了模拟测试28的词,所以这次就叫撞词吧) 蓝色的0... 蓝色的0... 都该联赛了还能CE呢... 考试结束前15分钟左右,期望得分300 然后对拍发现T2伪了写了一个能拿90分的垃圾随 ...

  5. [考试反思]0909csp-s模拟测试41:反典

    说在前面:我是反面典型!!!不要学我!!! 说在前面:向rank1某脸学习,不管是什么题都在考试反思后面稍微写一下题解. 这次是真的真的运气好... 这次知识点上还可以,但是答题策略出了问题... 幸 ...

  6. [考试反思]0729NOIP模拟测试10

    安度因:哇哦. 安度因:谢谢你. 第三个rank1不知为什么就来了.迷之二连?也不知道哪里来的rp 连续两次考试数学都占了比较大的比重,所以我非常幸运的得以发挥我的优势(也许是优势吧,反正数学里基本没 ...

  7. [考试反思]0714/0716,NOIP模拟测试3/4

    这几天时间比较紧啊(其实只是我效率有点低我在考虑要不要坐到后面去吹空调) 但是不管怎么说,考试反思还是要写的吧. 第三次考试反思没写总感觉缺了点什么,但是题都刷不完... 一进图论看他们刷题好快啊为什 ...

  8. [考试反思]1003csp-s模拟测试58:沉淀

    稳住阵脚. 还可以. 至少想拿到的分都拿到了,最后一题的确因为不会按秩合并和线段树分治而想不出来. 对拍了,暴力都拍了.挺稳的. 但是其实也有波折,险些被卡内存. 如果内存使用不连续或申请的内存全部使 ...

  9. [考试反思]0816NOIP模拟测试23

    210 210 210 170 还可以.暴力打满就rk4了? 但不管怎么说,总算是在改完题之后理直气壮的写考试反思了. T1是个dp,说水也不太水.(当然某脸只要A掉了一道题就要说那是水题) 我的思路 ...

随机推荐

  1. Python3 并发编程2

    目录 进程互斥锁 基本概念 互斥锁的使用 IPC 基本概念 队列 生产者消费者模型 基本概念 代码实现 线程 基本概念 创建线程 线程互斥锁 进程互斥锁 基本概念 临界资源: 一次仅允许一个进程使用的 ...

  2. Spring 学习,看松哥这一篇万余字干货就够了!

    1. Spring 简介 我们常说的 Spring 实际上是指 Spring Framework,而 Spring Framework 只是 Spring 家族中的一个分支而已.那么 Spring 家 ...

  3. H5中被废弃的标签

    <br>换行,已经被<p>标签进行替换 <hr>画线 <font> <b>,<u>,<i>,<s>:加粗 ...

  4. 【Java Web开发学习】Spring配置数据源

    Spring配置数据源 转载:https://www.cnblogs.com/yangchongxing/p/10027495.html =============================== ...

  5. mysql外连接

    一,起因 在学习一个新知识之前,最好先了解一下你为何要学习这个知识,这个知识或技术能帮你做什么,可以给你带来哪些帮助.因此我先交代一下写这篇随笔的起因. 我在做项目的时候遇到了一个比较有意思的情况, ...

  6. 《一头扎进》系列之Python+Selenium框架设计篇3- 价值好几K的框架,狼来了,狼来了....,狼没来,框架真的来了

    1. 简介 前边宏哥一边一边的喊框架,就如同一边一边的喊狼来了!狼来了!.....这回是狼没有来,框架真的来了.从本文开始宏哥将会一步一步介绍,如何从无到有地创建自己的第一个自动化测试框架.这一篇,我 ...

  7. 03-EF Core笔记之查询数据

    EF Core使用Linq进行数据查询. 基本查询 微软提供了一百多个示例来演示查询,地址:https://code.msdn.microsoft.com/101-LINQ-Samples-3fb98 ...

  8. [译]C# 7系列,Part 6: Read-only structs 只读结构

    原文:https://blogs.msdn.microsoft.com/mazhou/2017/11/21/c-7-series-part-6-read-only-structs/ 背景 在.NET世 ...

  9. super performSelector: 解决调用父类私有方法的问题

    super performSelector: 解决objc调用父类私有方法的问题 Objc中[super performSelector: ...]并不会像其他语言一样能良好的工作.super只是编译 ...

  10. 拥抱微服务,CODING 即将上线单项目多仓库功能

    随着数字化时代的全面到来,越来越多的企业开始尝试物联网.人工智能等新兴技术,用以加快自身的转型速度并积极开拓新的市场.互联网的兴起让各个行业的业务场景.用户行为.交互方式等都发生了巨大的变化.线上业务 ...