题目名称

PA

青春

三部曲

名称

huakai

taritari

truetears

输入

huakai.in

taritari.in

truetears.in

输出

huakai.out

taritari.out

truetears.out

每个测试点时限

1秒

1秒

1秒

内存限制

512MB

512MB

512MB

测试点数目

10

10

10

每个测试点分值

10

10

10

是否有部分分

题目类型

传统

传统

传统

注意事项(请务必仔细阅读):

PA

【题目描述】

汉诺塔升级了:现在我们有个圆盘和个柱子,每个圆盘大小都不一样,大的圆盘不能放在小的圆盘上面,个柱子从左到右排成一排。每次你可以将一个柱子上的最上面的圆盘移动到右边或者左边的柱子上(如果移动之后是合法的话)。现在告诉你初始时的状态,你希望用最少的步数将第大的盘子移动到第根柱子上,问最小步数。

【输入格式】

第一行一个正整数,代表询问的组数。

接下来组数据,每组数据第一行一个整数。

接下来一行每行个正整数,代表每个柱子上圆盘的大小。

【输出格式】

输出共行,代表每次的答案。如果方案不存在,输出“”。

【样例输入】

4

3

2 1 3

2

7 8

2

10000 1000

3

97 96 95

【样例输出】

4

0

-1

20

【样例解释】

无。

暴力map(状态不好)60

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<map>
using namespace std;
int T,n,B[],tail,head=,flag;
string c,cc;
struct P{
int x,o;
}A[];
struct node{
int a[][];
}q[];
map<string,int>f,s;
int cmp(const P &a,const P &b){
return a.x<b.x;
}
void Bfs(){
node now;
for(int i=;i<=n;i++){
now.a[i][]=i;
now.a[i][]=;
char tmp=now.a[i][]+'';c+=tmp;c+='';
}
f[c]=;s[c]=;q[++tail]=now;
while(head<=tail){
now=q[head++];
cc.clear();
for(int i=;i<=n;i++){
for(int j=;j<=now.a[i][];j++){
char tmp=now.a[i][j]+'';cc+=tmp;
}
cc+='';
}
for(int i=;i<n;i++){
if(now.a[i][]==)continue;
int R=now.a[i+][now.a[i+][]];
if(R<now.a[i][now.a[i][]]&&R)continue;
node r;memcpy(r.a,now.a,sizeof(r.a));
r.a[i+][]++;
r.a[i+][r.a[i+][]]=r.a[i][r.a[i][]];
r.a[i][]--;c.clear();
for(int j=;j<=n;j++){
for(int k=;k<=r.a[j][];k++){
char tmp=r.a[j][k]+'';c+=tmp;
}
c+='';
}
if(f[c]==){
f[c]=;s[c]=s[cc]+;q[++tail]=r;
}
}
for(int i=;i<=n;i++){
if(now.a[i][]==)continue;
int L=now.a[i-][now.a[i-][]];
if(L<now.a[i][now.a[i][]]&&L)continue;
node r;memcpy(r.a,now.a,sizeof(r.a));
r.a[i-][]++;
r.a[i-][r.a[i-][]]=r.a[i][r.a[i][]];
r.a[i][]--;
c.clear();
for(int j=;j<=n;j++){
for(int k=;k<=r.a[j][];k++){
char tmp=r.a[j][k]+'';c+=tmp;
}
c+='';
}
if(f[c]==){
f[c]=;s[c]=s[cc]+;q[++tail]=r;
}
}
}
}
int main()
{
//freopen("huakai.in","r",stdin);
//freopen("huakai.out","w",stdout);
scanf("%d",&T);
int TT=T;
while(T--){
flag=;scanf("%d",&n);
if(T==TT-)Bfs();
printf("%d\n",tail);
break;
for(int i=;i<=n;i++){
scanf("%d",&A[i].x);A[i].o=i;
}
sort(A+,A++n,cmp);
for(int i=;i<=n;i++)
B[A[i].o]=i;
for(int i=;i<=n;i++)
if(i!=B[i]){
flag=;break;
}
if(!flag){
printf("0\n");
continue;
}
c.clear();
for(int i=;i<=n;i++){
char tmp=B[i]+'';c+=tmp;c+='';
}
if(s[c]==)printf("-1\n");
else printf("%d\n",s[c]);
}
return ;
}

