zoukankan      html  css  js  c++  java
  • C++ 球迷 今日头条面试题

    试题描述:

    一个球场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<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);
    	}
    
  • 相关阅读:
    Linux学习笔记(十四)磁盘管理(二):格式化、挂载以及Swap分区
    Linux学习笔记(十三)磁盘管理(一):磁盘分区
    Linux学习笔记(十二)VIM编辑器
    Linux学习笔记(十一)shell基础:管道符、通配符和其他特殊符号
    Linux学习笔记(十)shell基础:历史命令、命令补全、输出重定向、输出重定向
    Linux学习笔记(九)shell基础:echo、命令别名和常用快捷键
    Linux学习笔记(八)Linux常用命令:用户登录查看命令
    Linux学习笔记(七)Linux常用命令:挂载命令
    Linux学习笔记(六)Linux常用命令:关机、重启以及系统运行级别
    Python: 截屏
  • 原文地址:https://www.cnblogs.com/FXY-180/p/9492160.html
Copyright © 2011-2022 走看看