码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 2022百度之星初赛第三场--字符计数


    在一张白色背景的图像上,有一些色的字符。小度发现这些字符可以分成三类:不含任何洞的字符”1”,含个洞
    的字符"0”,含两个洞的字符“8”。现在, 用"示色背景,用"#" 示背景上的艷字迹,小度想问问你,
    这三类字符各有多少个?
    保证字符之间互不嵌套或重叠,字符的各个洞的位置不重叠,字符的每个"#"之间四联通。
    格式
    输入格式:第一行两个整数n(1 ≤n≤1000)和m(1≤n≤1000)。
    随后n行,每行m个字符,示该该白图像。
    输出格式:输出一行三个整数,分别表示”1” 的个数、"0” 的个数和"8” 的个数。
    样例1
    输入: 3 11
    #.###. #####
    #.#.#.#.#.#
    #. ### . #####
    输出:111

     思路:通过bfs遍历所有未被遍历且联通在一起的‘#’,并计数,将得到的数字依次除以8,0,1所需的‘#’个数,并%掉相关数字,即可得到答案;

    AC代码:

    1. #include
    2. #include
    3. #include
    4. #include
    5. #include
    6. #include
    7. #include
    8. #include
    9. using namespace std;
    10. #define ll long long
    11. #define PII pair
    12. const int N=1010;
    13. int n,m;
    14. int dx[]={0,0,1,-1},dy[]={1,-1,0,0};
    15. char mp[N][N];
    16. bool st[N][N];
    17. queueq;
    18. int r1,r0,r8;
    19. void bfs(int sx,int sy)
    20. {
    21. int cnt=0;
    22. q.push({sx,sy});
    23. st[sx][sy]=1;
    24. while(q.size())
    25. {
    26. cnt++;
    27. PII t=q.front();
    28. q.pop();
    29. for(int i=0;i<4;i++)
    30. {
    31. int xx=t.first+dx[i],yy=t.second+dy[i];
    32. if(xx<0||xx>n-1||yy<0||yy>m-1)
    33. continue;
    34. if(st[xx][yy]||mp[xx][yy]=='.')
    35. continue;
    36. q.push({xx,yy});
    37. st[xx][yy]=1;
    38. }
    39. }
    40. r8+=cnt/13;
    41. cnt%=13;
    42. r0+=cnt/8;
    43. cnt%=8;
    44. r1+=cnt/3;
    45. }
    46. int main()
    47. {
    48. scanf("%d%d",&n,&m);
    49. for(int i=0;i
    50. scanf("%s",mp[i]);
    51. int res=0;
    52. for(int i=0;i
    53. for(int j=0;j
    54. if(!st[i][j]&&mp[i][j]=='#')
    55. bfs(i,j);
    56. printf("%d %d %d\n",r1,r0,r8);
    57. }

  • 相关阅读:
    Win10鼠标宏怎么设置?电脑设置鼠标宏的方法
    2019CCF非专业级别软件能力认证第一轮
    通过VScode连接远程 Linux 服务器修改vue代码
    《HCIP-openEuler实验指导手册》1.3Apache动态功能模块加载卸载练习
    ThingsBoard IoT Gateway 实战(三)- 使用 MQTT Connector 转接灯
    AI识万物:从0搭建和部署手语识别系统 ⛵
    A_B001_01 stc-isp 单片机烧录软件安装与使用
    GitLab CI/CD
    深度学习-N维数组和访问元素
    三、数据仓库实践-拉链表设计
  • 原文地址:https://blog.csdn.net/qq_62242287/article/details/126693149
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号