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。

相关推荐
苏宸啊5 分钟前
vecto底层模拟实现
c++
80530单词突击赢7 分钟前
STLVector底层原理与高效运用
数据结构·算法
一切尽在,你来8 分钟前
C++多线程教程-1.2.2 C++标准库并发组件的设计理念
开发语言·c++
haluhalu.11 分钟前
LeetCode---基础算法刷题指南
数据结构·算法·leetcode
iAkuya16 分钟前
(leetcode)力扣100 58组合总和(回溯)
算法·leetcode·职场和发展
80530单词突击赢18 分钟前
C++关联容器深度解析:set/map全攻略
java·数据结构·算法
m0_5613596718 分钟前
代码热更新技术
开发语言·c++·算法
兩尛25 分钟前
c++知识点1
java·开发语言·c++
冉佳驹33 分钟前
C++11 ——— 列表初始化、移动语义、可变参数模板、lamdba表达式、function包装器和bind包装器
c++·可变参数模板·移动构造·移动赋值·function包装器·bind包装器·lamdba表达式
_F_y42 分钟前
链表:重排链表、合并 K 个升序链表、K 个一组翻转链表
数据结构·链表