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 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画 ...
随机推荐
- ASP.NET中处理自定义错误的最佳方式
要在ASP.NET中处理好自定义错误(Custom Errors)首先要抛弃使用web.config\customErrors. <customErrors mode="RemoteO ...
- 探索Windows 8.1 Update 新功能点
Windows 8.1 Update 已经使用一段时间了,整体感觉比Windows 8.1 方便了不少,尤其是对鼠标用户来说更是进行了很多优化. 应用磁贴尺寸 在应用磁贴点击鼠标右键,有小.中.宽.大 ...
- c++游戏服务器编程学习笔记(一)TCP/IP
1. c++游戏服务器编程c++运行效率非常高2. TCP传输控制协议IP网际协议Socket 3.Linux 乌班图开源第三方库BOOST 4.80%游戏服务器端用C++工作量最大的地方是具体的游戏 ...
- 基于DDD的.NET开发框架 - ABP模块设计
返回ABP系列 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称. ASP.NET Boilerplate是一个用最佳实践和流行技术开发现代WEB应 ...
- 前端Mvvm QC 设计解析
QC 官网http://time-go.github.io/qc/ QC的具体用法.介绍和源码,大家可以去官网下载 从本节开始,我会和大家一起分享在这个框架设计中用到的技巧,希望这些技巧能个大家带来灵 ...
- extjs store的操作
先来个声明,看着不错,贴过来的,没都测试过. Store.getCount()返回的是store中的所有数据记录,然后使用for循环遍历整个store,从而得到每条记录. 除了使用getCount() ...
- Asp.Net MVC<二> : IIS/asp.net管道
MVC是Asp.net的设计思想,而IIS/asp.net是它的技术平台.理解ASP.NET的前提是对ASP.NET管道式设计的深刻认识.而ASP.NET Web应用大都是寄宿于IIS上的. IIS ...
- Entity Framework在WCF中序列化的问题
问题描述 如果你在WCF中用Entity Framework来获取数据并返回实体对象,那么对下面的错误一定不陌生. 接收对 http://localhost:5115/ReService.svc 的 ...
- 使用事件捕获实时捕获img是否加载完毕, 实现iframe内容高度自动适应
如何判断在html中图片加载完毕呢? 给img图片加onload事件呗. 如何判断一个界面中所有的图片加载完毕呢? 给所有的图片加上onload事件呗. 如果有1000张图片那要怎么绑定事件呢? 我们 ...
- ubuntu15.10下搭建cordova+ionic开发环境
安装jdk 在命令下输入java如果没有安装会提示该命令包含于openjdk软件包 sudo apt-get install openjdk然后按下tab会列出openjdk开头的软件包 我这里就选择 ...