P3654 First Step (ファーストステップ)(贪心算法)

cpp 复制代码
#include<bits/stdc++.h> 
using namespace std;

int main() {
	int r,c,k;
	cin>>r>>c>>k;
	char a[105][105];
	int ans=0;
	
	for(int i=0;i<r;i++){
		for(int j=0;j<c;j++){
			cin>>a[i][j];
		}
	}
	
	for(int i=0;i<r;i++){
		int cnt=0; // 用来记录连续空地的数量
		for(int j=0;j<c;j++){
			if(a[i][j]=='.'){
				cnt++; // 如果是空地,连续空地计数增加
			} else{
				if(cnt>=k) ans+=cnt-k+1;// 连续空地数大于等于 K 时,可以放置队员
				cnt=0; // 重置连续空地计数
			}
		}
		if(cnt>=k){ // 行末还有连续空地的情况,需要处理
			ans+=cnt-k+1;
		}
	}
	
	for(int j=0;j<c;j++){
		int cnt=0;
		for(int i=0;i<r;i++){
			if(a[i][j]=='.'){
				cnt++;
			} else{
				if(cnt>=k) ans+=cnt-k+1;
				cnt=0;
			}
		}
		if(cnt>=k) ans+=cnt-k+1;
	}
	if(k==1) ans/=2;// 如果 K == 1,则需要除以 2,因为每个空地计算了两次
	cout<<ans;
	
}

水平扫描(按行)

  • 对每一行进行扫描,累积每段连续的空地数量。
  • 当遇到杂物(#)时,检查当前空地段的长度 cnt 是否大于等于 k,如果满足条件,则可以放置队员,且可以从中选 cnt - k + 1 个位置。
  • 对每行扫描完后,检查该行末尾是否存在连续的空地段(例如 ...),并更新答案。

垂直扫描(按列):

  • 对每一列进行类似的操作,累积连续空地并检查可行的站位方式。

注意: 如果 k == 1,则每个空地点都会被统计两次。因此,最终答案需要除以 2。

相关推荐
老黄编程几秒前
三维空间圆柱方程
算法·几何
虾米Life9 分钟前
基于微服务脚手架的视频点播系统 (仿B站) [客户端] -1
c++·qt·微服务·架构
落羽的落羽20 分钟前
【C++】现代C++的新特性constexpr,及其在C++14、C++17、C++20中的进化
linux·c++·人工智能·学习·机器学习·c++20·c++40周年
xier_ran42 分钟前
关键词解释:DAG 系统(Directed Acyclic Graph,有向无环图)
python·算法
CAU界编程小白1 小时前
数据结构系列之十大排序算法
数据结构·c++·算法·排序算法
执携1 小时前
数据结构 -- 树(遍历)
数据结构
头发还没掉光光1 小时前
Linux网络初始及网络通信基本原理
linux·运维·开发语言·网络·c++
好学且牛逼的马1 小时前
【Hot100 | 6 LeetCode 15. 三数之和】
算法
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——二分查找
算法·leetcode·面试·职场和发展·c/c++
lkbhua莱克瓦242 小时前
Java基础——常用算法4
java·数据结构·笔记·算法·github·排序算法·快速排序