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

心如止水
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>
            一区二区三区欧美| 亚洲视频第一页| 狼人社综合社区| 久久精品国产77777蜜臀| 午夜精品一区二区在线观看| 一区二区三区国产盗摄| 中文日韩欧美| 午夜精品视频一区| 久久精品国产一区二区三区| 久久精品综合一区| 乱码第一页成人| 欧美日本三级| 国产精品一区二区你懂的| 国产欧美一区二区三区久久 | 亚洲裸体在线观看| 亚洲天堂av综合网| 久久久午夜精品| 欧美电影打屁股sp| 99精品热视频只有精品10| 亚洲女人小视频在线观看| 久久九九精品99国产精品| 欧美国产第二页| 国产精品视频| 亚洲精品国产精品乱码不99按摩 | 久久免费精品视频| 女生裸体视频一区二区三区| 亚洲国产天堂久久综合| 日韩一区二区精品葵司在线| 亚洲欧美影音先锋| 欧美激情视频一区二区三区在线播放| 国产精品v欧美精品∨日韩| 狠狠操狠狠色综合网| 日韩一区二区高清| 久久网站免费| 亚洲午夜视频| 欧美精品一线| 亚洲第一黄色网| 久久国产婷婷国产香蕉| 亚洲另类在线视频| 久久视频一区二区| 国产精品日韩欧美一区| 亚洲人成网站色ww在线| 久久亚洲视频| 欧美在线1区| 国产精品一区二区久久精品| 99精品免费视频| 欧美99久久| 欧美一区二区视频观看视频| 欧美日韩精品一区视频| 亚洲国产日韩美| 久久网站免费| 久久成人这里只有精品| 国产精品资源| 欧美一区二区三区在线免费观看| 亚洲人体一区| 欧美人成在线| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 日韩午夜视频在线观看| 欧美成人中文| 久久亚洲高清| 亚洲国产精品一区制服丝袜| 老鸭窝毛片一区二区三区| 香蕉尹人综合在线观看| 国产乱码精品一区二区三区不卡| 亚洲摸下面视频| 中日韩美女免费视频网址在线观看 | 国产区精品视频| 亚洲欧美在线另类| 亚洲影院免费观看| 国产免费成人| 美女尤物久久精品| 欧美成人蜜桃| 一区二区三区四区国产| 日韩午夜一区| 欧美国产日韩xxxxx| 麻豆成人91精品二区三区| 欧美一区观看| 激情懂色av一区av二区av| 另类春色校园亚洲| 欧美/亚洲一区| 99一区二区| 亚洲一区二区三区色| 国产欧美亚洲精品| 快she精品国产999| 欧美另类极品videosbest最新版本| 一本久久a久久精品亚洲| 亚洲天堂av在线免费观看| 国产农村妇女精品一区二区| 麻豆成人精品| 欧美午夜一区二区| 久久综合九九| 欧美日韩视频| 久久久亚洲午夜电影| 欧美国产免费| 久久aⅴ国产欧美74aaa| 久久伊人一区二区| 亚洲一区在线看| 久久久久久久999| 一区二区欧美视频| 久久精品五月| 亚洲欧美国产精品专区久久| 久久久久国产免费免费| 亚洲网址在线| 麻豆精品网站| 欧美一级片一区| 欧美国内亚洲| 久久中文久久字幕| 国产精品草草| 亚洲国产婷婷综合在线精品| 国产精品人人爽人人做我的可爱 | 亚洲美女中出| 激情久久久久久久久久久久久久久久| 亚洲人成网站精品片在线观看| 国产欧美日韩综合一区在线播放| 亚洲丰满少妇videoshd| 国产欧美一区二区精品秋霞影院| 最新精品在线| 亚洲第一在线视频| 久久精品国产99国产精品澳门| 日韩视频欧美视频| 快she精品国产999| 久久久久久穴| 国产日韩亚洲| 亚洲一区二区三区免费视频| 一区二区三区日韩精品| 久久久综合网| 久久中文精品| 激情av一区| 久久9热精品视频| 欧美一区二区成人| 国产精品久久看| 一区二区三区回区在观看免费视频| 亚洲激情视频网站| 久久一综合视频| 欧美福利一区二区| 亚洲国产清纯| 亚洲国语精品自产拍在线观看| 亚洲免费一在线| 亚洲永久视频| 欧美午夜性色大片在线观看| 欧美二区在线观看| 亚洲高清在线精品| 免费在线观看精品| 欧美风情在线观看| 亚洲日韩成人| 欧美日韩裸体免费视频| 日韩一区二区高清| 亚洲欧美中文在线视频| 国产日产亚洲精品系列| 欧美一级片在线播放| 久久久99久久精品女同性| 国产午夜久久久久| 久久躁狠狠躁夜夜爽| 欧美不卡激情三级在线观看| 亚洲风情亚aⅴ在线发布| 欧美高清视频在线播放| 日韩亚洲不卡在线| 欧美在线一级va免费观看| 国产一区亚洲| 欧美高清一区二区| 亚洲综合另类| 欧美大片国产精品| 一区二区日韩免费看| 国产伦精品一区二区三区免费迷| 欧美专区第一页| 欧美成人免费播放| 亚洲一二三区在线观看| 国产精品视频一二| 久久免费高清视频| 亚洲美女免费视频| 久久精品一区二区三区不卡| 亚洲高清影视| 国产精品日韩一区二区三区| 久久久久久久综合色一本| 亚洲另类春色国产| 久久网站热最新地址| 在线视频你懂得一区二区三区| 国产色视频一区| 欧美日韩1区2区| 久久免费黄色| 亚洲欧美影院| 日韩视频在线永久播放| 久久亚洲不卡| 欧美一区二区三区在线视频 | 欧美日韩成人一区二区| 欧美一区二区三区婷婷月色| 亚洲黄一区二区| 久久精品噜噜噜成人av农村| 亚洲免费高清视频| 激情视频一区| 国产日韩欧美综合一区| 欧美日韩在线一区二区三区| 久久午夜影视| 欧美在线免费播放| 亚洲尤物精选| 亚洲午夜精品视频| 9色精品在线| 亚洲第一中文字幕| 美腿丝袜亚洲色图| 久久久久久一区二区三区|