青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 87  文章 - 279  trackbacks - 0
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 219403
  • 排名 - 118

最新評論

閱讀排行榜

評論排行榜

Antenna Placement
Time Limit:1000MS? Memory Limit:65536K
Total Submit:380 Accepted:125

Description
The Global Aerial Research Centre has been allotted the task of building the fifth generation of mobile phone nets in Sweden. The most striking reason why they got the job, is their discovery of a new, highly noise resistant, antenna. It is called 4DAir, and comes in four types. Each type can only transmit and receive signals in a direction aligned with a (slightly skewed) latitudinal and longitudinal grid, because of the interacting electromagnetic field of the earth. The four types correspond to antennas operating in the directions north, west, south, and east, respectively. Below is an example picture of places of interest, depicted by twelve small rings, and nine 4DAir antennas depicted by ellipses covering them.

Obviously, it is desirable to use as few antennas as possible, but still provide coverage for each place of interest. We model the problem as follows: Let A be a rectangular matrix describing the surface of Sweden, where an entry of A either is a point of interest, which must be covered by at least one antenna, or empty space. Antennas can only be positioned at an entry in A. When an antenna is placed at row r and column c, this entry is considered covered, but also one of the neighbouring entries (c+1,r),(c,r+1),(c-1,r), or (c,r-1), is covered depending on the type chosen for this particular antenna. What is the least number of antennas for which there exists a placement in A such that all points of interest are covered?

Input
On the first row of input is a single positive integer n, specifying the number of scenarios that follow. Each scenario begins with a row containing two positive integers h and w, with 1 <= h <= 40 and 0 < w <= 10. Thereafter is a matrix presented, describing the points of interest in Sweden in the form of h lines, each containing w characters from the set ['*','o']. A '*'-character symbolises a point of interest, whereas a 'o'-character represents open space.

Output
For each scenario, output the minimum number of antennas necessary to cover all '*'-entries in the scenario's matrix, on a row of its own.

Sample Input

2
7 9
ooo**oooo
**oo*ooo*
o*oo**o**
ooooooooo
*******oo
o*o*oo*oo
*******oo
10 1
*
*
*
o
*
*
*
*
*
*

Sample Output

17
5

Source
Svenskt M?sterskap i Programmering/Norgesmesterskapet 2001

myCode:

#include? < iostream >
using ? namespace ?std;

const ? int ?INF? = ? 1 ? << ? 28 ;

int ?n,?r,?c;
int ?e[ 11 ]? = ? { 1 ,? 2 ,? 4 ,? 8 ,? 16 ,? 32 ,? 64 ,? 128 ,? 256 ,? 512 ,? 1024 } ;
char ?m[ 50 ][ 20 ];
int ?d[ 50 ][ 1024 ];
int ?b[ 20 ];
int ?cc[ 20 ];
int ?ss;

void ?Try( int ?x,? int ?s)
{
????
if ?(x? >= ?c)? {
????????
int ?k? = ? 0 ;
????????
for ?( int ?i = 0 ;?i < c;?i ++ )? {
????????????k?
+= ?b[i]? * ?e[i];
????????}

????????
if ?(d[ 0 ][k]? == ? - 1 ? || ?d[ 0 ][k]? > ?s)
????????????d[
0 ][k]? = ?s;
????????
return ?;
????}

????
if ?(m[ 0 ][x]? == ? ' o ' )? {
????????Try(x
+ 1 ,?s);
????}
? else ? if ?(m[ 0 ][x]? == ? ' * ' )? {
????????
int ?t1? = ?b[x],?t2? = ?b[x + 1 ],?t3? = ?s;
????????b[x]?
= ? 1 ;?b[x + 1 ]? = ? 1 ;?s? += ? 1 ;
????????Try(x
+ 2 ,?s);
????????b[x]?
= ?t1;?b[x + 1 ]? = ?t2;?s? = ?t3;
????????
if ?(r? != ? 1 ? || ?m[ 0 ][x]? == ? ' o ' )?Try(x + 1 ,?s);
????}
??
}


