Codeforces Round 866 (Div. 2)

A. Yura's New Name

题意:

给出一个仅由_或^组成的字符串,你可以在任意位置添加_或^字符,使得字符串满足:
任意字符要么属于^_^的一部分,要么属于^^的一部分。求最少添加的字符数量。

分析:

  1. 对于_我们只需处理没有组成^_^的_:
    ①如果_在首位置且左边没有^则添加^
    ②如果_在尾位置且右边没有^则添加^
    ③如果_在中间部分且右边没有^则添加^
  2. 当字符串只有一个^时末尾添加一个^

code:

#include <bits/stdc++.h>
using namespace std;

int main()
{
	std::ios::sync_with_stdio(false);
	cin.tie(0), cout.tie(0);
	
	int t;
	cin >> t;
	
	while (t --)
	{
		string s;
		cin >> s;
		
		int cnt = 0;
		for (int i = 0; i < s.size(); i ++)
		{
			if (!i && s[i] == '_')
				cnt ++;
			if (s[i] == '_' && i + 1 < s.size() && s[i + 1] != '^') 
				cnt ++;
		}
		
		if (s[s.size() - 1] == '_' || (s.size() == 1 && s[0] == '^'))
			cnt ++;
			
		cout << cnt << endl;
	}
	
	return 0;
}

B. JoJo's Incredible Adventures

题意:

给定一个长度为n的01串,每次向右循环移动一位,例如00111->10011,循环移动n-1次,得到一个n×n的矩阵。取一个最大的子矩阵,这个矩阵的元素均为1,求其面积。

分析:

  1. 若全为1:S_max = n × n。
  2. 若不全为1:
    考虑全为1的最长子串,其长度为k。设矩阵的长宽分别为a, b。则a + b = k + 1。
    S = ab,S当且仅当a = b = (k + 1) / 2时取最大值(基本不等式)。由于每移动一次a减1,b 加1,当a = b = (k + 1) / 2时一共移动(k + 1) / 2 - 1次,(k + 1) / 2 - 1 < n - 1,所以S_max能取到。

code:

#include <bits/stdc++.h>
using namespace std;

typedef long long LL;

int main()
{
	std::ios::sync_with_stdio(false);
	cin.tie(0), cout.tie(0);
	
	int t;
	cin >> t;
	
	while (t --)
	{
		string s;
		cin >> s;
		
		if (s.size() == 1)
			cout << (s[0] == '0' ? 0 : 1) << endl;
		else
		{
			LL len_m = 0, n = s.size();
			int idx = s.find('0');
			if (idx == -1)
				cout << n * n << endl;
			else
			{
				s += s;
				for (int i = 0; i < s.size(); i ++)
				{
					LL len = 0;
					while (s[i] == '1' && i < s.size())
						len ++, i ++;
					len_m = max(len_m, len);
				}
				cout << (len_m + 1) * (len_m + 1) / 4 << endl;
			}
		}
	}
	
	return 0;
}

C. Constructive Problem

题意:

能否只进行一次操作:"将序列a中的某个子序列修改为k",使得mex(a)恰好比原来多1。
mex(a)即不在集合a中的最小非负整数。

分析:

  1. 当只有一个元素时:若该元素不为0则输出"Yes",否则输出"No"
  2. 当有多个元素时:
    ①序列中不存在Mex + 1:只有当原序列是0,1,2,...,n - 1即n = Mex时输出"No",否则输出"Yes"。因为当n != Mex时我们可以将任意比Mex大的元素换成Mex使得最后mex(a) = Mex + 1
    ②序列中存在Mex:目的是增加Mex,消去Mex + 1。考虑贪心,将包含Mex + 1的最短子序列全部赋值为Mex,最后check一下mex(a)是否等于Mex + 1,如果等于输出"Yes"否则输出"No"。

code:

#include <bits/stdc++.h>
using namespace std;

typedef long long LL;
const int N = 2e6 + 5;
int a[N];

int Mex(int b[], int n)
{
	set<int> s;
	
	for (int i = 0; i < n; i ++)
		s.insert(b[i]);
	
	for (int i = 0;; i ++)
		if (s.count(i) == 0)
			return i;
}

int main()
{
	std::ios::sync_with_stdio(false);
	cin.tie(0), cout.tie(0);
	
	int t;
	cin >> t;
	
	while (t --)
	{
		int n;
		cin >> n;
		
		unordered_map<int, int> mp; 
		int mex = 0, mex2 = 0;
		
		for (int i = 0; i < n; i ++)
		{
			cin >> a[i];
			mp[a[i]] += 1;
		}
		
		mex = Mex(a, n);
		
		if (n == 1)
		{
			if (a[0] == 0)
				cout << "No" << endl;
			else
				cout << "Yes" << endl;
		}
		else
		{
			if (mp[mex + 1] == 0)
			{
				if (n == mex)
					cout << "No" << endl;
				else
					cout << "Yes" << endl;
			}
			else
			{
				int l = 0x3f3f3f3f, r = -1;
				for (int i = 0; i < n; i ++)
				{
					if (a[i] == mex + 1)
					{
						l = min(l, i);
						r = max(r, i);
					}
				}
				for (int i = l; i <= r; i ++)
					a[i] = mex;
				
				mex2 = Mex(a, n);
				
				if (mex2 == mex + 1)
					cout << "Yes" << endl;
				else
					cout << "No" << endl;
			}
		}
	}
	
	return 0;
}

