转圈游戏

传送门

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 练习的更多相关文章

  1. NOIP 2013 货车运输【Kruskal + 树链剖分 + 线段树 】【倍增】

    NOIP 2013 货车运输[树链剖分] 树链剖分 题目描述 Description A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在 ...

  2. Luogu 1979 NOIP 2013 华容道(搜索,最短路径)

    Luogu 1979 NOIP 2013 华容道(搜索,最短路径) Description 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面 ...

  3. [Noip 2013 Day1-3] 货车运输 做法总结

    [Noip 2013 Day1-3] 货车运输 做法总结 Online Judge:Luogu-1967 Label:启发式合并,离线,整体二分,按秩合并,倍增,最大生成树 打模拟离线赛时做到,顺便总 ...

  4. 【CodeVS 3290】【NOIP 2013】华容道

    http://codevs.cn/problem/3290/ 据说2013年的noip非常难,但Purpleslz学长还是AK了.能A掉这道题真心orz. 设状态$(i,j,k)$表示目标棋子在$(i ...

  5. 【NOIP 2013 DAY2 T3】 华容道(spfa)

    题目描述 [问题描述] 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少需要多少时间. 小 ...

  6. 水题挑战1:NOIP 2013 选择客栈

    丽江河边有\(n\) 家很有特色的客栈,客栈按照其位置顺序从 \(1\) 到 \(n\) 编号.每家客栈都按照某一种色调进行装饰(总共 \(k\) 种,用整数 \(0 \sim k-1\) 表示),且 ...

  7. NOIP 2013 货车运输 最大生成树加DFS巧妙AC

    #include<set> #include<map> #include<cmath> #include<queue> #include<stac ...

  8. 【CodeVS 3289】【NOIP 2013】花匠

    http://codevs.cn/problem/3289/ dp转移,树状数组维护前缀max和后缀max进行优化,$O(nlogn)$. #include<cstdio> #includ ...

  9. NOIp 2013 #3 转圈游戏 Label:模拟

    题目描述 n 个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n 个位置编号,从0 到 n-1.最初,第 0 号小伙伴在第 0 号位置,第 1 号小伙伴在第 1 号位置,……,依此 ...

  10. NOIp 2013 #2 花匠 Label:爆0的Water

    题目描述 花匠栋栋种了一排花,每株花都有自己的高度.花儿越长越大,也越来越挤.栋栋决定 把这排中的一部分花移走,将剩下的留在原地,使得剩下的花能有空间长大,同时,栋栋希 望剩下的花排列得比较别致. 具 ...

随机推荐

  1. Oracle数据库导出导入

    需求为将数据库A中的数据导出为*.dmp文件.然后将*.dmp文件导入到数据库B. 1.导出数据库A     在cmd窗体输入下面命令: 导出所有数据库 exp username/password@数 ...

  2. JMS解决系统间通信问题

    近期在给公司项目做二次重构,将原来庞大的系统拆分成几个小系统.系统与系统之间通过接口调用,系统间通信有非常多方式,如系统间通信接口做成请求controller,只是这样不方便也不安全,经常使用的方式是 ...

  3. 使用汇编分析c代码的内存分布

    arm平台下使用反汇编分析c内存分布: arm:使用arm-linux-objdump命令将编译完毕之后的elf文件,进行反汇编. 之后重定向到tmp.s文件里. 第一步变量例如以下c文件. vim ...

  4. 3D数学读书笔记——多坐标系和向量基础

    本系列文章由birdlove1987编写,转载请注明出处. 文章链接: http://blog.csdn.net/zhurui_idea/article/details/24662453 第一个知识点 ...

  5. #定位系统性能瓶颈# sysdig

    安装方法: curl -s https://s3.amazonaws.com/download.draios.com/stable/install-sysdig | sudo bash [root@l ...

  6. 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 ...

  7. SPOJ GSS 系列

    来怒做GSS系列了: GSS1:https://www.luogu.org/problemnew/show/SP1043 这题就是维护一个 sum , mx , lmx , rmx,转移时用结构体就好 ...

  8. PCB Genesis加邮票孔(弧形连接位宽度校正)实现算法

    采用弧形作为加接位,当两边距离较远时,会造成连接位变窄,由于之前算法是基于连接位间距做为半径画弧, 必然存在这个缺陷,这边做少许的改进解决此问题. 现将几个种增加孤形连接位的图形对比如下: 一.两边外 ...

  9. E20170915-hm

    client n. 顾客; 当事人; 诉讼委托人; [计算机] 客户端; seal  n. 密封; 印章; 海豹; 封条;  v. 密封; 盖章; 决定; 封上(信封); sheet  n. 纸; 被 ...

  10. thymeleaf公共页面元素抽取

    1.抽取公共片段 使用thymeleaf的th:fragment为样抽取的公共片段命名, 如下把div标签命名为 copy,就可以获取到div整个里的内容<div th:fragment=&qu ...