Noip 2013 练习
转圈游戏
Solution
快速幂
Code
//By Menteur_Hxy
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define F(i,a,b) for(register int i=(a);i<=(b);i++)
using namespace std;
typedef long long LL;
LL read() {
LL x=0,f=1; char c=getchar();
while(!isdigit(c)) {if(c=='-')f=-f;c=getchar();}
while(isdigit(c)) x=(x<<1)+(x<<3)+c-48,c=getchar();
return x*f;
}
LL n,m,k,ans;
LL qpow(LL a,LL b,LL MOD) {
LL res=1;
while(b) {
if(b&1) res=res*a%MOD;
a=a*a%MOD; b>>=1;
}
return res;
}
int main() {
n=read(),m=read(),k=read(),ans=read();
(ans+=m*qpow(10,k,n)%n)%=n;
printf("%lld\n",ans);
return 0;
}
火柴排队
Solution
建立映射关系,求逆序对个数
Code
//By Menteur_Hxy
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define F(i,a,b) for(register int i=(a);i<=(b);i++)
#define R(i,a,b) for(register int i=(b);i>=(a);i--)
using namespace std;
typedef long long LL;
LL read() {
LL x=0,f=1; char c=getchar();
while(!isdigit(c)) {if(c=='-')f=-f;c=getchar();}
while(isdigit(c)) x=(x<<1)+(x<<3)+c-48,c=getchar();
return x*f;
}
const LL N=100010,MOD=99999997;
int n;
int to[N],C[N];
LL ans;
struct Dat{LL id,da;}A[N],B[N];
struct BIT{
LL da[N];
BIT() {memset(da,0,sizeof(da));}
void upd(int x,int k) {for(;x<=N;x+=(x&-x)) da[x]+=k;}
LL qry(int x) {LL res=0;for(;x>0;x-=(x&-x)) res+=da[x];return res;}
}T;
bool cmp(Dat a,Dat b) {return a.da<b.da;}
int main() {
n=read();
F(i,1,n) A[i].id=i,A[i].da=read();
F(i,1,n) B[i].id=i,B[i].da=read();
sort(A+1,A+1+n,cmp);
sort(B+1,B+1+n,cmp);
F(i,1,n) C[B[i].id]=A[i].id;
R(i,1,n) {
ans+=T.qry(C[i]-1);
T.upd(C[i],1);
}
printf("%lld",ans%MOD);//忘%wa一次QAQ
return 0;
}
货车运输
Solution
建最大生成树,对询问找lca,暴力
Code
//By Menteur_Hxy
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define F(i,a,b) for(register int i=(a);i<=(b);i++)
#define R(i,a,b) for(register int i=(b);i>=(a);i--)
#define E(i,u) for(register int i=head[u],v;i;i=T[i].nxt)
using namespace std;
typedef long long LL;
LL read() {
LL x=0,f=1; char c=getchar();
while(!isdigit(c)) {if(c=='-')f=-f;c=getchar();}
while(isdigit(c)) x=(x<<1)+(x<<3)+c-48,c=getchar();
return x*f;
}
const int N=10010,M=50010,INF=0x3f3f3f3f;
int n,m,q,cnt;
int fa[N],f[N][33],dis[N],head[N],dep[N],vis[N];
struct Edg{int fr,to,cst,nxt;}E[M],T[N<<1];
bool cmp(Edg a,Edg b) {return a.cst>b.cst;}
int getf(int x) {return fa[x]==x?x:fa[x]=getf(fa[x]);}
void dfs(int u,int pre) {
vis[u]=1;
E(i,u) if((v=T[i].to)!=pre) {//T,E不分QAQ
dep[v]=dep[u]+1;
f[v][0]=u;
dis[v]=T[i].cst;
dfs(v,u);
}
}
int getm(int x,int lca) {
int res=INF;
while(x!=lca) {
res=min(res,dis[x]);
x=f[x][0];
}
return res;
}
int lca(int x,int y) {
int l=x,r=y;
if(dep[x]<dep[y]) swap(x,y);
int nd=dep[x]-dep[y];
for(int i=0;nd;nd>>=1,i++) if(nd&1) x=f[x][i];
if(x!=y) {
R(i,0,32) if(f[x][i]!=f[y][i])
x=f[x][i],y=f[y][i];
x=f[x][0];
}
return min(getm(l,x),getm(r,x));
}
int main() {
n=read(),m=read();
F(i,1,m) {
int a=read(),b=read(),c=read();
E[i]=(Edg){a,b,c};
}
sort(E+1,E+1+m,cmp);
F(i,1,n) fa[i]=i;
F(i,1,m) {
int fu=getf(E[i].fr),fv=getf(E[i].to);
if(fu==fv) continue; fa[fu]=fv;
int a=E[i].fr,b=E[i].to,c=E[i].cst;
T[++cnt]=(Edg){a,b,c,head[a]}; head[a]=cnt;
T[++cnt]=(Edg){b,a,c,head[b]}; head[b]=cnt;
if(cnt==((n-1)<<1)) break;
}
F(i,1,n) if(!vis[i]) dfs(i,0);//可能有多棵树
for(register int j=1;(1<<j)<=n;j++)
F(i,1,n) if(f[i][j-1]) f[i][j]=f[f[i][j-1]][j-1];
q=read();
while(q--) {
int x=read(),y=read();
if(getf(x)!=getf(y)) puts("-1");
else printf("%d\n",lca(x,y));
}
return 0;
}
积木大赛
Solution
显然是差分后把正值加起来
Code
//By Menteur_Hxy
#include <vector>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#define F(i,a,b) for(register int i=(a);i<=(b);i++)
#define R(i,a,b) for(register int i=(b);i>=(a);i--)
using namespace std;
typedef long long LL;
int read() {
int x=0,f=1; char c=getchar();
while(!isdigit(c)) {if(c=='-')f=-f;c=getchar();}
while(isdigit(c)) x=(x<<1)+(x<<3)+c-48,c=getchar();
return x*f;
}
const int N=100010;
int n;
int da[N];
LL ans;
int main() {
n=read();
F(i,1,n) da[i]=read();
R(i,1,n) da[i]=da[i]-da[i-1];
F(i,1,n) if(da[i]>0) ans+=da[i];
printf("%lld",ans);
return 0;
}
花匠
Solution
分(xian)析(ran)可知第一个数一定要有
分别讨论第一个数是波峰还是波谷
Code
//By Menteur_Hxy
#include <vector>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#define F(i,a,b) for(register int i=(a);i<=(b);i++)
#define R(i,a,b) for(register int i=(b);i>=(a);i--)
using namespace std;
typedef long long LL;
typedef pair<int,int> PII;
int read() {
int x=0,f=1; char c=getchar();
while(!isdigit(c)) {if(c=='-')f=-f;c=getchar();}
while(isdigit(c)) x=(x<<1)+(x<<3)+c-48,c=getchar();
return x*f;
}
const int N=100010;
int n,opt,t1,t2;
int da[N];
int main() {
n=read();
F(i,1,n) da[i]=read();
F(i,1,n) {
if(da[i]>da[i-1]&&opt==0) t1++,opt=1;
else if(da[i]<da[i-1]&&opt==1) t1++,opt=0;
}
opt=0;da[0]=da[1]+1;
F(i,1,n) {
if(da[i]>da[i-1]&&opt==1) t2++,opt=0;
else if(da[i]<da[i-1]&&opt==0) t2++,opt=1;
}
printf("%d",max(t1,t2));
return 0;
}
华容道
Solution
60-80分:bfs
正解回头再说
Code
60-80分
//By Menteur_Hxy
#include <queue>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#define F(i,a,b) for(register int i=(a);i<=(b);i++)
using namespace std;
int read() {
int x=0,f=1; char c=getchar();
while(!isdigit(c)) {if(c=='-')f=-f;c=getchar();}
while(isdigit(c)) x=(x<<1)+(x<<3)+c-48,c=getchar();
return x*f;
}
const int N=40;
int mv[5]={0,1,0,-1,0};
int n,m,q,ex,ey,sx,sy,tx,ty,ans,now;
int vis[N][N][N][N];
bool map[N][N];
struct P{
int x0,y0,x1,y1,dep;
P(int a0=0,int b0=0,int a1=0,int b1=0,int deep=0) {
x0=a0,y0=b0,x1=a1,y1=b1,dep=deep;
}
};
queue <P> Q;
void bfs() {
while(!Q.empty()) Q.pop();
Q.push(P(ex,ey,sx,sy,0));
while(!Q.empty()) {
P u=Q.front(); Q.pop();
if(vis[u.x0][u.y0][u.x1][u.y1]==now) continue;
vis[u.x0][u.y0][u.x1][u.y1]=now;
// cout<<u.x0<<" "<<u.y0<<" "<<u.x1<<" "<<u.y1<<" "<<u.dep<<endl;
if(u.x1==tx&&u.y1==ty) {ans=u.dep;return ;}
if(u.x0==u.x1&&abs(u.y1-u.y0)==1)
Q.push(P(u.x1,u.y1,u.x0,u.y0,u.dep+1));
if(u.y0==u.y1&&abs(u.x1-u.x0)==1)
Q.push(P(u.x1,u.y1,u.x0,u.y0,u.dep+1));
F(i,0,3) {
int x=u.x0+mv[i],y=u.y0+mv[i+1];
if(!map[x][y]||(x==u.x1&&y==u.y1)) continue;
Q.push(P(x,y,u.x1,u.y1,u.dep+1));
}
}
}
int main() {
n=read(),m=read(),q=read();
F(i,1,n) F(j,1,m) map[i][j]=read();
for(now=1;now<=q;now++) {
scanf("%d %d %d %d %d %d",&ex,&ey,&sx,&sy,&tx,&ty);
// printf("%d %d %d %d %d %d\n",ex,ey,sx,sy,tx,ty);
ans=-1; bfs();
printf("%d\n",ans);
}
return 0;
}
Noip 2013 练习的更多相关文章
- NOIP 2013 货车运输【Kruskal + 树链剖分 + 线段树 】【倍增】
NOIP 2013 货车运输[树链剖分] 树链剖分 题目描述 Description A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在 ...
- Luogu 1979 NOIP 2013 华容道(搜索,最短路径)
Luogu 1979 NOIP 2013 华容道(搜索,最短路径) Description 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面 ...
- [Noip 2013 Day1-3] 货车运输 做法总结
[Noip 2013 Day1-3] 货车运输 做法总结 Online Judge:Luogu-1967 Label:启发式合并,离线,整体二分,按秩合并,倍增,最大生成树 打模拟离线赛时做到,顺便总 ...
- 【CodeVS 3290】【NOIP 2013】华容道
http://codevs.cn/problem/3290/ 据说2013年的noip非常难,但Purpleslz学长还是AK了.能A掉这道题真心orz. 设状态$(i,j,k)$表示目标棋子在$(i ...
- 【NOIP 2013 DAY2 T3】 华容道(spfa)
题目描述 [问题描述] 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少需要多少时间. 小 ...
- 水题挑战1:NOIP 2013 选择客栈
丽江河边有\(n\) 家很有特色的客栈,客栈按照其位置顺序从 \(1\) 到 \(n\) 编号.每家客栈都按照某一种色调进行装饰(总共 \(k\) 种,用整数 \(0 \sim k-1\) 表示),且 ...
- NOIP 2013 货车运输 最大生成树加DFS巧妙AC
#include<set> #include<map> #include<cmath> #include<queue> #include<stac ...
- 【CodeVS 3289】【NOIP 2013】花匠
http://codevs.cn/problem/3289/ dp转移,树状数组维护前缀max和后缀max进行优化,$O(nlogn)$. #include<cstdio> #includ ...
- NOIp 2013 #3 转圈游戏 Label:模拟
题目描述 n 个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n 个位置编号,从0 到 n-1.最初,第 0 号小伙伴在第 0 号位置,第 1 号小伙伴在第 1 号位置,……,依此 ...
- NOIp 2013 #2 花匠 Label:爆0的Water
题目描述 花匠栋栋种了一排花,每株花都有自己的高度.花儿越长越大,也越来越挤.栋栋决定 把这排中的一部分花移走,将剩下的留在原地,使得剩下的花能有空间长大,同时,栋栋希 望剩下的花排列得比较别致. 具 ...
随机推荐
- Oracle数据库导出导入
需求为将数据库A中的数据导出为*.dmp文件.然后将*.dmp文件导入到数据库B. 1.导出数据库A 在cmd窗体输入下面命令: 导出所有数据库 exp username/password@数 ...
- JMS解决系统间通信问题
近期在给公司项目做二次重构,将原来庞大的系统拆分成几个小系统.系统与系统之间通过接口调用,系统间通信有非常多方式,如系统间通信接口做成请求controller,只是这样不方便也不安全,经常使用的方式是 ...
- 使用汇编分析c代码的内存分布
arm平台下使用反汇编分析c内存分布: arm:使用arm-linux-objdump命令将编译完毕之后的elf文件,进行反汇编. 之后重定向到tmp.s文件里. 第一步变量例如以下c文件. vim ...
- 3D数学读书笔记——多坐标系和向量基础
本系列文章由birdlove1987编写,转载请注明出处. 文章链接: http://blog.csdn.net/zhurui_idea/article/details/24662453 第一个知识点 ...
- #定位系统性能瓶颈# sysdig
安装方法: curl -s https://s3.amazonaws.com/download.draios.com/stable/install-sysdig | sudo bash [root@l ...
- HDU 5533/ 2015长春区域 G.Dancing Stars on Me 暴力
Dancing Stars on Me Problem Description The sky was brushed clean by the wind and the stars were col ...
- SPOJ GSS 系列
来怒做GSS系列了: GSS1:https://www.luogu.org/problemnew/show/SP1043 这题就是维护一个 sum , mx , lmx , rmx,转移时用结构体就好 ...
- PCB Genesis加邮票孔(弧形连接位宽度校正)实现算法
采用弧形作为加接位,当两边距离较远时,会造成连接位变窄,由于之前算法是基于连接位间距做为半径画弧, 必然存在这个缺陷,这边做少许的改进解决此问题. 现将几个种增加孤形连接位的图形对比如下: 一.两边外 ...
- E20170915-hm
client n. 顾客; 当事人; 诉讼委托人; [计算机] 客户端; seal n. 密封; 印章; 海豹; 封条; v. 密封; 盖章; 决定; 封上(信封); sheet n. 纸; 被 ...
- thymeleaf公共页面元素抽取
1.抽取公共片段 使用thymeleaf的th:fragment为样抽取的公共片段命名, 如下把div标签命名为 copy,就可以获取到div整个里的内容<div th:fragment=&qu ...