CF 1900A Cover in Water 学习笔记

原题链接

传送门

题意

给定多个细胞,细胞有两种情况,一种情况是空的,另一种情况是阻塞的,可以往空的细胞里面装水,可以把装水细胞里面的水转移到另一个细胞里面,阻塞的细胞不能进行任何操作,如果一个空的细胞左右两边的细胞都有水,该细胞也会有水(大概类似于渗透作用),问需要多少水可以使得所有的空细胞里面装满水

代码

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

int main()
{
	int t;
	scanf("%d",&t);
	
	while(t--)
	{
		int n;
		scanf("%d",&n);
		string s;
		cin>>s;
		
		int length=s.size();
		bool flag=false;
		int cnt=0;
		for(int i=0;i<length;i++)
		{
			if(s[i]=='.'&&s[i+1]=='.'&&s[i+2]=='.')	
			{
				flag=true;
				break;
			}
			if(s[i]=='.')	cnt++;
		}
		
		if(flag==true)	printf("2\n");
		else	printf("%d\n",cnt);
	}
	
	return 0;
}

总结

1.遍历所有细胞,发现有连续的三个空细胞,可以把第一个和第三个空细胞装满水,中间的空细胞会因为类似渗透作用的原因充满水,然后把中间的空细胞的水取走,转移到其他空细胞,中间的空细胞又会因为渗透作用充满水,也就是说拥有了源源不断的水,只要出现连续的三个空细胞,只需要两份水,可以满足任意多的空细胞的要求

2.如果没有连续的三个空细胞,有多少个空细胞就需要多少份水

3.字符串长度使用s.zize()来计算

相关推荐
陈天伟教授14 分钟前
基于学习的人工智能(3)机器学习基本框架
人工智能·学习·机器学习·知识图谱
毕设源码-钟学长14 分钟前
【开题答辩全过程】以 高校课程学习评价系统设计与实现为例,包含答辩的问题和答案
学习
chinesegf16 分钟前
图文并茂的笔记、便签是如何用py开发的
笔记·状态模式
fruge2 小时前
从第三方库中偷师:学习 Lodash 的函数封装技巧
学习
lingggggaaaa5 小时前
免杀对抗——C2远控篇&C&C++&DLL注入&过内存核晶&镂空新增&白加黑链&签名程序劫持
c语言·c++·学习·安全·网络安全·免杀对抗
陈天伟教授5 小时前
基于学习的人工智能(5)机器学习基本框架
人工智能·学习·机器学习
我先去打把游戏先5 小时前
ESP32学习笔记(基于IDF):基于OneNet的ESP32的OTA功能
笔记·物联网·学习·云计算·iphone·aws
初願致夕霞5 小时前
学习笔记——基础hash思想及其简单C++实现
笔记·学习·哈希算法
小女孩真可爱6 小时前
大模型学习记录(五)-------调用大模型API接口
pytorch·深度学习·学习
hd51cc6 小时前
C++ 学习笔记 名称
笔记·学习