享受爆零的快感

老叶本来是让初三的打的,然后我SB的去凑热闹了

TM的T2写炸了(去你妹的优化),T1连-1的分都忘记判了,T3理所当然的不会

光荣革命啊!

T1

思维图论题,CHJ dalao给出了正解但-1输成0了缅怀

而且这题不能用读优玄学

思路也很新奇,先跑一遍MST,判断是否有无解的情况

然后看一下MST中与1相连的边有几条

如果小于k那么我们把所有与1相连的边减上一个值使它们优先被选,然后跑MST

大于k就加上去即可

注意到这个值可以二分,因此不停做MST即可

CODE

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=5005,M=100005;
const double EPS=1e-5;
struct data
{
int l,r,s;
double add;
}a[M];
int n,m,k,cnt,father[N],tot;
long long ans;
inline bool comp(data a,data b)
{
return a.s+a.add<b.s+b.add;
}
inline int getfather(int k)
{
return father[k]==k?k:father[k]=getfather(father[k]);
}
inline int MST(double x)
{
register int i; int res=0,tot=0;
for (i=1;i<=m;++i)
if (a[i].l==1||a[i].r==1) a[i].add=x;
sort(a+1,a+m+1,comp);
for (i=1;i<=n;++i)
father[i]=i; ans=0;
for (i=1;i<=m;++i)
{
int fx=getfather(a[i].l),fy=getfather(a[i].r);
if (fx!=fy)
{
if (a[i].l==1||a[i].r==1) ++res;
ans+=a[i].s; ++tot;
father[fx]=fy;
}
}
if (tot!=n-1) return -1;
return res;
}
int main()
{
freopen("path.in","r",stdin); freopen("path.out","w",stdout);
register int i;
scanf("%d%d%d",&n,&m,&k);
for (i=1;i<=m;++i)
{
scanf("%d%d%d",&a[i].l,&a[i].r,&a[i].s);
if (a[i].l==1||a[i].r==1) ++tot;
}
if (tot<k||MST(0)==-1) { puts("-1"); return 0; }
double l=-100000.0,r=100000.0;
while (r-l>EPS)
{
double mid=(l+r)/2.0;
int t=MST(mid);
if (t==k) { printf("%lld",ans); break; }
if (t>k) l=mid; else r=mid;
}
return 0;
}

T2

这么小的数据范围,就是套路的状压DP

只有我一个人想到记忆化搜索暴力玄学搜索么

好吧又是我ZZ了

首先发现n的范围只有15,果断状压成01串表示第几个串选或不选

而后预处理一个数组g[i][j]表示当t[i]上的字符为j时,与其它串的匹配情况(用二进制下压缩01串表示)

例如,四个串为

?a?

ab?

aa?

??b

例如

  • g[2]['a']=1101(与第四个,第三个,第一个串分别匹配)=13

  • g[1]['a']=1111=15

然后我们设DP数组f[i][j]表示匹配到第i位时(第i位尚未匹配)所有串的匹配情况为j(二进制下的01串)时方案总数

则有f[i][j]可以转移出

f[i+1][j&g[i][ch]]+=f[i][j]('a'<=ch<='z')

因为这里只要一个位置不匹配那就整个串都不匹配,因此只有两边都是1才满足要求

最后ans+=所有j的1的个数恰好为k个的f[len+1][j]

C++没有以字符为下标的数组,因此所有字符减去'a'即可

CODE

#include<cstdio>
#include<cstring>
using namespace std;
const int N=20,D=50,mod=1000003;
int g[D+5][30],f[D+5][(1<<N+1)+5],n,k,ans,t;
char s[N][55],ch;
inline int count(int x)
{
int tot=0;
while (x) tot+=x&1,x>>=1;
return tot;
}
int main()
{
freopen("question.in","r",stdin); freopen("question.out","w",stdout);
register int i,j; scanf("%d",&t);
while (t--)
{
memset(f,0,sizeof(f));
memset(g,0,sizeof(g));
scanf("%d%d",&n,&k);
for (i=1;i<=n;++i)
scanf("%s",s[i]+1); int len=strlen(s[1]+1);
for (i=1;i<=len;++i)
for (ch='a';ch<='z';++ch)
for (j=1;j<=n;++j)
if (s[j][i]=='?'||ch==s[j][i]) g[i][ch-'a']|=1<<j-1;
f[1][(1<<n)-1]=1; ans=0;
for (i=1;i<=len;++i)
for (j=0;j<1<<n;++j)
if (f[i][j]) for (ch='a';ch<='z';++ch)
f[i+1][j&g[i][ch-'a']]=(f[i+1][j&g[i][ch-'a']]+f[i][j])%mod;
for (i=0;i<1<<n;++i)
if (count(i)==k) ans=(ans+f[len+1][i])%mod;
printf("%d\n",ans);
}
return 0;
}

T3

这就是传说中的神题么

暴力的想法都是有的,但是就是刚不出来(只有YZC dalao拿了2分)

标算是DP+KMP+矩阵乘法(快速幂),还是不可食用的

想要标算的同学看BZOJ1009黄学长题解

