C++ 牛群 字符串类型简单统计

2023-12-24 06:36

本文主要是介绍C++ 牛群 字符串类型简单统计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

约翰有 n
头奶牛。

每头奶牛的品种由一个小写字母表示,不同奶牛的品种可能不同。

请问,能否将这些奶牛分为两个非空的牛群,并使得每个牛群都恰好包含两种奶牛。

例如,如果一共有 5
头奶牛,品种依次为 aabcc,则可将它们分为两个牛群 ab 和 acc,其中,第 1
个牛群恰好包含 a、b 两个品种的奶牛,第 2
个牛群恰好包含 a、c 两个品种的奶牛。

输入格式
共一行,包含一个长度为 n
的由小写字母构成的字符串,其中第 i
个字符表示第 i
头奶牛的品种。

输出格式
如果可以将这些奶牛分为两个非空的牛群,并使得每个牛群都恰好包含两种奶牛,则输出 Yes,否则输出 No。

数据范围
前 4
个测试点满足 1≤n≤5

所有测试点满足 1≤n≤105

输入样例1:
ababa
输出样例1:
Yes
输入样例2:
aabcc
输出样例2:
Yes
输入样例3:
abbb
输出样例3:
No

思路:这道题就是字符串类型统计的。我们要理解想到满足题目的分法,就必须要至少有2个类型的牛,并且最多4种。
那么我们可以先统计不同类型的牛的有几种,存在count里。如果为大于4或者小于2直接输出No。如果为3,就统计这三种牛的个数,需要至少满足一种牛个数大于等于2,否则不够分。如果为2种,那么2种牛都必须大于等于2个。

#include <iostream>using namespace std;int main ()
{string s;cin>>s;int n[26] = {0};for(auto x : s) n[x - 'a'] ++;int count = 0;for(int i = 0; i < 26; i ++) if(n[i] != 0) count ++;// cout<<count;if(count > 4 || count < 2) {cout<<"No"<<endl;return 0;} else if(count == 3){int num = 0;for(int i = 0; i < 26; i++) {if(n[i] < 2 && n[i] != 0) {num ++;}if(num >= 3) {cout<<"No"<<endl;return 0;}}} else if(count == 2) {for(int i = 0; i < 26; i++) {if(n[i] < 2 && n[i] != 0) {cout<<"No"<<endl;return 0;}}}cout<<"Yes"<<endl;return 0;
}

这篇关于C++ 牛群 字符串类型简单统计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/530863

相关文章

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

C#中字符串分割的多种方式

《C#中字符串分割的多种方式》在C#编程语言中,字符串处理是日常开发中不可或缺的一部分,字符串分割是处理文本数据时常用的操作,它允许我们将一个长字符串分解成多个子字符串,本文给大家介绍了C#中字符串分... 目录1. 使用 string.Split2. 使用正则表达式 (Regex.Split)3. 使用

opencv实现像素统计的示例代码

《opencv实现像素统计的示例代码》本文介绍了OpenCV中统计图像像素信息的常用方法和函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 统计像素值的基本信息2. 统计像素值的直方图3. 统计像素值的总和4. 统计非零像素的数量

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

Python中异常类型ValueError使用方法与场景

《Python中异常类型ValueError使用方法与场景》:本文主要介绍Python中的ValueError异常类型,它在处理不合适的值时抛出,并提供如何有效使用ValueError的建议,文中... 目录前言什么是 ValueError?什么时候会用到 ValueError?场景 1: 转换数据类型场景

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不