void ?DFS( int ?i,? int ?x,? int ?s)
{
????
if ?(x? >= ?c)? {
????????
int ?k? = ? 0 ;
????????
for ?( int ?j = 0 ;?j < c;?j ++ )? {
????????????k?
+= ?cc[j]? * ?e[j];
????????}

????????
if ?(d[i][k]? == ? - 1 ? || ?d[i][k]? > ?ss? + ?s)
????????????d[i][k]?
= ?ss? + ?s;
????????
return ?;
????}

????
if ?(b[x]? == ? 0 )? {
????????
if ?(m[i - 1 ][x]? == ? ' * ' )? {
????????????cc[x]?
= ? 1 ;?s? += ? 1 ;
????????????DFS(i,?x
+ 1 ,?s);
????????}
? else ? {
????????????
if ?(m[i][x]? == ? ' * ' )? {
????????????????
int ?t1? = ?cc[x],?t2? = ?cc[x + 1 ],?t3? = ?s;
????????????????cc[x]?
= ? 1 ;??cc[x + 1 ]? = ? 1 ;?s? += ? 1 ;
????????????????
if ?(b[x + 1 ]? == ? 0 ? && ?m[i - 1 ][x + 1 ]? == ? ' * ' )
????????????????????s?
+= ? 1 ;
????????????????DFS(i,?x
+ 2 ,?s);
????????????????cc[x]?
= ?t1;?cc[x + 1 ]? = ?t2;?s? = ?t3;
????????????????
if ?(i? != ?r - 1 ? || ?m[i][x]? == ? ' o ' )?DFS(i,?x + 1 ,?s);
????????????}
? else ? if ?(m[i][x]? == ? ' o ' )? {
????????????????DFS(i,?x
+ 1 ,?s);
????????????}

????????}

????}
? else ? {
????????????
if ?(m[i][x]? == ? ' * ' )? {
????????????????
int ?t1? = ?cc[x],?t2? = ?cc[x + 1 ],?t3? = ?s;
????????????????cc[x]?
= ? 1 ;??cc[x + 1 ]? = ? 1 ;?s? += ? 1 ;
????????????????
if ?(b[x + 1 ]? == ? 0 ? && ?m[i - 1 ][x + 1 ]? == ? ' * ' )
????????????????????s?
+= ? 1 ;
????????????????DFS(i,?x
+ 2 ,?s);
????????????????cc[x]?
= ?t1;?cc[x + 1 ]? = ?t2;?s? = ?t3;
????????????????
if ?(i? != ?r - 1 ? || ?m[i][x]? == ? ' o ' )?DFS(i,?x + 1 ,?s);
????????????}
? else ? if ?(m[i][x]? == ? ' o ' )? {
????????????????DFS(i,?x
+ 1 ,?s);
????????????}
??????
????}

}


void ?init()
{
????memset(d[
0 ],? - 1 ,? sizeof (d[ 0 ]));
????memset(b,?
0 ,? sizeof (b));
????Try(
0 ,? 0 );
}


void ?Solve()?
{
????
int ?i,?j,?k;
????init();
????
for ?(i = 0 ;?i < r - 1 ;?i ++ )? {
????????memset(d[i
+ 1 ],? - 1 ,? sizeof (d[i + 1 ]));
????????
for ?(k = 0 ;?k < e[c];?k ++ )? {
????????????
if ?(d[i][k]? != ? - 1 )? {
????????????????
int ?t? = ?k,?j? = ? 0 ,?kk? = ? 0 ;
????????????????memset(b,?
0 ,? sizeof (b));
????????????????memset(cc,?
0 ,? sizeof (cc));
????????????????
while ?(t? != ? 0 )? {
????????????????????b[j
++ ]? = ?t? % ? 2 ;
????????????????????t?
/= ? 2 ;
????????????????}

????????????????ss?
= ?d[i][k];
????????????????DFS(i
+ 1 ,? 0 ,? 0 );
????????????}

????????}

????}

????
int ?ans? = ?INF;
????
for ?(k = 0 ;?k < e[c];?k ++ )? {
????????
if ?(d[r - 1 ][k]? != ? - 1 ? && ?d[r - 1 ][k]? < ?ans)? {
????????????ans?
= ?d[r - 1 ][k];
????????}

????}

????cout?
<< ?ans? << ?endl;
}


int ?main()
{?
????cin?
>> ?n;
????
while ?(n -- ? != ? 0 )? {
????????cin?
>> ?r? >> ?c;
????????
for ?( int ?i = 0 ;?i < r;?i ++ )?cin? >> ?m[i];
????????Solve();
????}

????system(
" pause " );
????
return ? 0 ;
}


ghost_wei大牛的code,? 放出來供大家學(xué)習,? 用了滾動數(shù)組優(yōu)化, 而且位運算用得出神入化:)
#include<iostream.h>
#include?
<fstream.h>
const?int?k2[11]={1,2,4,8,16,32,64,128,256,512,1024};
int?n,m,c[2][1024];
char?d[40][10];
inline?
void?min(int?&i,int?j)
{
????
if?(i>j)?i=j;
}

