PA
【题目描述】
汉诺塔升级了:现在我们有N个圆盘和N个柱子,每个圆盘大小都不一样,大的圆盘不能放在小的圆盘上面,N个柱子从左到右排成一排。每次你可以将一个柱子上的最上面的圆盘移动到右边或者左边的柱子上 (如果移动之后是合法的话) 。 现在告诉你初始时的状态, 你希望用最少的步数将第i小的盘子移动到第i根柱子上,问最小步数。
【输入格式】
第一行一个正整数T,代表询问的组数。
接下来T组数据,每组数据第一行一个整数N。
接下来一行每行N个正整数,代表每个柱子上圆盘的大小。
【输出格式】
输出共N行,代表每次的答案。如果方案不存在,输出“−1” 。
【样例输入】
4
3
2 1 3
2
7 8
2
10000 1000
3
97 96 95
【样例输出】
4
0
-1
20
【样例解释】
无。
【数据范围与规定】
对于70%的数据,N的值都是相等的。
对于100%的数据,1 ≤ T≤ 6 × 10e3 ,1 ≤ n ≤ 7。

【题目分析】

Bfs 因为很多很多数据 所以预处理所有的情况 然后O(1)查询

预处理的时候 1到7的都处理了

先存进去的 1 12 123 1234 12345 123456 1234567

这几个 然后把他拆成数组 place[i]表示第i小的在哪

因为移动的时候先动每个柱子最顶端的 所以维护top[i]表示i柱子最上面一个是谁

然后每个状态枚举移动那个 左移还是右移

那个bat数组是转移的时候简化操作用的

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm> using namespace std; const int maxn=; int n,top[],place[],res[maxn],q[maxn],bit[],front,tail,w[],z[]; bool use[maxn]; bool cmp(int a,int b)
{
return w[a]<w[b];
} void analyze(int s)
{
int x=;
int ss=s;
for (int a=;a<=;a++)
top[a]=;
while (ss)
{
x++;
place[x]=ss%;
ss/=;
}
reverse(place+,place+x+);
for (int a=x;a>=;a--)
top[place[a]]=a;
for (int a=;a<=x;a++)
if (a==top[place[a]])
{
int p=place[a];
if (p!= && (a<top[p-] || !top[p-]))
{
int news=s-bit[x-a];
if (!use[news])
{
q[++tail]=news;
use[news]=true;
res[news]=res[s]+;
}
}
if (p!=x && (a<top[p+] || !top[p+]))
{
int news=s+bit[x-a];
if (!use[news])
{
q[++tail]=news;
use[news]=true;
res[news]=res[s]+;
}
}
}
} int main()
{
freopen("huakai.in","r",stdin);
freopen("huakai.out","w",stdout); front=,tail=;
int status=;
bit[]=;
for (int a=;a<=;a++)
{
bit[a]=bit[a-]*;
status=status*+a;
q[++tail]=status;
use[status]=true;
}
for (;front<=tail;)
{
int s=q[front++];
analyze(s);
}
int t;
scanf("%d",&t);
for (;t--;)
{
scanf("%d",&n);
for (int a=;a<=n;a++)
scanf("%d",&w[a]),z[a]=a;
sort(z+,z+n+,cmp);
int s=;
for (int a=;a<=n;a++)
s=s*+z[a];
if (!use[s]) printf("-1\n");
else printf("%d\n",res[s]);
} return ;
}

