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

心如止水
Je n'ai pas le temps
posts - 400,comments - 130,trackbacks - 0
此題的意思就是在用‘.’和‘#’組成的圖形中,有多少個長方形。這類問題最容易想到的方法就是BFS,這題我依然按照這個思路去想。

 

利用BFS很容易得出有多少個由 # 組成的圖形,問題的關(guān)鍵成為了如何判斷一個圖形是否是長方形。

如下圖形:

. . . .

##. .

##. .

. . . .

一眼即可看出它是個長方形(廢話)。

再看另一個:

. . . .

## . .

### .

. . . .

它不是一個長方形。

如果注意到兩個圖形的行坐標的最大值最小值、列坐標的最大值最小值與圖形的面積之間的關(guān)系,我們很容易想出來一個算法。

(xmax-xmin+1)*(ymax-ymin+1)==area

是一個長方形;

否則不是。

時間復雜度O(rc)1000*1000的數(shù)據(jù)規(guī)模完全可以承受。

此題還有其他解法。

這種方法很好理解,但是程序有點長,因為涉及到BFS

Ps:另外說明一下BFS應(yīng)該由一個點出發(fā)向8個點搜索,題目中說的不是太清楚。這一點我也是看了測試數(shù)據(jù)才知道。

 

以下是我的程序:

#include<stdio.h>
#define min(a,b) (a<b?a:b)
#define max(a,b) (a>b?a:b)
typedef 
struct
{
    
long front,rear,count,x[100000],y[100000];
}
Queue;
char map[1001][1001];
long r,c;
long id[]={-1,-1,0,1,1,1,0,-1};
long jd[]={0,1,1,1,0,-1,-1,-1};
int used[1001][1001]={0};
void clear(Queue *q)
{
    q
->count=0;
    q
->front=0;
    q
->rear=-1;
}

void put(Queue *q,long a,long b)
{
    q
->count++;
    q
->rear++;
    q
->x[q->rear]=a;
    q
->y[q->rear]=b;
}

void get(Queue *q,long *a,long *b)
{
    q
->count--;
    
*a=q->x[q->front];
    
*b=q->y[q->front];
    q
->front++;
}

int empty(Queue *q)
{
    
return (q->count<=0);
}

long bfs1()
{
    
long i,j,re=0;
    
for(i=0;i<r;i++)
      
for(j=0;j<c;j++)
        
if(map[i][j]=='#')
          re
++;
    
return re;
}

long bfs2(long *ans)
{
    
long i,j,k,t1,t2,re=0,xmin,xmax,ymin,ymax,flag;
    Queue A;
    clear(
&A);
    
for(i=0;i<r;i++)
      
for(j=0;j<c;j++)
      
{
         flag
=0;
         
if(map[i][j]=='#'&&!used[i][j])
         
{
            put(
&A,i,j);
            xmin
=xmax=i;
            ymin
=ymax=j;
            flag
=1;
         }

         
while(!empty(&A))
         
{
            
get(&A,&t1,&t2);
            
if(!used[t1][t2])
            
{
               used[t1][t2]
=1;
               xmin
=min(xmin,t1);
               xmax
=max(xmax,t1);
               ymin
=min(ymin,t2);
               ymax
=max(ymax,t2);
               
for(k=0;k<8;k++)
                 
if(t1+id[k]>=0&&t1+id[k]<r&&t2+jd[k]>=0&&t2+jd[k]<c&&!used[t1+id[k]][t2+jd[k]]&&map[t1+id[k]][t2+jd[k]]=='#')
                   put(
&A,t1+id[k],t2+jd[k]);
            }

         }

         
if(flag)
         
{
            re
+= (xmax-xmin+1)*(ymax-ymin+1);
            (
*ans)++;
         }

      }

    
return re;
}

int main()
{
    FILE 
*fin,*fout;
    fin
=fopen("battle.in","r");
    
long i,j,area1,area2,ans=0;
    fscanf(fin,
"%ld%ld",&r,&c);
    
for(i=0;i<r;i++)
      fscanf(fin,
"%s",map[i]);
    fclose(fin);
//------Read In
    area1=bfs1();
    area2
=bfs2(&ans);
    fout
=fopen("battle.out","w");
    
if(area1!=area2)
      fprintf(fout,
"Bad placement.\n");
    
else
      fprintf(fout,
"There are %ld ships.\n",ans);
    fclose(fout);
return 0;
}

