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

相关文章

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

C++构造函数中explicit详解

《C++构造函数中explicit详解》explicit关键字用于修饰单参数构造函数或可以看作单参数的构造函数,阻止编译器进行隐式类型转换或拷贝初始化,本文就来介绍explicit的使用,感兴趣的可以... 目录1. 什么是explicit2. 隐式转换的问题3.explicit的使用示例基本用法多参数构造

C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解

《C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解》:本文主要介绍C++,C#,Rust,Go,Java,Python,JavaScript性能对比全面... 目录编程语言性能对比、核心优势与最佳使用场景性能对比表格C++C#RustGoJavapythonjav

MyBatis中的两种参数传递类型详解(示例代码)

《MyBatis中的两种参数传递类型详解(示例代码)》文章介绍了MyBatis中传递多个参数的两种方式,使用Map和使用@Param注解或封装POJO,Map方式适用于动态、不固定的参数,但可读性和安... 目录✅ android方式一:使用Map<String, Object>✅ 方式二:使用@Param

C++打印 vector的几种方法小结

《C++打印vector的几种方法小结》本文介绍了C++中遍历vector的几种方法,包括使用迭代器、auto关键字、typedef、计数器以及C++11引入的范围基础循环,具有一定的参考价值,感兴... 目录1. 使用迭代器2. 使用 auto (C++11) / typedef / type alias

GO语言实现串口简单通讯

《GO语言实现串口简单通讯》本文分享了使用Go语言进行串口通讯的实践过程,详细介绍了串口配置、数据发送与接收的代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录背景串口通讯代码代码块分解解析完整代码运行结果背景最近再学习 go 语言,在某宝用5块钱买了个

C# WebAPI的几种返回类型方式

《C#WebAPI的几种返回类型方式》本文主要介绍了C#WebAPI的几种返回类型方式,包括直接返回指定类型、返回IActionResult实例和返回ActionResult,文中通过示例代码介绍的... 目录创建 Controller 和 Model 类在 Action 中返回 指定类型在 Action