青春
【问题描述】
现在有一个被1× 1的小格子分割的矩形纸片,每个小格子内包含一个整数。现在你可以进行一系列的折叠, 每次折叠的折痕必须是分割两行或者两列小格子的分割线。在折叠完之后,所有重叠的小格子被看作一个单独的格子,并且这个格子的价值为重叠的小格子的价值和。你想要知道,在所有可能得到的新格子中,格子价值的最大值为多少。
【输入格式】
输入文件的第一行有两个整数N和M,分别表示初始的矩形纸片的长和宽。接下来的N行,每行有M个数字表示初始的小格子内的整数。
【输出格式】
输出一行表示所能得到的格子价值的最大值。
【样例输入】
2 2
1 -2
3 -4
【样例输出】
4
【样例解释】
无。

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int N=;
const int M=;
const int INF=0x3f3f3f3f;
int n,m,z[N][M],sum[M],f[M],ans;
void solve(int pos)
{
for(int i=;i<=m;i++)
sum[i]+=z[pos][i];
int maxv[]={-INF,-INF};
for(int i=;i<=m;i++)
{
f[i]=sum[i];
if(maxv[(i&)^]>) f[i]+=maxv[(i&)^];
maxv[i&]=max(maxv[i&],f[i]);
ans=max(ans,f[i]);
}
for(int i=pos+;i<=n;i+=) solve(i);
for(int i=;i<=m;i++) sum[i]-=z[pos][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",&z[i][j]);
ans=-INF;
memset(sum,,sizeof sum);
for(int i=;i<=n;i++) solve(i);
printf("%d\n",ans);
}

三部曲
【问题描述】
因为外来的入侵,国王决定在某些城市加派士兵。所有城市初始士兵数量为0。当城市i被加派了k名士兵时。城市?的所有子城市需要被加派k + 1名士兵。这些子城市的所有子城市需要被加派k +2名士兵。以此类推。当然,加派士兵的同时,国王也需要不断了解当前的情况。于是他随时可能询问以城市 i 为根的子树中的所有城市共被加派了多少士兵。你现在是国王的军事大臣,你能回答出国王的每个询问么?
【输入格式】
第一行,包含两个整数N,P代表城市数量以及国王的命令的数量。
第二行N −1个整数,表示2− N号每个节点的父亲节点。
接下来的P行,每行代表国王的一个命令,命令分两种:
A X K在城市X加入K个士兵
Q X 询问以城市X为根的子树中所有士兵数量的和。
【输出格式】
对于每个Q,输出答案。
【样例输入】
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%的数据,1 ≤ N ≤ 1000 1≤ P<= 300。
对于100%的数据,1 ≤ N ≤ 50000 ,1≤ P ≤ 100000 1≤ X ≤ N 0 ≤ K ≤1000

【题目分析】

50分 暴力解决 vector建图

#include<cstdio>
#include<cstring>
#include<iostream>
#include<vector>
using namespace std;
#define maxn 50010
#define maxm 100010
vector<int>tu[maxn];
int ans[maxn]={};
int n,p;
int sum=;
void print(int a)
{
for(int i=;i<tu[a].size();i++)
{
sum+=ans[tu[a][i]];
if(tu[tu[a][i]].size())
print(tu[a][i]);
}
}
void add(int a,int b)
{
for(int i=;i<tu[a].size();i++)
{
int tp=tu[a][i];
ans[tp]+=b;
if(tu[tp].size())
add(tp,b+);
}
}
int main()
{
freopen("truetears.in","r",stdin);
freopen("truetears.out","w",stdout);
scanf("%d%d",&n,&p);
for(int i=;i<=n;i++)
{
int a;
scanf("%d",&a);
tu[a].push_back(i);
}
for(int i=;i<=p;i++)
{
char x;int y,z;
cin>>x;
if(x=='Q')
{
sum=;
scanf("%d",&y);
if(tu[y].size())
print(y);
sum+=ans[y];
printf("%d\n",sum);
}
if(x=='A')
{
scanf("%d%d",&y,&z);
ans[y]+=z;
if(tu[y].size())
add(y,z+);
}
}
fclose(stdin);fclose(stdout);
return ;
}

qbxt十一系列二的更多相关文章

  1. qbxt十一系列一

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

  2. qbxt十一系列四

    关于考试:题目很难,T1和T3都失误,爆零orz 更正:第三组:不存在相同的字符|str|=26,26<=n<=100 [题目分析] 第一反应,组合数学:第二反应,有端倪:jn给了一道题G ...

  3. qbxt十一系列三

    [题目分析] 这完全是个数学题啊,有些崩溃,上午考试写了两个小时,20分,于是乎 下午改啊改啊 改到10分....如果第二个圆的圆心在第一个圆.....呃 说不清楚 像下面这个图这样,两圆重叠部分中C ...

  4. 【圣诞特献】Web 前端开发精华文章推荐【系列二十一】

    <Web 前端开发精华文章推荐>2013年第九期(总第二十一期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各种增强网站用户体验的 jQuery 插件,展示前沿的 HTML5 和  ...

  5. WPF入门教程系列二十三——DataGrid示例(三)

    DataGrid的选择模式 默认情况下,DataGrid 的选择模式为“全行选择”,并且可以同时选择多行(如下图所示),我们可以通过SelectionMode 和SelectionUnit 属性来修改 ...

  6. Web 开发人员和设计师必读文章推荐【系列二十九】

    <Web 前端开发精华文章推荐>2014年第8期(总第29期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ...

  7. Web 前端开发人员和设计师必读文章推荐【系列二十八】

    <Web 前端开发精华文章推荐>2014年第7期(总第28期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ...

  8. Web 开发精华文章集锦(jQuery、HTML5、CSS3)【系列二十七】

    <Web 前端开发精华文章推荐>2014年第6期(总第27期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ...

  9. Web 前端开发人员和设计师必读精华文章【系列二十六】

    <Web 前端开发精华文章推荐>2014年第5期(总第26期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ...

随机推荐

  1. 1019: A+B和C比大小

    1019: A+B和C比大小 时间限制: 1 Sec  内存限制: 128 MB提交: 518  解决: 300[提交][状态][讨论版] 题目描述 给定区间[-231, 231]内的3个整数A.B和 ...

  2. android studio1.0 for Mac环境搭建与demo运行(手动下载gradle,科学上google) 转载

    http://blog.csdn.net/allenffl/article/details/41957907 官网下载 http://developer.android.com/sdk/install ...

  3. archlinux 网络配置

    https://wiki.archlinux.org/index.php/Network_configuration_%28%E7%AE%80%E4%BD%93%E4%B8%AD%E6%96%87%2 ...

  4. Another app is currently holding the yum lock; waiting for it to exit...另一个应用程序在占用yum lock,等待其退出。

    这种情况下通常是由于yum的时候意外退出造成的,虽然也给出提示当前占用进行的id,但是执行kill -9 3599 强制杀死进程后,情况依然没能改变. 备注:(-9是强制杀死) 主要原因是因为,yum ...

  5. 【crunch bang】字体美化

    中文字体美化是个很讨厌的事情,无数初学者在这里面浪费了无数时间,做了无数没有意义的事情.但这也是不得不做的,我把 Debian/Ubuntu 所需要的中文字体美化操作步骤详细记录在这里,希望能节约大家 ...

  6. 用smack+openfire做即时通讯

    首发:个人博客 必须说明:smack最新的4.1.1,相对之前版本变化很大,而且资料缺乏,官方文档也不好,所以还是用老版本3.2.2吧.这篇博文中的代码是4.1.1版的,但不推荐用它.用openfir ...

  7. 不允许调用库函数,也不允许使用任何全局或局部变量编写strlen函数

    不允许调用库函数,也不允许使用任何全局或局部变量编写strlen函数. 这是一道面试题,可以使用递归的方式解答,答案如下: #include <stdio.h> int mylen(cha ...

  8. nginx 优化

    隐藏nginx版本号:在http标签内写server_tokens off; 隐藏apache版本号:ServerTokens Prod ServerSignature Off 更改nginx默认的用 ...

  9. Linux Centos 上一些常用的命令

    1.查看端口被哪个进程占用 netstat -lnp | grep <端口号> 2.查看某个进程号详细信息 ps <进程号> 3.检查指定服务是否开启(例如 telnet) c ...

  10. 某硕笔试题mysql数据库部分(较为全面)

    Student(S#,Sname,Sage,Ssex) 学生表  Course(C#,Cname,T#) 课程表  SC(S#,C#,score) 成绩表  Teacher(T#,Tname) 教师表 ...