C++ 实现球迷 今日头条面试题

作者:FXY_ssf 时间:2022-07-08 11:03:24 

试题描述:

一个球场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);
}

总结

以上所述是小编给大家介绍的C++ 实现球迷 今日头条面试题网站的支持!

来源:https://www.cnblogs.com/FXY-180/p/9492160.html

标签:c++,今日头条,面试题
0
投稿

猜你喜欢

  • android阅读器长按选择文字功能实现代码

    2023-09-16 08:48:42
  • Visual Studio 2022 安装低版本 .Net Framework的图文教程

    2023-06-22 19:18:44
  • Java实现企业员工管理系统

    2023-08-22 16:44:50
  • Spring中的REST分页的实现代码

    2023-03-16 01:06:46
  • Android蓝牙通信编程

    2023-06-24 04:37:48
  • java当中的定时器的4种使用方式

    2022-08-07 14:31:39
  • Java异常处理中同时有finally和return语句的执行问题

    2022-08-14 15:28:30
  • SpringBoot预加载与懒加载实现方法超详细讲解

    2021-08-31 11:39:13
  • java数据结构基础:单链表与双向链表

    2023-03-02 09:21:59
  • Android实现自定义曲线图

    2023-08-22 07:05:01
  • Java微信跳一跳操作指南

    2022-07-06 11:14:36
  • C#中Lambda表达式的用法

    2022-12-22 15:59:17
  • Java数据导出功能之导出Excel文件实例

    2022-08-19 07:20:30
  • C# Resources资源详解

    2021-10-13 02:49:32
  • android图像绘制(四)自定义一个SurfaceView控件

    2022-09-27 11:28:07
  • Spring 代理 Bean 获取不到原始 Bean 对象注解解决方法

    2022-10-31 17:06:08
  • 在java poi导入Excel通用工具类示例详解

    2022-11-11 21:16:00
  • Unity动画混合树实例详解

    2022-06-17 14:41:27
  • C语言运算符优先级列表(超详细)

    2023-07-04 08:17:54
  • 详解Spring的两种代理方式:JDK动态代理和CGLIB动态代理

    2023-08-08 14:38:37
  • asp之家 软件编程 m.aspxhome.com