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 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画 ...
随机推荐
- log4j.properties 详解与配置步骤(转)
找的文章,供参考使用 转自 log4j.properties 详解与配置步骤 一.log4j.properties 的使用详解 1.输出级别的种类 ERROR.WARN.INFO.DEBUGERROR ...
- BZOJ 1009 【HNOI2008】 GT考试
Description 阿申准备报名参加GT考试,准考证号为N位数X1X2....Xn(0<=Xi<=9),他不希望准考证号上出现不吉利的数字.他的不吉利数学A1A2...Am(0< ...
- Protocol in Objective-C
Objecttive-C Protocal 相似 Java Interface
- iis7 运行 php5.5 的方法
首先添加IIS. 控制面板-〉程序-〉打开或关闭Windows功能 1. 勾选“Internet 信息服务” 2. 勾选“IIS 管理控制台” Internet 信息服务-〉Web 管理工具 ...
- Qt5 新特性
Qt 5 已经临近发布,其最大的特点就是模块化.将原来庞大的模块更细分为不同的部分,同时,一个大版本的升级,当然少不了添加.删除各个功能类.文本简单介绍 Qt5 的特性,其具体内容来自 Qt5 官方 ...
- 知乎日报win10版 - 天天读报【开源】
业余时间写的一个知乎日报win10版客户端,支持收藏,评论,点赞等. 商店地址:https://www.microsoft.com/zh-cn/store/apps/%E5%A4%A9%E5%A4%A ...
- WPF学习之路由事件
原文:http://www.cnblogs.com/lxy131/archive/2010/08/10/1796754.html WPF中新添加了一种事件---路由事件 路由事件与一般事件的区别在于: ...
- css 图片的无缝滚动
转载:http://blog.sina.com.cn/s/blog_6387e82401013kx8.html js的图片的横向或者竖向的无缝滚动图片. ttp://zx.bjmylike.com/ ...
- jsonp的优缺点
转载:http://www.w3cfuns.com/notes/18271/df9ecd8f0ca5e523ae75745a3996c47c.html JSONP的优缺点 1.优点 ...
- Java 增强型的for循环 for each
Java 增强型的for循环 for each For-Each循环 For-Each循环也叫增强型的for循环,或者叫foreach循环. For-Each循环是JDK5.0的新特性(其他新特性比如 ...