uva 1444 Knowledge for the masses
uva 1444
Description
You are in a library equipped with bookracks that move on rails. There are many parallel rails, i.e., the bookracks are organized in several rows, see figure:
To borrow a book, you have to find the librarian, who seems to hide on the opposite side of the bookracks. Your task then is to move the racks along the rails so that a passage forms. Each rack has a certain integer width, and can be safely positioned at any integer point along the rail. (A rack does not block in a non-integer position and could accidentally move in either direction). The racks in a single row need not be contiguous -- there can be arbitrary (though integer) space between two successive bookracks. A passage is formed at position k if there is no bookrack in the interval (k, k + 1) in any row (somehow you don't like the idea of trying to find a more sophisticated passage in this maze.)
Moving a rack requires a certain amount of efflort on your part: moving it in either direction costs 1. This cost does not depend on the distance of the shift, which can be explained by a well known fact that static friction is considerably higher than kinetic friction. Still, you are here to borrow a book, not to work out, so you would like to form a passage (at any position) with as little efflort as possible.
Input
The input contains several test cases. The first line of the input contains a positive integer Z15, denoting the number of test cases. ThenZ test cases follow, each conforming to the format described below.
Two space separated integers R and L(1R, 1
L
106) are given in the first line of an input instance. They denote the number of rows and the width of each and every row, respectively. Then R lines with rows descriptions follow. Each such line starts with an integer ni, followed by ni integers ai, 1, ai, 2,...ai, ni, all separated by single spaces. Number ai, j denotes either the width of a bookrack when ai, j > 0or a unit of empty space when ai, j = 0. Note that for any row i,
ai, j equals L minus the number of ai, j that are equal to zero. You may assume that n1 + n2 + ... + nR
2*107. Moreover, there will be at least one 0 in the description of each row, which means that creating a passage is always possible.
Output
For each test case, your program has to write an output conforming to the format described below.
In the first line, your program should output the minimum cost of making a passage through the bookracks. In the second line, it should print out the increasing sequence of all the positions at which a minimum cost passage can be formed.
Sample Input
1
4 10
8 1 2 1 0 1 2 0 1
7 2 2 2 1 0 1 0
6 1 3 2 0 2 1
7 2 1 2 0 2 1 0
Sample Output
3
8 9 题意:从上面到下面需要通过很多行,每一行都有书架或者空格,只有空格才能通过,问你最少需要移动多少书架才能达到终点
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn=1e6+;
int g[maxn],can[maxn],zero[maxn],pos[maxn],a[maxn],cost[maxn];
int N,H;
void Init()
{
int n;
cin>>n;
for(int i=;i<n;i++) cin>>a[i];
fill(cost,cost+maxn,-);
int ze=,now=;
for(int i=;i<n;i++)
{
if(a[i]==)
{
zero[ze++]=i;
can[now++]++;
}
else
{
now+=a[i];
int k=min(ze,a[i]);//空格长度与待移动书架长度,最多也只能移动空格位那么长
for(int j=;j<=k;j++)
{
cost[now-j]=i-zero[ze-j]-(j-);//只移j个,计算给(now-j)腾出空位需付代价
g[now-j]+=cost[now-j];//cost只是这一行的代价,总计用g(i)
can[now-j]++;//那么(now-j) 这个位置也可以通行了
}
}
}
reverse(a,a+n); //开始从右往左移
now--;ze=; //ze赋值为零!!!!!代表现在还没有看到可以直接通过的位置
for(int i=;i<n;i++)
{
if(a[i]==)
{
zero[ze++]=i;
now--;
}
else
{
now-=a[i];
int c=min(a[i],ze);
for(int j=;j<=c;j++)
{
if(cost[now+j]==-)
{
cost[now+j]=i-zero[ze-j]-(j-);
g[now+j]+=cost[now+j];
can[now+j]++;
}
else
{
int cc=i-zero[ze-j]-(j-);
g[now+j]+=min(,cc-zero[now+j]);
}
}
}
}
} void Print() //只要满足最小移动数的列举,其余就算可以通过也不要
{
int ans=1e9;
int cnt=;
for(int i=;i<H;i++)
{
if(can[i]==N)
{
if(ans>g[i])
{
ans=g[i];
cnt=;
pos[cnt++]=i;
}
else if(ans==g[i])
pos[cnt++]=i;
}
}
cout<<ans<<endl;
for(int i=;i<cnt;i++) cout<<pos[i]<<" ";
puts("");
} int main()
{
int T;
cin>>T;
while(T--)
{
memset(can,,sizeof(can)); //一定要清零
memset(cost,,sizeof(cost));
memset(pos,,sizeof(pos));
memset(g,,sizeof(g)); //一定要清零
cin>>N>>H;
for(int i=;i<N;i++) Init();
Print();
}
return ;
}
uva 1444 Knowledge for the masses的更多相关文章
- UVA 10002 Center of Masses
题目链接:http://acm.uva.es/local/online_judge/search_uva.html Problem:Find out the center of masses of a ...
- UVA 1456 六 Cellular Network
Cellular Network Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Submit S ...
- UVA 322 ships (POJ 1138)
题目地址: http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
- uva 1354 Mobile Computing ——yhx
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABGcAAANuCAYAAAC7f2QuAAAgAElEQVR4nOy9XUhjWbo3vu72RRgkF5
- UVA 10564 Paths through the Hourglass[DP 打印]
UVA - 10564 Paths through the Hourglass 题意: 要求从第一层走到最下面一层,只能往左下或右下走 问有多少条路径之和刚好等于S? 如果有的话,输出字典序最小的路径 ...
- UVA 11404 Palindromic Subsequence[DP LCS 打印]
UVA - 11404 Palindromic Subsequence 题意:一个字符串,删去0个或多个字符,输出字典序最小且最长的回文字符串 不要求路径区间DP都可以做 然而要字典序最小 倒过来求L ...
- UVA&&POJ离散概率与数学期望入门练习[4]
POJ3869 Headshot 题意:给出左轮手枪的子弹序列,打了一枪没子弹,要使下一枪也没子弹概率最大应该rotate还是shoot 条件概率,|00|/(|00|+|01|)和|0|/n谁大的问 ...
- UVA计数方法练习[3]
UVA - 11538 Chess Queen 题意:n*m放置两个互相攻击的后的方案数 分开讨论行 列 两条对角线 一个求和式 可以化简后计算 // // main.cpp // uva11538 ...
- UVA数学入门训练Round1[6]
UVA - 11388 GCD LCM 题意:输入g和l,找到a和b,gcd(a,b)=g,lacm(a,b)=l,a<b且a最小 g不能整除l时无解,否则一定g,l最小 #include &l ...
随机推荐
- swift中使用GCDMulticastDelegate
在开源库XMPPFramework中提供了一个GCDMulticastDelegate类,使用它可以为一个对象添加多个被委托的对象,以前用oc编写的工程引入了这个类,使用起来十分方便.最近由于换了工作 ...
- Netty,Thrifty
小白科普:Netty有什么用? https://mp.weixin.qq.com/s/PTKnRQ_hLf8BBPYnywLenA Thrifty 是基于.net Attribute 实现了标准 Th ...
- Django day 34 过滤课程,登录,redis,python操作redis
一:过滤课程, 二:登录 三:redis, 四:python操作redis
- 20道spring boot面试题
面试了少量人,简历上都说自己熟习 Spring Boot, 或者者说正在学习 Spring Boot,一问他们时,都只停留在简单的使用阶段,很多东西都不清楚,也让我对面试者大失所望. 下面,我给大家总 ...
- SQL常用指令集(Oracle)
1. Select rownum(oracle) top(mysql): 用于规定返回指定数目的值 Where roenum < number 2. Like 用于在where子句搜索指定模式 ...
- 洛谷P3371 【模板】单源最短路径(弱化版)(SPFA解法)
题目背景 本题测试数据为随机数据,在考试中可能会出现构造数据让SPFA不通过,如有需要请移步 P4779. 题目描述 如题,给出一个有向图,请输出从某一点出发到所有点的最短路径长度. 输入输出格式 输 ...
- 平方分割poj2104K-th Number
K-th Number Time Limit: 20000MS Memory Limit: 65536K Total Submissions: 59798 Accepted: 20879 Ca ...
- iOS规范化时间格式,object-C计算指定时间与当前的时间差
object-c计算指定时间与当前的时间差 头文件(.h): #import <Foundation/Foundation.h> @interface LuDate : NSDate +( ...
- [ SPOJ Qtree1 ] Query on a tree
\(\\\) Description 给定 \(n\) 个点的树,边按输入顺序编号为\(1,2,...n-1\) . 现要求按顺序执行以下操作(共 \(m\) 次): \(CHANGE\ i\ t_i ...
- Unity笔记(2)自学第一天
学习记录: 界面使用: