DAY1

生活大爆炸版石头剪刀布

  直接模拟即可。

// codevs3716
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define MOD 1000000007
#define inf 2147483640
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std; const int maxn=2000;
int c[5][5]={{0,0,1,1,0},
{1,0,0,1,0},
{0,1,0,0,1},
{0,0,1,0,1},
{1,1,0,0,0}};
int a[maxn],b[maxn]; int main() {
int n,na,nb;
scanf("%d%d%d",&n,&na,&nb);
for (int i=0;i<na;i++) scanf("%d",&a[i]);
for (int i=0;i<nb;i++) scanf("%d",&b[i]);
int A=0,B=0;
for (int i=0;i<n;i++) {
A+=c[a[i%na]][b[i%nb]];
B+=c[b[i%nb]][a[i%na]];
}
printf("%d %d",A,B);
return 0;
}

联合权值

  一开始无脑枚举,因为只需要dfs1层,感觉完全不虚,结果被菊花树卡得只有70分,于是怒水一发树形dp。

// codevs3728
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define MOD 10007
#define inf 2147483640
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std; const int maxn=200010;
struct edge {int to,next;}e[maxn<<1];
int head[maxn],n,cnt,w[maxn],ans1,ans2;; void link(int u,int v) {
e[++cnt].to=v;e[cnt].next=head[u];head[u]=cnt;
e[++cnt].to=u;e[cnt].next=head[v];head[v]=cnt;
}
void dfs(int x,int fa,int f) {
ans1=(ans1+w[x]*w[f]);ans2=max(ans2,w[x]*w[f]);
int x1=0,x2=0;
for (int i=head[x];i;i=e[i].next) if (e[i].to!=fa) {
dfs(e[i].to,x,fa);
ans2=max(ans2,x2*w[e[i].to]);
ans1=(ans1+x1*w[e[i].to])%MOD;
x1=(x1+w[e[i].to])%MOD;x2=max(x2,w[e[i].to]);
}
}
int main() {
scanf("%d",&n);
for (int u,v,i=1;i<n;i++) {
scanf("%d%d",&u,&v);
link(u,v);
}
for (int i=1;i<=n;i++) scanf("%d",&w[i]);
dfs(1,0,0);
printf("%d %d",ans2,ans1*2%MOD);
return 0;
}

飞扬的小鸟

  一开始打了个nm²加队列乱搞可以获得85分的高分哦!正解背包。

// codevs3729
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define inf 100000000
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std; const int maxn=10010,maxm=1010;
struct data {int p,l,r;}t[maxn];
int n,m,K,u[maxn],d[maxn],l[maxn],r[maxn],f[maxn][maxm]; int main() {
scanf("%d%d%d",&n,&m,&K);
for (int i=0;i<n;i++) scanf("%d%d",&u[i],&d[i]);
for (int i=0;i<=n;i++) l[i]=0,r[i]=m+1;
for (int x,i=1;i<=K;i++) {
scanf("%d",&x);
scanf("%d%d",&l[x],&r[x]);
}
int cnt=0;
for (int i=1;i<=n;i++) {
for (int j=1;j<=m;j++) {
f[i][j]=inf;
if (j>u[i-1]) f[i][j]=min(f[i][j],min(f[i-1][j-u[i-1]],f[i][j-u[i-1]])+1);
}
for (int j=m-u[i-1];j<=m;j++) f[i][m]=min(f[i][m],min(f[i-1][j],f[i][j])+1);
for (int j=l[i]+1;j<=r[i]-1;j++)
if (j+d[i-1]<=m) f[i][j]=min(f[i][j],f[i-1][j+d[i-1]]);
for (int j=1;j<=l[i];j++) f[i][j]=inf;
for (int j=r[i];j<=m;j++) f[i][j]=inf;
int flag=0;
for (int j=1;j<=m;j++) if (f[i][j]<inf) {flag=1;break;}
if (!flag) {printf("0\n%d",cnt);return 0;}
else if (r[i]!=m+1) cnt++;
}
int ans=inf;
for (int i=1;i<=m;i++) ans=min(ans,f[n][i]);
printf("1\n%d",ans);
return 0;
}

DAY2

无线网络发射选址

  无脑枚举。

// codevs3730
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
#define LL long long
#define MOD 10007
#define inf 2147483640
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std; int f[200][200],n,d; int main() {
scanf("%d%d",&d,&n);
for (int x,y,k,i=1;i<=n;i++) {
scanf("%d%d%d",&x,&y,&k);
f[x][y]=k;
}
int ans=0,tot=0;
for (int i=0;i<=128;i++)
for (int j=0;j<=128;j++) {
int cnt=0;
for (int k=max(i-d,0);k<=min(i+d,128);k++)
for (int l=max(j-d,0);l<=min(j+d,128);l++) cnt+=f[k][l];
if (ans==cnt) tot++;
else if (ans<cnt) ans=cnt,tot=1;
}
printf("%d %d",tot,ans);
return 0;
}

