C++ 實現(xiàn)球迷 今日頭條面試題
試題描述:
一個球場C的球迷看臺可容納M*N個球迷。官方想統(tǒng)計一共有多少球迷群體,最大的球迷群體有多少人。
球迷選座特性:同球迷群體會選擇相鄰座位,不同球迷群體選擇不相鄰的座位。(相鄰包括前后相鄰、左右相鄰、斜對角相鄰);
給定一個M*N的二維球場,0代表該位置沒人,1代表該位置有人,希望輸出球隊群體個數(shù)P,最大的球隊群體人數(shù)Q。
輸入:
第一行,2個數(shù)字,M、N,使用英文逗號隔開。
接下來M行,每行N個數(shù)字,使用英文逗號隔開。
輸出:
一行,2數(shù)字,P和Q。
輸入樣例:
10,10
0,0,0,0,0,0,0,0,0,0
0,0,0,1,1,0,1,0,0,0
0,1,0,0,0,0,0,1,0,1
1,0,0,0,0,0,0,0,1,1
0,0,0,1,1,1,0,0,0,1
0,0,0,0,0,0,1,0,1,1
0,1,1,0,0,0,0,0,0,0
0,0,0,1,0,1,0,0,0,0
0,0,1,0,0,1,0,0,0,0
0,1,0,0,0,0,0,0,0,0
輸出樣例:
6,8
其他:
對于100%的數(shù)據(jù),1<=M,N<=3e3。
這道題是一道明顯的深度優(yōu)先搜索,而且十分簡單。
但是在看到輸入示例后會發(fā)現(xiàn)每個數(shù)據(jù)的后面都存在著一個字符,而且回車也屬于字符。
所以我們要先對數(shù)據(jù)進行處理。
我們需要使用的的輔助工具就是getchar()了,不知道的人可以把getchar()作為一個爪子,每當一個char類型的字符被輸入后,getchar()就可以準確的捕捉到他。
但是getchar()是會忽略每行第一個字符的。
所以我們可以定義一個數(shù)組,在取完第一個數(shù)后再使用getchar()。就可以把所有的0和1存儲在一個n*m的二維數(shù)組中了。
再說dfs,就十分簡單了,只需要判斷可能走的8個方向,再使用一個計數(shù)器計數(shù)就可以了。
但是為了避免走重復的路,也是為了避免時間超限。所以我們可以定義一個bool類型的數(shù)組,記錄走過的路。
同時在主函數(shù)中做寫一個兩層的嵌套循環(huán),找到每個1,再進行dfs。
也要注意使用scanf和printf。
在最后也需要使用一個putchar(),相當于是輸出一個字符。
論速度那個快 putchar(),getchar>scanf,printf>cin,cout。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<stdio.h>
using namespace std;
int n,m,l,k,sum,ans,cnt;
char a[4000][4000],op;
bool b[4000][4000]={0};
int dfs(int x,int y)
{
if(a[x-1][y]=='1'&&b[x-1][y]==0)
{
b[x-1][y]=1;
dfs(x-1,y);
ans++;
}
if(a[x][y+1]=='1'&&b[x][y+1]==0)
{
b[x][y+1]=1;
dfs(x,y+1);
ans++;
}
if(a[x-1][y+1]=='1'&&b[x-1][y+1]==0)
{
b[x-1][y+1]=1;
dfs(x-1,y+1);
ans++;
}
if(a[x+1][y]=='1'&&b[x+1][y]==0)
{
b[x+1][y]=1;
dfs(x+1,y);
ans++;
}
if(a[x][y-1]=='1'&&b[x][y-1]==0)
{
b[x][y-1]=1;
dfs(x,y-1);
ans++;
}
if(a[x+1][y-1]=='1'&&b[x+1][y-1]==0)
{
b[x+1][y-1]=1;
dfs(x+1,y-1);
ans++;
}
if(a[x+1][y+1]=='1'&&b[x+1][y+1]==0)
{
b[x+1][y+1]=1;
dfs(x+1,y+1);
ans++;
}
if(a[x-1][y-1]=='1'&&b[x-1][y-1]==0)
{
b[x-1][y-1]=1;
dfs(x-1,y-1);
ans++;
}
return ans;
}
int main()
{
scanf("%d%c%d",&n,&op,&m);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
getchar();
a[i][j]=getchar();
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
ans=0;
if(a[i][j]=='0')b[i][j]=1;
if(a[i][j]=='1'&&b[i][j]==0)
{
sum++;
cnt=max(cnt,dfs(i,j));
}
}
}
char p=',';
printf("%d",sum);
putchar(p);
printf("%d",cnt);
}
總結(jié)
以上所述是小編給大家介紹的C++ 實現(xiàn)球迷 今日頭條面試題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對我們網(wǎng)站的支持!
上一篇:C++實現(xiàn)產(chǎn)生隨機數(shù)和相應(yīng)的猜拳小游戲?qū)嵗a
欄 目:C語言
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/689.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-用棧實現(xiàn)表達式求值的方法詳解
- 01-10使用OpenGL實現(xiàn)3D立體顯示的程序代碼
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10求斐波那契(Fibonacci)數(shù)列通項的七種實現(xiàn)方法
- 01-10C語言 解決不用+、-、&#215;、&#247;數(shù)字運算符做加法
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10c++中inline的用法分析
- 01-10用C++實現(xiàn)DBSCAN聚類算法
- 01-10深入全排列算法及其實現(xiàn)方法


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10delphi制作wav文件的方法
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 04-02jquery與jsp,用jquery
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10C#中split用法實例總結(jié)


