NOIP2014
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的更多相关文章
- NOIP2014初赛分数线及金华上线名单
NOIP2014初赛分数线及金华上线名单 分数线:提高组81.5,普及组93 这分数线还能再高些吗?悲催的浙江. 金华上线普及组名单: 地市 姓名 学校 年级 参赛语种 成绩 金华 成浩鹏 稠州丹溪校 ...
- [NOIP2014]寻找道路(图论)
题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点连通. 2 .在满足条 ...
- vijos1907[noip2014]飞扬的小鸟(完全背包)
描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便宣告 ...
- [NOIP2014] 提高组 洛谷P2038 无线网络发射器选址
题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ...
- CCF关于NOIP2014复赛报名的通知
CCF关于NOIP2014复赛报名的通知 CCF NOIP2014复赛全部实行网上注册.报名.未通过网上报名的选手将不具备参赛和申诉资格. 系统注册须知: NOIP2014复赛注册时间:2014年 ...
- NOIP2014感想
NOIP2014转眼就结束了,让人不由感慨时间之快,仿佛几天前还是暑假,几天后就已经坐在考场里了. 从暑假8月开始写博客,发了一些解题报告什么的,但这篇文章不再会是“题目大意 & 解题过程 & ...
- 全国信息学奥林匹克联赛 ( NOIP2014) 复赛 模拟题 Day1 长乐一中
题目名称 正确答案 序列问题 长途旅行 英文名称 answer sequence travel 输入文件名 answer.in sequence.in travel.in 输出文件名 answer. ...
- NOIP2014 行记
不知道OI是啥或者信息学竞赛是啥的可以按`Ctrl+W`. <del>很早开始写的..准备出分之后再发布.</del> 谨以此文纪念我信息学竞赛的第一次正式考试. 背景音乐底部 ...
- bzoj 3751: [NOIP2014]解方程 同余系枚举
3.解方程(equation.cpp/c/pas)[问题描述]已知多项式方程:a ! + a ! x + a ! x ! + ⋯ + a ! x ! = 0求这个方程在[1, m]内的整数解(n 和 ...
- [NOIP2014][DP]飞扬的小鸟
[NOIP2014]飞扬的小鸟 ——!x^n+y^n=z^n 题目描述: Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画 ...
随机推荐
- Java GC回收机制
优秀Java程序员必须了解的GC工作原理 一个优秀的Java程序员必须了解GC的工作原理.如何优化GC的性能.如何与GC进行有限的交互,因为有一些应用程序对性能要求较高,例如嵌入式系统.实时系统等,只 ...
- APMServ 支持.htaccess伪静态
假如你的APMServ安装在X盘APMServ5.2.6目录的话请按以下步骤做. X:\APMServ5.2.6\Apache\conf\httpd.conf 文件找到你所在的虚拟目录修改以下这个地 ...
- h1/title,b/strong,i/em 的区别
< strong > 表示html页面上的强调(emphasized text), < em > 表示句子中的强调(即强调语义) 1.b和strong的区别 盲人朋友使用阅读设 ...
- C#.NET 大型通用信息化系统集成快速开发平台 4.0 版本 - 组织机构的名称编号是否允许重复?
通常情况下,一个公司内部的部门名称,编号是不可能重复的.但是是在多公司的情况下,很可能有部门名称重复的问题存在,这时需要允许部门名称重复. 例如一个大型IT公司,在2个地区都有研发部或者客户服务部,这 ...
- saltstack安装配置(halite)
saltstack官方提供了一个简单的web UI--halite.但是给出的安装配置方法实在没法实现,在网上找了几篇博客,见文章末尾的参考链接,可以用起来了.但是功能有点简单.这篇文章记录安装配置h ...
- android 中退出程序的两种方式
转自:http://blog.sina.com.cn/s/blog_5da93c8f0100t76l.html 思考:如何安全的退出程序? finish是Activity的类,仅仅针对Activity ...
- 深度学习(deep learning)
最近deep learning大火,不仅仅受到学术界的关注,更在工业界受到大家的追捧.在很多重要的评测中,DL都取得了state of the art的效果.尤其是在语音识别方面,DL使得错误率下降了 ...
- 80端口未占用,apache无法启动解决办法
网上很多关于apache无法启动的原因,新手遇到最多的是80端口被占用. 今天为了解决apache和tomcat端口共存问题,修改了httpd.conf的配置,由于增加位置没有做明显标识,重启apac ...
- 模块度与Louvain社区发现算法
Louvain算法是基于模块度的社区发现算法,该算法在效率和效果上都表现较好,并且能够发现层次性的社区结构,其优化目标是最大化整个社区网络的模块度. 模块度(Modularity) 模块度是评估一个社 ...
- TensorFlow的开源与Hadoop的开源
最近看TensorFlow代码的时候,用Git pull下来最新的master一看,哇好多的更新,然后点击去之前看到一半的cc文件继续看,好多地方都改变了.但是一看Git log,有好多巨大的comm ...