寻找道路

  写得奇丑无比。。还Wa了两发,数组开小了→_→。。先反向连边处理哪些点能走哪些点不能走,然后Dijkstra。

// codevs3731
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
#define LL long long
#define MOD 10007
#define inf 2147483640
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std; const int maxn=10010,maxm=200010;
struct edge {int to,next;}e[maxm<<1];
struct data {
int num,w;
friend bool operator < (const data a,const data b) {
return a.w>b.w;
}
};
int head[maxn],f[maxn],vis[maxn],dis[maxn],u[maxm],v[maxm];
int n,m,cnt,s,t; void link(int u,int v) {
e[++cnt].to=v;e[cnt].next=head[u];head[u]=cnt;
}
void dfs(int x) {
vis[x]=1;
for (int i=head[x];i;i=e[i].next) if (!vis[e[i].to]) dfs(e[i].to);
}
void Dijkstra() {
priority_queue<data> q;
data x=(data){s,0},y;
for (int i=1;i<=n;i++) dis[i]=inf,vis[i]=0;
dis[s]=0;q.push(x);
while (!q.empty() && !vis[t]) {
x=q.top();q.pop();
if (vis[x.num]) continue;
vis[x.num]=1;
for (int i=head[x.num];i;i=e[i].next)
if (f[e[i].to] && dis[e[i].to]>x.w+1) {
dis[e[i].to]=y.w=x.w+1;
y.num=e[i].to;
q.push(y);
}
}
}
int main() {
scanf("%d%d",&n,&m);
for (int i=1;i<=m;i++) {
scanf("%d%d",&u[i],&v[i]);
link(v[i],u[i]);
//link(u,v);
}
scanf("%d%d",&s,&t);swap(s,t);
dfs(s);
memset(head,0,sizeof(head));cnt=0;
for (int i=1;i<=m;i++) link(u[i],v[i]);
for (int i=1;i<=n;i++) {
f[i]=vis[i];
for (int j=head[i];j;j=e[j].next) f[i]&=vis[e[j].to];
}
swap(s,t);
Dijkstra();
printf("%d",dis[t]==inf ? -1 : dis[t]);
return 0;
}

解方程

  一开始一直纠结怎么优化高精度,一直无果。。模了题解没想到是这这样的结果→_→。

  我们发现若将等式左侧模上一个数等于0,那么有可能这个x是解。而在模M的意义下,f[x]与f[x+M]的值是一样的。于是我们就随便搞5个素数,分别预处理出从1~M-1的范围中的解,然后枚举x判断即可。

// codevs3732
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
#define LL long long
#define MOD 10007
#define inf 2147483640
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std; const int maxn=1000010;
int M[5]={9973,9931,9941,9949,9967};
int ans[maxn],a[5][maxn],res[5][maxn],pre[5][maxn];
int n,m; int cal(int t,int x) {
int sum=0;
for (int i=0;i<=n;i++) sum=(sum+a[t][i]*pre[t][i])%M[t];
if (sum<0) sum+=M[t];
return sum;
}
bool check(int x) {
for (int t=0;t<5;t++) if (res[t][x%M[t]]!=0) return 0;
return 1;
}
int main() {
scanf("%d%d",&n,&m);
char ch[10010];
for (int i=0;i<=n;i++) {
scanf("%s",ch+1);
int l=strlen(ch+1);
bool flag=0;
for (int t=0;t<5;t++) {
if (ch[1]!='-') a[t][i]=ch[1]-'0';
else a[t][i]=0,flag=1;
}
for (int t=0;t<5;t++) {
for (int k=2;k<=l;k++) a[t][i]=(a[t][i]*10+ch[k]-'0')%M[t];
if (flag) a[t][i]=-a[t][i];
}
}
for (int t=0;t<5;t++)
for (int x=1;x<M[t];x++) {
pre[t][0]=1;
for (int i=1;i<=n;i++) pre[t][i]=(pre[t][i-1]*x)%M[t];
res[t][x]=cal(t,x);
}
for (int i=1;i<=m;i++) if (check(i)) ans[++ans[0]]=i;
printf("%d\n",ans[0]);
for (int i=1;i<=ans[0];i++) printf("%d\n",ans[i]);
return 0;
}

  