原文链接:https://www.cnblogs.com/XiongTingyang/p/17323325.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Codeforces Round 866 (Div. 2) - Python技术站

(0)
上一篇 2023年4月25日
下一篇 2023年4月25日

相关文章

  • python通过BF算法实现关键词匹配的方法

    以下是关于“Python通过BF算法实现关键词匹配的方法”的完整攻略: 简介 BF算法是一种简单的字符串匹配算法,它通过暴力枚举的方式在文本中查找关键词。本教程将介绍如何使用Python通过BF算法实现关键词匹配,并提供两个示例。 算法实现 BF算法是一种简单的字符串匹配算法,它通过暴力枚举的方式在文本中查找关键词。具体来说,我们将关键词从文本的第一个字符开…

    python 2023年5月14日
    00
  • pytorch 液态算法实现瘦脸效果

    以下是关于“PyTorch液态算法实现瘦脸效果”的完整攻略: 简介 液态算法是一种基于深度学习的图像处理技术,可以实现对人脸的瘦脸、美白、祛斑等效果。在本教程中,我们将介绍如何使用PyTorch实现液态算法,实现瘦脸效果。 原理 液态算法的实现原理包括人脸检测、关键点定位、三维变形等步骤。在本教程中,我们将使用PyTorch实现人脸检测和关键点定位,使用三维…

    python 2023年5月14日
    00
  • Python实现常见的几种加密算法(MD5,SHA-1,HMAC,DES/AES,RSA和ECC)

    Python实现常见的几种加密算法 在计算机安全领域,加密算法是非常重要的一部分。加密算法可以保护数据的机密性完整性和可用性。在本文中,我们将介绍常见的种加密算法,包括MD5,SHA-1,HMAC,DES/AES,RSA和ECC,并提供Python实现的完整攻略。 MD5 MD5是一种常见的哈希函数,它可以将意长度的消息转换为一个128位的哈希值。MD5算法…

    python 2023年5月13日
    00
  • 利用PyTorch实现爬山算法

    利用PyTorch实现爬山算法 爬山算法(Hill Climbing)是一种基于局部搜索的优化算法,它的主要思想是从当前解的邻域中选择一个更优的解作为下一次搜索的起点,直到找到最优解或达到最大迭代次数。本文将详细讲解如何使用PyTorch实现爬山算法,并提供两个示例说明。 爬山算法原理 爬山算法的基本思想是从当前解的邻域中选择一个更优的解作为下一次搜索的起点…

    python 2023年5月14日
    00
  • 决策树剪枝算法的python实现方法详解

    下面是详细讲解“决策树剪枝算法的Python实现方法”的完整攻略,包括算法原理、Python实现和两个示例说明。 算法原理 决策树剪枝算法是一种用于减少决策树复杂度的技术,通过去除一些不必要的分支和叶子节点,从而提高决策树的泛化能力和预测性能。其基本思想是决策树的训练过程中,先生成一棵完整的决策树,然后通过对决策树进行剪枝,去除一些不必要的分支和叶子节点,从…

    python 2023年5月14日
    00
  • C++20中的结构化绑定类型示例详解

    ” C++20中的结构化绑定类型示例详解 ” 具体攻略如下: 什么是结构化绑定类型? 结构化绑定类型是C++17中的新特性,它可以让我们将一个复杂类型的元素绑定到某个变量上,从而更方便地使用这些元素。 C++20还进一步扩展了结构化绑定类型的功能,可以通过给用于引用的名字声明类型来进行显式类型的绑定。 结构化绑定类型的基本用法 下面的例子展示了如何使用结构化…

    数据结构 2023年5月17日
    00
  • 浅谈机器学习需要的了解的十大算法

    下面是详细讲解“浅谈机器学习需要的了解的十大算法”的完整攻略,包含两个示例说明。 机器学习需要了解的十大算法简介 机器学习需要了解的十大算法是指在机器学习领域中需要掌握的十种算法。这些算法包括线性回归、逻辑回归、决策树、随机森林、支持向量机、朴素贝叶斯、K近邻、神经网络、聚类和降维。这些算法在不同的场景下都有广泛的应用。 线性回归算法 线性回归算法是一种基于…

    python 2023年5月14日
    00
  • python实现高斯判别分析算法的例子

    Python实现高斯判别分析算法的例子 高斯判别分析(Gaussian Discriminant Analysis,GDA)是一种经典的分类算法,它假设每个类别的数据都服从高斯分布,并通过最大化似然函数来估计模型参数。在本攻略中,我们将介绍如何使用Python实现高斯判别分析算法,并提供两个示例来说明如何使用高斯判别分析算法进行分类。 步骤1:了解高斯判别分…

    python 2023年5月14日
    00
合作推广
合作推广
分享本页
返回顶部