转圈游戏

传送门

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. PKU 2774 Long Long Message (后缀数组练习模板题)

    题意:给你两个字符串.求最长公共字串的长度. by:罗穗骞模板 #include <iostream> #include <stdio.h> #include <stri ...

  2. 浅析android适配器adapter中的那些坑

    做项目中遇到的,折磨了我将近两天,今天把经验分享出来.让大家以后少走点弯路,好了.简单来说一下什么是android的适配器,怎样定义.怎样添加适配器的重用性.怎样去减少程序的耦合性 适配器顾名思义是用 ...

  3. 一句话实现Mysql查询结果带行号

    SELECT @rowno:=@rowno + 1 AS rowno,a.* FROM tableName a,(SELECT @rowno:=0) b

  4. linux驱动由浅入深系列:tinyalsa(tinymix/tinycap/tinyplay/tinypcminfo)音频子系统之一【转】

    本文转载自:http://blog.csdn.net/radianceblau/article/details/64125411 目前linux中主流的音频体系结构是ALSA(Advanced Lin ...

  5. Stockbroker Grapevine(floyd)

    http://poj.org/problem?id=1125 题意: 首先,题目可能有多组测试数据,每个测试数据的第一行为经纪人数量N(当N=0时, 输入数据结束),然后接下来N行描述第i(1< ...

  6. mybatis一对多关系的关联查询

    问题描述:实现两张表的关联查询 学生表: 班级表: 要实现学生管理信息中有所在班级的名称,即如下图所示 1.对应学生表的pojo类写全班级表中的字段(适用于要连接的表字段较少的情况) sql语句直接在 ...

  7. SQL之LEFT JOIN,EIGHT JOIN,INSERT JOIN的区别

    left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录inner join(等值连接) 只 ...

  8. 5.14web相关概念

    1.软件架构 1.C/S:客户端/服务器端 2.B/S:浏览器/服务器端 2.资源分类 1.静态资源:所有用户访问后,得到的结果都是一样的,称为静态资源.静态资源可以直接被浏览器解析如:html,cs ...

  9. javascript 核心概念(1)-数据类型

    语法 (1)到现在为止,大多数浏览器也还是支持到ECMAScript 第三版的标准. 核心概念就是一个语言的基本工作原理,涉及语法,操作符,数据类型. (2)javascript的一切--变量,函数名 ...

  10. Tour UVA - 1347

    John Doe, a skilled pilot, enjoys traveling. While on vacation, he rents a small plane and starts vi ...