NOIP2014的更多相关文章

  1. NOIP2014初赛分数线及金华上线名单

    NOIP2014初赛分数线及金华上线名单 分数线:提高组81.5,普及组93 这分数线还能再高些吗?悲催的浙江. 金华上线普及组名单: 地市 姓名 学校 年级 参赛语种 成绩 金华 成浩鹏 稠州丹溪校 ...

  2. [NOIP2014]寻找道路(图论)

    题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点连通. 2 .在满足条 ...

  3. vijos1907[noip2014]飞扬的小鸟(完全背包)

    描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便宣告 ...

  4. [NOIP2014] 提高组 洛谷P2038 无线网络发射器选址

    题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ...

  5. CCF关于NOIP2014复赛报名的通知

    CCF关于NOIP2014复赛报名的通知   CCF NOIP2014复赛全部实行网上注册.报名.未通过网上报名的选手将不具备参赛和申诉资格. 系统注册须知: NOIP2014复赛注册时间:2014年 ...

  6. NOIP2014感想

    NOIP2014转眼就结束了,让人不由感慨时间之快,仿佛几天前还是暑假,几天后就已经坐在考场里了. 从暑假8月开始写博客,发了一些解题报告什么的,但这篇文章不再会是“题目大意 & 解题过程 & ...

  7. 全国信息学奥林匹克联赛 ( NOIP2014) 复赛 模拟题 Day1 长乐一中

    题目名称 正确答案  序列问题 长途旅行 英文名称 answer sequence travel 输入文件名 answer.in sequence.in travel.in 输出文件名 answer. ...

  8. NOIP2014 行记

    不知道OI是啥或者信息学竞赛是啥的可以按`Ctrl+W`. <del>很早开始写的..准备出分之后再发布.</del> 谨以此文纪念我信息学竞赛的第一次正式考试. 背景音乐底部 ...

  9. bzoj 3751: [NOIP2014]解方程 同余系枚举

    3.解方程(equation.cpp/c/pas)[问题描述]已知多项式方程:a ! + a ! x + a ! x ! + ⋯ + a ! x ! = 0求这个方程在[1, m]内的整数解(n 和 ...

  10. [NOIP2014][DP]飞扬的小鸟

    [NOIP2014]飞扬的小鸟 ——!x^n+y^n=z^n 题目描述: Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画 ...

随机推荐

  1. JSTL中的TLD配置和使用。

    一,JSTL介绍: JSTL标签库,是日常开发经常使用的,也是众多标签中性能最好的.把常用的内容,放在这里备份一份,随用随查.尽量做到不用查,就可以随手就可以写出来.这算是Java程序员的基本功吧,一 ...

  2. P1835 素数密度_NOI导刊2011提高(04)

    题目描述 给定区间[L,R](L≤R≤2147483647,R-L≤1000000),请计算区间中素数的个数. 输入输出格式 输入格式: 两个数L和R. 输出格式: 一行,区间中素数的个数. 输入输出 ...

  3. 带OUTPUT参数的CLR存储过程

    前面写了一篇<带参数的CLR存储过程>http://www.cnblogs.com/insus/p/4373605.html ,如果我们需要创建一个带OUTPUT返回值. 实现它,可以先了 ...

  4. 在Azure上搭建Orchard CRM入口网站

    这是英文版:Setup Orchard CRM portal website on Azure

  5. Android-完全退出当前应用程序的四种方法

    Android程序有很多Activity,比如说主窗口A,调用了子窗口B,如果在B中直接finish(), 接下里显示的是A.在B中如何关闭整个Android应用程序呢?本人总结了几种比较简单的实现方 ...

  6. 小图标外链API

    网页上有些分享的小图标,比如分享到facebook,weibo,qq空间等功能的时候,图标以前一般是自己做一个css sprite.当一个网站的图标变了的时候,比如facebook变成assbook的 ...

  7. centos7下使用yum安装mysql数据库以及设置远程访问

    CentOS7的yum源中默认好像是没有mysql的.为了解决这个问题,我们要先下载mysql的repo源. 1. 下载mysql的repo源 $ wget http://repo.mysql.com ...

  8. 快速开发之代码生成器(asp.net mvc4 + easyui + knockoutjs)

    一.前言 作为一个码农这么多年,一直在想怎么提高我们的编码效率,关于如何提高编码效率,我自己的几点体会 1.清晰的项目结构,要编写代码的地方集中 2.实现相同功能的代码量少并且清晰易懂 3.重复或有规 ...

  9. 从炉石传说的一个自杀OTK说起

    OTK就是one turn kill,不过这次我们要谈的OTK是自杀,对就是自己把自己给OTK了. 其实程序没有任何错误,只是恰巧碰上了这么个死循环. ps:文章最后有代码git地址 发动条件及效果: ...

  10. Nodejs进阶:基于express+multer的文件上传

    关于作者 程序猿小卡,前腾讯IMWEB团队成员,阿里云栖社区专家博主.欢迎加入 Express前端交流群(197339705). 正在填坑:<Nodejs学习笔记> / <Expre ...