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。

相关推荐
滨HI0几秒前
C++ opencv简化轮廓
开发语言·c++·opencv
小青龙emmm2 分钟前
2025级C语言第二次周测(国教专用)题解
c语言·开发语言·算法
学习路上_write14 分钟前
FREERTOS_互斥量_创建和使用
c语言·开发语言·c++·stm32·单片机·嵌入式硬件
一起养小猫14 分钟前
《Java数据结构与算法》第三篇(下)队列全解析:从基础概念到高级应用
java·开发语言·数据结构
WolfGang00732132 分钟前
代码随想录算法训练营Day28 | 509.斐波那契数列、70.爬楼梯、746.使用最小花费爬楼梯
算法
Boop_wu35 分钟前
[Java EE] 多线程进阶(JUC)(2)
java·jvm·算法
闻缺陷则喜何志丹1 小时前
【SOSDP模板 容斥原理 逆向思考】3757. 有效子序列的数量|分数未知
c++·算法·力扣·容斥原理·sosdp·逆向思考
CoovallyAIHub2 小时前
如何在手机上轻松识别多种鸟类?我们发现了更简单的秘密……
深度学习·算法·计算机视觉
别动哪条鱼2 小时前
AVAudioFifo
数据结构·ffmpeg·音视频
第二只羽毛2 小时前
遵守robots协议的友好爬虫
大数据·爬虫·python·算法·网络爬虫