posted on 2010-01-06 18:46 lee1r 閱讀(406) 評論(0)  編輯 收藏 引用 所屬分類: 題目分類:搜索
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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ⅴ四虎| 亚洲在线视频观看| 欧美日韩亚洲综合| 亚洲综合色激情五月| 亚洲一区欧美| 在线观看亚洲精品视频| 一区二区三区 在线观看视| 韩日精品中文字幕| 一本到12不卡视频在线dvd| 国产精品久久综合| 亚洲高清色综合| 激情国产一区| 欧美体内she精视频在线观看| 亚洲福利av| 精品成人一区二区| 亚洲精品久久久一区二区三区| 开心色5月久久精品| 欧美在线视频全部完| 欧美精品一区二区三区在线播放 | 欧美日韩美女一区二区| 欧美一区日韩一区| 国产伦精品一区二区三区照片91| 最新亚洲视频| 日韩视频免费| 欧美日韩一区在线| 最新高清无码专区| 亚洲影院高清在线| 国产精品成人免费精品自在线观看| 99国产精品视频免费观看一公开| 亚洲图片在线| 国产欧美一区在线| 99精品欧美一区二区三区综合在线| 在线色欧美三级视频| 亚洲福利在线视频| 一区在线影院| 亚洲欧美日韩精品综合在线观看 | 亚洲日韩成人| 欧美激情精品久久久久久久变态| 欧美久久久久久久| 在线观看精品一区| 蜜臀va亚洲va欧美va天堂| 亚洲精品久久久久久久久久久| 欧美一级久久久| 国产精品无人区| 亚洲视频精选| 久久久国产视频91| 免费成年人欧美视频| 亚洲国产精品久久久久秋霞不卡| 一本色道久久综合一区| 欧美一区二区在线看| 欧美精品一区二区三区蜜桃 | 亚洲国产一区在线| 欧美亚洲一区| 最近看过的日韩成人| 欧美在线视频观看| 免费视频一区| 国产综合精品| 亚洲一区二区四区| 91久久精品国产| 久久精品国产一区二区三区免费看| 国产精品成人在线| 日韩一区二区精品葵司在线| 久久久国产精彩视频美女艺术照福利| 日韩一级片网址| 一本大道av伊人久久综合| 母乳一区在线观看| 亚洲高清一二三区| 亚洲高清在线观看| 久久精品国产v日韩v亚洲| 99视频日韩| 久久久久久亚洲精品不卡4k岛国| 欧美私人网站| 亚洲主播在线| 亚洲视频欧美视频| 欧美午夜激情视频| 亚洲视频免费在线| 亚洲美女色禁图| 欧美日韩成人激情| 一区二区三区免费看| av不卡在线| 国产精品久久久久久久久久ktv| 99国产精品久久久| 国产精品久久网| 午夜亚洲一区| 老牛国产精品一区的观看方式| 黄色国产精品| 蜜月aⅴ免费一区二区三区| 久久久夜夜夜| 国产乱子伦一区二区三区国色天香| 亚洲三级影院| 亚洲精品免费电影| 欧美日韩高清在线一区| 在线亚洲美日韩| 亚洲欧美久久久| 久热精品视频| 欧美福利网址| 免费在线欧美黄色| 9色国产精品| 亚洲另类在线一区| 国产精品视频专区| 欧美91福利在线观看| 女女同性精品视频| 国产精品稀缺呦系列在线| 欧美 日韩 国产一区二区在线视频 | 一区二区三区在线视频观看| 亚洲免费网址| 久久国产精品久久久| 亚洲国产精品精华液2区45| 久久精品人人| 久久综合色婷婷| 宅男噜噜噜66国产日韩在线观看| 欧美韩国一区| 国语自产偷拍精品视频偷| 欧美激情乱人伦| 欧美日韩亚洲一区二| 欧美制服丝袜| 免费看成人av| 老鸭窝91久久精品色噜噜导演| 欧美人与性动交cc0o| 亚洲免费成人av| 久久精品国产综合精品| 夜夜爽www精品| 亚洲伦伦在线| 伊人久久亚洲热| 亚洲一区二区免费在线| 亚洲国内自拍| 久久国产视频网站| 亚洲欧美成人网| 欧美三级欧美一级| 欧美激情成人在线| 亚洲电影免费观看高清| 亚洲免费中文字幕| 香蕉成人啪国产精品视频综合网| 亚洲一区免费网站| 欧美国产1区2区| 久久不见久久见免费视频1| 欧美激情视频在线免费观看 欧美视频免费一 | 亚洲美女av网站| 久久手机免费观看| 久久超碰97人人做人人爱| 欧美日韩精品一区二区| 免费观看成人| 亚洲国产日韩欧美在线99 | 欧美新色视频| 亚洲精品一级| 国产日韩专区| 国产一区香蕉久久| 亚洲激情一区二区三区| 亚洲国产精品一区二区www在线| 亚洲欧美国产精品专区久久| 久久精品国产999大香线蕉| 国产精品乱码妇女bbbb| 欧美一区二区视频免费观看| 欧美精品1区| 国产伦理一区| 亚洲欧美日韩一区在线| 亚洲欧美日产图| 国内成+人亚洲| 欧美在线观看一区二区三区| 亚洲激情国产| 欧美无砖砖区免费| 亚洲日本欧美在线| 欧美亚洲视频在线观看| 国产日本精品| 亚洲欧美中文在线视频| 国产毛片精品视频| 午夜欧美精品久久久久久久| 欧美bbbxxxxx| 亚洲精品少妇| 欧美性大战久久久久| 亚洲免费视频网站| 久久亚洲一区二区三区四区| 在线成人av.com| 欧美国产精品v| 夜夜嗨av色一区二区不卡| 久久夜色精品| 日韩写真在线| 欧美资源在线| 日韩视频一区二区三区在线播放免费观看 | 噜噜噜91成人网| 亚洲毛片在线观看| 亚洲免费一在线| 国产综合香蕉五月婷在线| 欧美国产高潮xxxx1819| 一本色道久久综合| 欧美 日韩 国产精品免费观看| 亚洲精品久久视频| 国产精品久久久久久妇女6080| 午夜免费久久久久| 午夜在线精品偷拍| 国产亚洲一区在线| 母乳一区在线观看| 亚洲欧美日韩成人高清在线一区| 免费视频一区二区三区在线观看| 夜夜嗨av色综合久久久综合网| 国产精品色午夜在线观看|