EZ 2018 05 06 NOIP2018 慈溪中学集训队互测(五)的更多相关文章

  1. EZ 2018 05 26 NOIP2018 模拟赛(十六)

    这次难道就是传说中的标准分大赛?而且这次比赛的链接不翼而飞了 一堆人153pts然后就有Rank4?看来这个Rank4不值钱了,才涨了50+的Rating. 不过还好最后5min的时候想出了T1正解, ...

  2. EZ 2018 05 20 NOIP2018 模拟赛(十五)

    这次的比赛充满着玄学的气息,玄学链接 首先讲一下为什么没有第十四场 其实今天早上9点时看到题目就叫了:原题! 没错,整套试卷都做过,我还写了题解 然后老叶就说换一套,但如果仅仅是这样就没什么 但等13 ...

  3. EZ 2018 05 13 NOIP2018 模拟赛(十三)

    这次的比赛真心水,考时估分240,然后各种悠闲乱逛 然后测完T1数组开小了炸成40,T2,T3都没开long long,T2炸成20,T3爆0 掉回1600+的深渊,但是还有CJJ dalao比我更惨 ...

  4. EZ 2018 05 04 NOIP2018 模拟赛(十二)

    这次的试卷应该是激励我们一下的,链接 然后大家的分数就都很高,然后我就210被一群秒A T2的240大佬爆踩 掉了5rating但Rank竟然发杀了 X_o_r dalao && YZ ...

  5. EZ 2018 05 01 NOIP2018 模拟赛(十一)

    莫名其妙暴涨Rating 其实题目都挺好挺简单的,但是越简单就越容易ZZ 不理解问什么第一题这么多人找环 不过T2是真心细节题,T3太难了 题目戳这里 T1 仔细分析题意发现那个交换规则就是废话,如果 ...

  6. EZ 2018 04 06 NOIP2018 模拟赛(七)

    我是链接 这次是真的惨,码了将近2hours的可持久化线段树炸掉了! 而且本地拍了一万年也没发现哪里炸了. T1 压位的入门题,话说这道题能拿个99分就可以了(100分要FFT) 对于暴力,就是暴力找 ...

  7. 【loj2461】【2018集训队互测Day 1】完美的队列

    #2461. 「2018 集训队互测 Day 1」完美的队列 传送门: https://loj.ac/problem/2461 题解: 直接做可能一次操作加入队列同时会弹出很多数字,无法维护:一个操作 ...

  8. 【2018集训队互测】【XSY3372】取石子

    题目来源:2018集训队互测 Round17 T2 题意: 题解: 显然我是不可能想出来的……但是觉得这题题解太神了就来搬(chao)一下……Orzpyz! 显然不会无解…… 为了方便计算石子个数,在 ...

  9. EZ 2018 07 06 NOIP模拟赛

    又是慈溪那边给的题目,这次终于没有像上次那样尴尬了, T1拿到了较高的暴力分,T2没写炸,然后T3写了一个优雅的暴力就203pts,Rank3了. 听说其它学校的分数普遍100+,那我们学校还不是强到 ...

随机推荐

  1. 使用 jQuery Ajax 异步登录,并验证用户输入信息(maven)

    使用 jQuery Ajax 异步登录,并验证用户输入信息(maven) 本篇内容: (1)上一篇是使用同步的请求实现登录,并由 Servlet 决定登陆后下一步做哪些事情,本篇使用 jQuery A ...

  2. 【Python】控制鼠标点击

    from pymouse import PyMouse m = PyMouse() a = m.position() #获取当前坐标的位置 print(a) m.move(50, 500) #鼠标移动 ...

  3. CSS| 解决子级用css float浮动 而父级div没高度不能自适应高度

    解决子级用css float浮动 而父级div没高度不能自适应高度 解决子级对象使用css float浮动 而父级div不能自适应高度,不能被父级内容撑开解决方法,父级div没有高度解决方法. 最外层 ...

  4. pt-heartbeat --update --daemonize 只执行一次秒退的问题

    使用pt-heartbeat帮助测试MySQL从库delay时长- 第一次运行测试成功,运行顺畅. 过几天再次用--update测试时,发现pt-heartbeat只update一次就自己退出了,-- ...

  5. Android分区

    1. Android 分区: 2. Android各个分区的作用: 2.1 modem分区 实现手机必需的通信功能,大家通常所的刷RADIO就是刷写modem分区,在所有适配的ROM中这部分是不动,否 ...

  6. sysbench压力测试工具安装及使用

    使用sysbench指定连接的时候不需要写上mysql-socket参数 如果自己使用sysbench来测试mysql性能的话,建议使用源码编译比较好,版本为0.4版本. 步骤是: .yum inst ...

  7. MySQL基础之 存储引擎

    MyISAM存储引擎 缺点:不支持事务,不支持外键.只支持表级锁. 优点:访问速度快,多用于select.insert语句的高负载操作.仅仅支持全文索引. MyISAM缓存在内存的是索引,不是数据.而 ...

  8. 移动web前端开发时注意事项

    在智能手机横行的时代,作为一个web前端,不会编写移动web界面,的确是件悲催的事情.当公司准备做一个微信的微网站时,作为一个多年经验的web前端码农,我迷茫了,真心不知道从何下手. 接下来就是搜一堆 ...

  9. swift类型擦除的定义-swift的类型擦除只是一个类型高低阶转换的游戏。

    所谓swift的类型擦除是指: moand转换: 通过技术手段(通常是包装器),将具体类型的类型信息擦除掉了,只将类型的(某一个侧面的)抽象信息(通常指的是类型尊从的协议.接口.或基类)暴露出来. A ...

  10. MyBatis实战之动态SQL

    如果使用JDBC或者其他框架,很多时候你得根据需要去拼接SQL,这是一个麻烦的事情,而MyBatis提供对SQL语句动态的组装能力,而且它只有几个基本的元素,非常简单明了,大量的判断都可以在MyBat ...