摘要:
大意:给定一个MxN大小的方格,地图有3中方格,墙、草地、空地。他的老板希望Robert能在地图中放置尽可能多的机器人。每个机器人可以向四个方向开火,激光可以穿透草地,但不能穿透墙壁。思路:将一行被墙隔开且包含空地的连续区域叫做“块”。 把每个横向“块”看做二部图中的X中的顶点,竖向“块”看做集合中Y的顶点,若两个“块”有公共的顶点空地,于是就连一条边。这样就转换成了没有公共顶点的最大边集,即最大匹配。我们怎么去求“块”呢?用一个2个二维数组xs,ys来对水平方向和垂直方向上的“块”进行编号,编号之后如果两个块有公共的空地的话,那么就在“块”与“块”之间连边。即read_graph(xs[i] 阅读全文
posted @ 2012-11-10 10:39
有间博客
阅读(618)
评论(0)
推荐(0)