C++实现球迷今日头条面试题-创新互联
试题描述:
我们提供的服务有:成都做网站、成都网站制作、成都外贸网站建设、微信公众号开发、网站优化、网站认证、共青城ssl等。为超过千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的共青城网站制作公司一个球场C的球迷看台可容纳M*N个球迷。官方想统计一共有多少球迷群体,大的球迷群体有多少人。
球迷选座特性:同球迷群体会选择相邻座位,不同球迷群体选择不相邻的座位。(相邻包括前后相邻、左右相邻、斜对角相邻);
给定一个M*N的二维球场,0代表该位置没人,1代表该位置有人,希望输出球队群体个数P,大的球队群体人数Q。
输入:
第一行,2个数字,M、N,使用英文逗号隔开。
接下来M行,每行N个数字,使用英文逗号隔开。
输出:
一行,2数字,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%的数据,1<=M,N<=3e3。
这道题是一道明显的深度优先搜索,而且十分简单。
但是在看到输入示例后会发现每个数据的后面都存在着一个字符,而且回车也属于字符。
所以我们要先对数据进行处理。
我们需要使用的的辅助工具就是getchar()了,不知道的人可以把getchar()作为一个爪子,每当一个char类型的字符被输入后,getchar()就可以准确的捕捉到他。
但是getchar()是会忽略每行第一个字符的。
所以我们可以定义一个数组,在取完第一个数后再使用getchar()。就可以把所有的0和1存储在一个n*m的二维数组中了。
再说dfs,就十分简单了,只需要判断可能走的8个方向,再使用一个计数器计数就可以了。
但是为了避免走重复的路,也是为了避免时间超限。所以我们可以定义一个bool类型的数组,记录走过的路。
同时在主函数中做写一个两层的嵌套循环,找到每个1,再进行dfs。
也要注意使用scanf和printf。
在最后也需要使用一个putchar(),相当于是输出一个字符。
论速度那个快 putchar(),getchar>scanf,printf>cin,cout。
#include#include #include #include #include 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); }
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
名称栏目:C++实现球迷今日头条面试题-创新互联
本文地址:http://myzitong.com/article/dicjhj.html