• 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. }

  • 相关阅读:
    python+nodejs+vue医院信息管理系统
    距平图(标签-AR)
    数学建模 -- 层次分析法(AHP)
    网页优化(布局优化、图片优化)
    精彩回顾:CACTER邮件数据防泄露EDLP亮相2022世界互联网大会
    嵌入式-DMA
    点乘和余弦相似度
    Win:使用组策略启用和禁用 USB 驱动器
    在LMMS中导入mid文件并播放
    Linux中的pstree 查看进程树、netstat 显示网络状态和端口占用信息
  • 原文地址:https://blog.csdn.net/qq_62242287/article/details/126693149