void?work()
{
????
int?i,j,km,k,e7,e8,l,t,ans;
????km
=k2[m];
????
for?(i=0;i<km;i++)?c[0][i]=100000;
????c[
0][0]=0;
????e7
=0;?e8=1;
????
for?(i=0;i<n;i++)
????
{
????????
for?(j=0;j<km;j++)?c[e8][j]=100000;
????????
for?(j=1;j<m;j++)
????????????
if?(d[i][j]=='*')
????????????????
for?(k=0;k<km;k++)
????????????????????min(c[e7][k
|k2[j]|k2[j-1]],c[e7][k]+1);
????????
for?(k=0;k<km;k++)
????????
{
????????????l
=0;?t=0;
????????????
for?(j=0;j<m;j++)?
????????????????
if?(!(k&k2[j])&&d[i][j]=='*')
????????????????
{
????????????????????l
+=k2[j];
????????????????????t
++;
????????????????}

????????????min(c[e8][l],c[e7][k]
+t);
????????}

????????e7
=e7^1;?e8=e8^1;
????}

????ans
=100000;
????
for?(k=0;k<km;k++)
????????min(ans,c[e7][k]);
????cout
<<ans<<endl;
}

int?main()
{
????
int?tc,cas,i,j;
????cin
>>tc;
????
for?(cas=1;cas<=tc;cas++)
????
{
????????cin
>>n>>m;
????????
for?(i=0;i<n;i++)
????????????
for(j=0;j<m;j++)
????????????????cin
>>d[i][j];
????????work();
????}

????
return?0;
}

posted on 2006-10-18 17:29 閱讀(2147) 評論(4)  編輯 收藏 引用 所屬分類: ACM題目

FeedBack:
# re: 狀態(tài)壓縮DP, pku3020[未登錄] 2007-04-30 11:16 Leon
Ghost的算法真是精辟,只是狀態(tài)數(shù)組定義的空間可能會不夠,代碼的line 30  回復(fù)  更多評論
  
# re: 狀態(tài)壓縮DP, pku3020 2007-06-30 10:35 姜雨生
真是太好了
以后多向你請教  回復(fù)  更多評論
  
# re: 狀態(tài)壓縮DP, pku3020[未登錄] 2008-07-02 08:22 菜鳥
大牛解釋一下這一段吧:
for (i=0;i<n;i++)
{
for (j=0;j<km;j++) c[e8][j]=100000;
for (j=1;j<m;j++)
if (d[i][j]=='*')
for (k=0;k<km;k++)
min(c[e7][k|k2[j]|k2[j-1]],c[e7][k]+1);
for (k=0;k<km;k++)
{
l=0; t=0;
for (j=0;j<m;j++)
if (!(k&k2[j])&&d[i][j]=='*')
{
l+=k2[j];
t++;
}
min(c[e8][l],c[e7][k]+t);
}
e7=e7^1; e8=e8^1;
}
  回復(fù)  更多評論
  