换个状态 int判重

/*
开始10 写wa了
改到60 没法改了
后来发现 就800000个状态 不应该超时 ~ ~ map慢死
Hash也慢 双向bfs也过不了…..
但是状态写的不好 int存不下
后来听dmh说了他的状态 感觉很好 而且int能存下
改啊改改啊改 就A了
以后慎用map
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 10000010
using namespace std;
int T,n,B[],C[],top[],p[],M[],q[maxn],head,tail,S[maxn];
bool f[maxn];
struct P{
int x,o;
}A[];
int cmp(const P &a,const P &b){
return a.x<b.x;
}
void Insert(int s){
memset(top,,sizeof(top));
int len=;
int tmp=s;
while(tmp){
p[++len]=tmp%;
tmp/=;
}
reverse(p+,p++len);
for(int i=len;i>=;i--)
top[p[i]]=i;
for(int i=;i<=len;i++)
if(i==top[p[i]]){
if(p[i]!=&&(top[p[i]-]>i||!top[p[i]-])){
int r=s-M[len-i];
if(!f[r]){
f[r]=;S[r]=S[s]+;
q[++tail]=r;
}
}
if(p[i]!=len&&(top[p[i]+]>i||!top[p[i]+])){
int r=s+M[len-i];
if(!f[r]){
f[r]=;S[r]=S[s]+;
q[++tail]=r;
}
}
}
}
void Ready(){
int s=;M[]=;
for(int i=;i<=;i++){
M[i]=M[i-]*;
s=s*+i;
q[++tail]=s;
f[s]=;S[s]=;
}
while(head<tail){
s=q[++head];
Insert(s);
}
}
int main()
{
freopen("huakai.in","r",stdin);
freopen("huakai.out","w",stdout);
Ready();
scanf("%d",&T);
while(T--){
scanf("%d",&n);
for(int i=;i<=n;i++){
scanf("%d",&A[i].x);
A[i].o=i;
}
sort(A+,A++n,cmp);
for(int i=;i<=n;i++)
B[A[i].o]=i;
for(int i=;i<=n;i++)
C[B[i]]=i;
int s=;
for(int i=;i<=n;i++)
s=s*+C[i];
if(f[s]==)printf("-1\n");
else printf("%d\n",S[s]);
}
return ;
}

青春

【问题描述】

现在有一个被的小格子分割的矩形纸片,每个小格子内包含一个整数。现在你可以进行一系列的折叠,每次折叠的折痕必须是分割两行或者两列小格子的分割线。

在折叠完之后,所有重叠的小格子被看作一个单独的格子,并且这个格子的价值为重叠的小格子的价值和。

你想要知道,在所有可能得到的新格子中,格子价值的最大值为多少。

【输入格式】

输入文件的第一行有两个整数和,分别表示初始的矩形纸片的长和宽。接下来的行,每行有个数字表示初始的小格子内的整数。

【输出格式】

输出一行表示所能得到的格子价值的最大值。

【样例输入】

2 2

1 -2

3 -4

【样例输出】

4

【样例解释】

无。

【数据规模与约定】

对于的数据,格子内的数字权值的绝对值不超过。

数据点

数据点

1

3

3

6

15

100

2

10

10

7

20

100

3

10

10

8

20

500

4

15

15

9

20

500

5

20

20

10

20

500

Dfs

/*
T2 不会正解 也没时间打暴力了
就骗了点分 不粘了
正解Dfs 递归压缩行数变成一行
然后枚举这一行怎么个折法
不断更新最大值
注意奇数列由偶数列更新来 偶数列由奇数列更新来 */
#include<cstdio>
#include<cstring>
#define maxn 510
using namespace std;
int n,m,g[maxn][maxn],f[maxn],s[maxn],ans=-0x3f3f3f3f,mx[];
int max(int a,int b){
return a>b?a:b;
}
void Dfs(int x){
for(int i=;i<=m;i++)
s[i]+=g[x][i];
mx[]=mx[]=-0x3f3f3f3f;
for(int i=;i<=m;i++){
f[i]=s[i];
f[i]+=max(mx[(i&)^],);
ans=max(ans,f[i]);
mx[(i&)]=max(mx[i&],f[i]);
}
for(int i=x+;i<=n;i+=)Dfs(i);
for(int i=;i<=m;i++)
s[i]-=g[x][i];
}
int main()
{
freopen("taritari.in","r",stdin);
freopen("taritari.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
scanf("%d",&g[i][j]);
for(int i=;i<=n;i++)Dfs(i);
printf("%d\n",ans);
return ;
}

三部曲

【问题描述】

因为外来的入侵,国王决定在某些城市加派士兵。所有城市初始士兵数量为。当城市被加派了名士兵时。城市的所有子城市需要被加派名士兵。这些子城市的所有子城市需要被加派名士兵。以此类推。

当然,加派士兵的同时,国王也需要不断了解当前的情况。于是他随时可能询问以城市i为根的子树中的所有城市共被加派了多少士兵。

你现在是国王的军事大臣,你能回答出国王的每个询问么?

【输入格式】

第一行,包含两个整数代表城市数量以及国王的命令的数量。

第二行个整数,表示号每个节点的父亲节点。

接下来的行,每行代表国王的一个命令,命令分两种:

在城市加入个士兵

询问以城市为根的子树中所有士兵数量的和。

【输出格式】

对于每个,输出答案。

【样例输入】

7 10

1 1 2 2 5 5

Q 1

A 2 1

Q 1

Q 2

Q 5

A 5 0

Q 5

A 3 1

Q 1

Q 2

【样例输出】

0

11

11

8

10

14

13

【样例解释】

无。

暴力50

#include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
#define maxn 50010
using namespace std;
int n,m,num,head[maxn],s[maxn];
vector<int>son[maxn];
struct node{
int v,pre;
}e[maxn*];
char C[];
int init(){
int x=,f=;char s=getchar();
while(s<''||s>''){if(s=='-')f=-;s=getchar();}
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x*f;
}
void Add(int from,int to){
num++;e[num].v=to;
e[num].pre=head[from];
head[from]=num;
}
void Dfs(int now,int from){
for(int i=head[now];i;i=e[i].pre){
int v=e[i].v;
if(v==from)continue;
son[now].push_back(v);
Dfs(v,now);
}
}
int Query(int x){
int r=s[x];
for(int i=;i<son[x].size();i++)
r+=Query(son[x][i]);
return r;
}
void Insert(int x,int y){
s[x]+=y;
for(int i=;i<son[x].size();i++)
Insert(son[x][i],y+);
}
int main()
{
freopen("truetears.in","r",stdin);
freopen("truetears.out","w",stdout);
n=init();m=init();
int fat,x,y;
for(int i=;i<n;i++){
fat=init();
Add(i+,fat);Add(fat,i+);
}
Dfs(,);
for(int i=;i<=m;i++){
scanf("%s",C);
if(C[]=='Q'){
x=init();
printf("%d\n",Query(x));
}
if(C[]=='A'){
x=init();y=init();
Insert(x,y);
}
}
return ;
}

正解还在研究23333~~

晚安~~

10.4 noip模拟试题的更多相关文章

  1. 10.26 noip模拟试题

    enc[问题背景]zhx 和他的妹子聊天.[问题描述]考虑一种简单的加密算法.假定所有句子都由小写英文字母构成,对于每一个字母,我们将它唯一地映射到另一个字母.例如考虑映射规则:a->b, b- ...

  2. 10.27 noip模拟试题

    1.铺瓷砖(tile.cpp/c/pas)[问题描述]有一面很长很长的墙. 你需要在这面墙上贴上两行瓷砖. 你的手头有两种不同尺寸的瓷砖,你希望用这两种瓷砖各贴一行.瓷砖的长可以用分数表示,贴在第一行 ...

  3. 10.24 noip模拟试题

    尼玛pdf依旧不会粘23333 /* 每段合并到总的里面 假设总的有X个 这一段有Y个 一共有X+1个空 那么就有 C(X+1,1)+C(X+1,2)+C(X+1,3)+...+C(X+1,Y) 这样 ...

  4. 10.18 noip模拟试题

    分火腿 (hdogs.pas/.c/.cpp) 时间限制:1s:内存限制 64MB 题目描述: 小月言要过四岁生日了,她的妈妈为她准备了n根火腿,她想将这些火腿均分给m位小朋友,所以她可能需要切火腿. ...

  5. 10.13 noip模拟试题

    Porble 1时间与空间之旅(tstrip.*) 题目描述 公元22××年,宇宙中最普遍的交通工具是spaceship.spaceship的出现使得星系之间的联系变得更为紧密,所以spaceship ...

  6. 10.11 noip模拟试题

    4题均为128M,1s 1. 锻炼计划(exercise.pas) 身体是革命的本钱,OIers不要因为紧张的学习和整天在电脑前而忽视了健康问题.小x设计了自己的锻炼计划,但他不知道这个计划是否可行, ...

  7. 10.8 noip模拟试题

      1.花 (flower.cpp/c/pas) [问题描述] 商店里出售n种不同品种的花.为了装饰桌面,你打算买m支花回家.你觉得放两支一样的花很难看,因此每种品种的花最多买1支.求总共有几种不同的 ...

  8. 10.3 noip模拟试题

    希望[题目描述]网页浏览器者有后退与前进按钮,一种实现这两个功能的方式是用两个栈,“前进栈”.“后退栈”.这里你需要实现以下几个功能:BACK: 如果“后退栈”为空则忽略此命令. 否则将当前两面压入“ ...

  9. 10.25 noip模拟试题

    今天题目略水2333 依旧不粘题目了23333 T1 /*数学题 给定n个斜率 求有多少个三元组 保证两两斜率不同 ans=C(n,3)-ΣC(len[i],2)*(n-len[i])-ΣC(len[ ...

随机推荐

  1. 【andorid】Attribute is missing the Android namespac

    初学安卓,错误颇多 出现这个问题,是因为xml节点属性单词拼写错了,比如android我写成了adnorid,当然就错误了.

  2. C#与C++、Java之比较概览

    转自C#与C++.Java之比较概览 C#与C++.Java之比较概览 Ben Albahari 著  荣耀 译 本文翻译时间较早.欢迎指出任何误失.谢谢. 感谢以下人士的支持和反馈(按字母先后顺序) ...

  3. BZOJ 3122 随机数生成器

    http://www.lydsy.com/JudgeOnline/problem.php?id=3122 题意:给出p,a,b,x1,t 已知xn=a*xn-1+b%p,求最小的n令xn=t 首先,若 ...

  4. ExecutorService介绍2

    Thread和ExecutorService的区别 使用Thread,当子线程执行结束后,主线程如果没有其他执行任务,主线程会终止. /** * Created by litao on 15/10/7 ...

  5. 14.6.7 Configuring the Number of Background InnoDB IO Threads 配置InnoDB IO Threads的数量

    14.6.7 Configuring the Number of Background InnoDB IO Threads 配置InnoDB IO Threads的数量 InnoDB 使用后台线程来服 ...

  6. android 通过eclipse混淆代码 打包 + proguard 总结

    android应用程序的混淆打包 1 . 在工程文件project.properties中加入下proguard.config=proguard.cfg , 如下所示: target=android- ...

  7. Android开发详解之onTouch和onClick详解

    android组件中的onTouch,onClick,onLongClick事件发生先后顺序和关联: 一,onTouch返回false 首先是onTouch事件的down事件发生,此时,如果长按,触发 ...

  8. python换行写入文件

    今天用python做写入文件时,碰到,写入的东西不能换行,打开写入的文件都是一行.后来发现需要在写入的字符后面加上+'\n'. 另外python需要追加写入文件的时候,是用这个方法f = open(' ...

  9. 通过ComponentName获取相应的Widget

    最近在锁屏上研究,如果预置widget,研究了好久,终于找到方法了,先上代码: private int getAppWidgetFromComName(ComponentName providerCo ...

  10. Unity3d shader之卡通着色Toon Shading

    卡通着色的目的是为了让被着色物体显得过渡的不那么好,明暗交界线很明显,等等卡通风格的一系列特征, 也叫Non-photorealisticrendering非真实渲染 重点要做到两点: 1.    描 ...