信息学奥赛第三节 —— 字符串3(对字符串使用sort/reverse + isupper() + islower() + isdigit())

本文主要是介绍信息学奥赛第三节 —— 字符串3(对字符串使用sort/reverse + isupper() + islower() + isdigit()),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

与字符串有关的函数

字符类型的判断:

  • isalpha(c) —— 是否是字母
  • islower(c) —— 是否是小写字母
  • isupper(c) —— 是否是大写字母
  • isdigit(c) —— 是否是数字

字符类型转换:

  • tolower() —— 转小写
  • toupper() —— 转大写

排序:

  • sort() —— 默认升序排序,常用sort(a,a + n)对整个数组排序,sort(a + 1,a + n - 1)对从第二个位置到倒数第二个位置排序。
  • reverse() —— 逆序输出元素

获取指针:

string s;
  • s.begin() —— 头指针
  • s.end() —— 为指针 最后一个位置的下一位

举例

toupper()

#include <iostream>
#include <string>using namespace std;int main()
{char c;cin >> c;//bc = toupper(c);//将小写字符转化为大写字符并返回大写字符的ASCII码cout << c << endl;//Breturn 0;
}

用sort对从第二个位置至倒数第二个位置排序

#include <algorithm>
#include <iostream>
#include <string>using namespace std;int main()
{int a[12] = {1000,5,6,3,4,9,8,7,11,55,10,1000};int n = 12;sort(a + 1,a + n - 1);for (int i = 0; i < n;i++) cout << a[i] << " ";//1000 3 4 5 6 7 8 9 10 11 55 1000return 0;
}

使用reverse对数组逆序输出

#include <algorithm>
#include <iostream>
#include <string>using namespace std;int main()
{int a[5] = {1,2,3,4,5};int n = 5;reverse(a,a + n);for (int i = 0; i < n;i++) cout << a[i] << " ";//5 4 3 2 1return 0;
}

对字符串使用sort和reverse

#include <algorithm>
#include <iostream>
#include <string>using namespace std;int main()
{string s1 = "abcde";string s2 = "bceda";reverse(s1.begin(),s1.end());//对s1进行逆序输出cout << s1 << endl;//edcbasort(s2.begin(),s2.end());//对s2进行排序cout << s2 << endl;//abcdereturn 0;
}
练习1 原题链接

题目描述

从键盘中任意输入一串字符,直至输入"#"字符代表结束.请编程统计输入的字符中的大写字母,小写字母和数字字符的个数分别是多少?

输入

输入只有一行,包括一串字符.(长度小于20)

输出

输出只有一行(这意味着末尾有一个回车符号),包括3个整数。分别代表大写字符,小写字符和数字字符的个数。

样例输入

daDSALDdcada3240#

样例输出

5 7 4

AC代码1:

#include <algorithm>
#include <iostream>
#include <string>using namespace std;int main()
{string s;getline(cin,s);//读入字符串int len = s.size();int daxie = 0,xiaoxie = 0,shuzi = 0;//用来计数for (int i = 0;i < len;i++)//遍历字符串中的元素{if (s[i] == '#') break;//读到结束标志if (s[i] >= 'A' && s[i] <= 'Z') daxie++;else if (s[i] >= 'a' && s[i] <= 'z') xiaoxie++;else shuzi++;}cout << daxie << " " << xiaoxie << " " << shuzi << endl;return 0;
}

补充:本题的思路很简单,只需要遍历字符串的元素,依次统计个数即可。需要强调一下,代码编写完之后,可以通过输入一些特殊的测试样例来大概测试一下代码的正确性。如:

  • 输入AAAAAAAAAA#,程序应该输出10 0 0。(10个大写字母)
  • 输入aaaaaaaaaa#,程序应该输出0 10 0。(10个小写字母)
  • 输入1111111111#,程序应该输出0 0 10。(10个数字)

当然,也可以利用前面介绍的一些函数来实现:
AC代码2:

#include <algorithm>
#include <iostream>
#include <string>using namespace std;int main()
{string s;getline(cin,s);int len = s.size();int daxie = 0,xiaoxie = 0,shuzi = 0;for (int i = 0;i < len;i++){if (s[i] == '#') break;if (isupper(s[i])) daxie++;else if (islower(s[i])) xiaoxie++;else if (isdigit(s[i])) shuzi++;}cout << daxie << " " << xiaoxie << " " << shuzi << endl;return 0;
}
练习2 原题链接

题目描述

James在一节C++课程上,准备为自己的程序定义变量名称。老师告诉James,一个合法的变量名应该满足如下的三个条件:
1、只能由字母(大写或者小写)、数字及下划线(_)组成
2、不能以数字开头
3、不能是C++中有特殊含义的单词,由于James是C++的初学者,只学过int、double、cout、cin这四个有特殊含义的单词,因此James只要避开这几个单词就可以。
请你编程帮助James判断他定义的变量名是否合法。

输入

一行,包含一个字符串,是James为变量起的名字,且长度不大于20。

输出

一行,如果是合法的C++变量名,则输出yes,否则输出no。

样例输入

sum

样例输出

yes

AC代码

#include <algorithm>
#include <iostream>
#include <string>using namespace std;bool is_law(string s)//用来判断变量名是否合法
{int len = s.size();if (isdigit(s[0])) return false;//以数字开头if (s == "cin" || s == "cout" || s == "int" || s == "double") return false;//关键字重合for (int i = 0;i < len;i++)//遍历字符{//既不是大写字母也不是小写字母也不是下划线if (!isupper(s[i]) && !islower(s[i]) && s[i] != '_') return false;}return true;
}int main()
{string s;getline(cin,s);if (is_law(s)) cout << "yes" << endl;else cout << "no" << endl;return 0;
}

这篇关于信息学奥赛第三节 —— 字符串3(对字符串使用sort/reverse + isupper() + islower() + isdigit())的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

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

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

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min