# re: 狀態(tài)壓縮DP, pku3020 2008-08-04 22:56 ecnu
二分匹配做的。。關(guān)鍵是狀態(tài)壓縮不會。5555...  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
      <noscript id="pjuwb"></noscript>
            <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
              <dd id="pjuwb"></dd>
              <abbr id="pjuwb"></abbr>
              国产九区一区在线| 欧美激情精品久久久久久久变态| 日韩视频免费观看高清在线视频| 亚洲永久免费av| 一本一本a久久| 欧美成人午夜激情在线| 日韩视频免费在线观看| 美女日韩欧美| 亚洲国产精品免费| 亚洲高清视频中文字幕| 欧美一区激情视频在线观看| 在线观看一区视频| 久久亚洲电影| 欧美国产综合视频| 亚洲国产另类久久精品| 久久综合久久久久88| 亚洲欧洲日产国产综合网| 亚洲欧美中文日韩在线| 欧美一级视频免费在线观看| 欧美日韩少妇| 一区二区黄色| 亚洲国产欧美日韩精品| 欧美在线免费观看亚洲| 葵司免费一区二区三区四区五区| 免费黄网站欧美| 在线日韩欧美视频| 国产精品久久久久三级| 麻豆久久婷婷| 性色av一区二区怡红| 亚洲精品综合精品自拍| 久久免费精品视频| 亚洲一区在线直播| 亚洲三级性片| 合欧美一区二区三区| 欧美视频中文字幕| 欧美成人a视频| 久久国产精品72免费观看| 中国女人久久久| 91久久久亚洲精品| 久热精品在线| 欧美一区二区三区免费看| 在线中文字幕日韩| 亚洲黄色高清| 黄色欧美成人| 国产欧美婷婷中文| 国产精品久久亚洲7777| 欧美日韩国产成人在线免费| 噜噜噜久久亚洲精品国产品小说| 午夜精品婷婷| 亚洲尤物在线| 亚洲五月婷婷| 中国女人久久久| 日韩一级免费| 亚洲理论电影网| 亚洲国产91| 亚洲国产精品成人一区二区| 久久综合久久美利坚合众国| 欧美在线三区| 欧美资源在线| 久久成人在线| 欧美自拍偷拍午夜视频| 欧美一区中文字幕| 欧美一区二区三区在线播放| 亚洲在线视频| 午夜在线成人av| 午夜精品久久久久久久白皮肤| 亚洲欧美日韩国产另类专区| 亚洲欧美日韩国产综合| 亚洲欧美日韩国产一区二区三区 | 国产日韩欧美亚洲一区| 国产精品久久久久久久久免费| 国产精品国产三级国产| 国产精品护士白丝一区av| 国产精品第一页第二页第三页| 国产精品成人免费| 国产精品久久久久久久久免费樱桃| 欧美视频精品在线观看| 国产精品国产自产拍高清av| 国产精品高潮在线| 国产精品嫩草久久久久| 国产一区二区日韩精品欧美精品 | 欧美福利视频| 亚洲黄色免费| 艳妇臀荡乳欲伦亚洲一区| 亚洲视频在线免费观看| 亚洲欧美久久久久一区二区三区| 性一交一乱一区二区洋洋av| 久久精品国产精品| 欧美顶级大胆免费视频| 欧美日韩中文字幕综合视频| 国产精品久久99| 国内精品久久久久久久影视麻豆 | 国产日韩欧美综合一区| 国语精品一区| 99国产精品视频免费观看一公开| 亚洲影院免费| 麻豆成人91精品二区三区| 亚洲国产精品一区二区www| 99热精品在线| 久久久精品国产免费观看同学| 免费亚洲婷婷| 国产精品视频一二三| 亚洲第一在线综合网站| 中国成人黄色视屏| 久久精品卡一| 最近中文字幕mv在线一区二区三区四区| 亚洲最新中文字幕| 久久久久久久久久久成人| 欧美美女操人视频| 国产亚洲欧美日韩一区二区| 亚洲精品在线视频| 久久er精品视频| 亚洲欧洲视频| 久久国产成人| 国产精品扒开腿做爽爽爽软件 | 亚洲精品综合久久中文字幕| 先锋影音久久久| 欧美激情一区在线| 国产主播精品| 亚洲视频第一页| 免播放器亚洲一区| 99国产精品视频免费观看| 久久精品综合| 国产乱人伦精品一区二区| 亚洲精品国精品久久99热一| 亚洲欧美激情在线视频| 久久亚洲综合网| 中文一区二区在线观看| 欧美不卡在线视频| 黑人操亚洲美女惩罚| 午夜精品久久久久| 亚洲精品久久嫩草网站秘色 | 国模一区二区三区| 午夜一区不卡| 日韩亚洲欧美一区二区三区| 久久人人爽人人爽| 国产在线播放一区二区三区| 亚洲一区黄色| 日韩天堂在线观看| 欧美激情精品久久久久| 在线观看视频日韩| 可以看av的网站久久看| 亚洲欧美日韩天堂| 国产精品毛片| 亚洲欧洲99久久| 一区二区三区免费看| 欧美日本韩国| 一区二区欧美亚洲| 亚洲精品在线视频| 欧美精品国产精品| 日韩亚洲不卡在线| 91久久国产综合久久91精品网站| 久久久久国产精品午夜一区| 国产日韩欧美综合| 久久久www| 欧美自拍偷拍| 激情视频一区二区| 你懂的视频欧美| 免费观看久久久4p| 亚洲区国产区| 最新日韩在线| 欧美日韩中文字幕| 亚洲一区二区黄| 中文一区二区| 国产欧美日韩激情| 久久精品一二三区| 久久久久.com| 亚洲国产精品一区二区第四页av | 中文网丁香综合网| 国产伦理精品不卡| 久久久久国产精品www| 久久嫩草精品久久久久| 亚洲国产精品久久精品怡红院| 欧美肥婆在线| 欧美日韩亚洲一区二区三区四区| 亚洲在线一区| 欧美一区在线视频| 亚洲电影下载| 亚洲美女视频在线观看| 国产精品麻豆va在线播放| 久久一综合视频| 欧美精品一级| 欧美一区亚洲二区| 久久综合网色—综合色88| 在线视频精品一| 销魂美女一区二区三区视频在线| 一区二区三区在线高清| 亚洲精品国产日韩| 国产精品一卡二卡| 蜜臀91精品一区二区三区| 欧美在线视屏| 影音先锋久久久| 亚洲电影欧美电影有声小说| 欧美韩日高清| 久久成人免费日本黄色| 久久免费一区| 亚洲成色777777在线观看影院| 亚洲欧洲视频在线| 国产嫩草一区二区三区在线观看 | 亚洲国产精品激情在线观看|