当前位置: 首页 > news >正文

C++ 字母大小写转换两种方法统计数字字符的个数

目录

题目:

代码1:

代码2:

题目描述输入一行字符,统计出其中数字字符的个数。

代码如下:

判断⼀个字符是否是数字字符有⼀个函数是 isdigit ,可以直接使⽤。

代码如下:


题目:

大家都知道一些办公软件有自动将字母转换为大写的功能。输入一个长度不超过 
100
100 且不包括空格的字符串。要求将该字符串中的所有小写字母变成大写字母并输出。

输入格式
输入一行,一个字符串。

输出格式
输出一个字符串,即将原字符串中的所有小写字母转化为大写字母。

输入输出样例
输入 
Luogu4!
输出 
LUOGU4!

代码1:

#include<iostream>
using namespace std;
const int N = 110;
char s[N];
int main()
{cin >> s;for(int i = 0; s[i] != '\0'; i++){if(s[i] >= 'a' && s[i] <= 'z') //如果是⼩写字⺟ {s[i] -= 32; //转换成⼤写 }}cout << s <<endl;
}

这⾥再给⼤家介绍两个函数: islower 和 tolower ,需要的头⽂件是 <cctype>
字符分类函数和字符转换函数:https://legacy.cplusplus.com/reference/cctype/
int islower ( int c ); //判断字符是否是⼩写字⺟ 
int tolower ( int c ); //转换成⼩写字⺟ 
islower 是C/C++中提供的⼀个判断字符是否是⼩写字⺟的函数,如果参数 c 是⼩写字⺟,函数返
回⼀个⾮0的数字,如果不是⼩写字⺟,函数返回0,其实还有⼀个函数是 isupper ,是判断⼤写字
⺟的。
tolower 是C/C++中提供的⼀个将参数 c 从⼤写字⺟转化成⼩写字⺟的函数,通过返回值返回转换
后的⼩写字⺟。如果 c 本⾝就是⼩写字⺟,则什么都不发⽣。还有⼀个函数是 toupper ,是⼩写字⺟转换成⼤写的。
有了上⾯的函数掌握,上⾯的代码就可以改写成:

代码2:

#include <iostream>
#include <cctype>
using namespace std;
const int N = 110;
char s[N];
int main()
{cin >> s;for(int i = 0; s[i] != '\0'; i++){if(islower(s[i])){s[i] = toupper(s[i]);}}cout << s <<endl;
}

题目描述
输入一行字符,统计出其中数字字符的个数。

输入格式
一行字符串,总长度不超过 
255

输出格式
输出为 
1
1 行,输出字符串里面数字字符的个数。

输入输出样例
输入 
Today is 2021-03-27
输出 
8

代码如下:

//代码1 
#include <iostream>
using namespace std;
const int N = 266;
char arr[N];
int main()
{//使⽤fgets读取带空格的字符串时,会读取到\n,并将\n也读取到arr中,会⾃动在末尾加上\0 fgets(arr, N, stdin);int i = 0;int c = 0;while (arr[i] != '\n') //这⾥判断是否等于\n,来觉得是否结束 {if (arr[i] >= '0' && arr[i] <= '9')c++;i++;}cout << c << endl;return 0;
}
//代码2 
#include <iostream>
using namespace std;
const int N = 266;
char arr[N];
int main()
{//下⾯这种读取⽅式遇到\n就停⽌,不会讲\n存⼊arr,会⾃动在末尾存放\0 scanf("%[^\n]s", arr);int i = 0;int c = 0;while (arr[i] != '\0') //这⾥判断是否等于\0,来觉得是否结束 {if (arr[i] >= '0' && arr[i] <= '9')c++;i++;}cout << c << endl;return 0;
}

上面代码注意while循环中判断条件,一个是是否是“\n”,一个是是否是'\0'。

判断⼀个字符是否是数字字符有⼀个函数是 isdigit ,可以直接使⽤。

int isdigit ( int c ); 如果参数 c 是数字字符,则返回⾮ 0 的值,如果不是数字字符,则返回 0 。

代码如下:

#include <iostream>
#include <cctype>
using namespace std;
const int N = 266;
char arr[N];
int main()
{//下⾯这种读取⽅式遇到\n就停⽌,不会讲\n存⼊arr,会⾃动在末尾存放\0 scanf("%[^\n]s", arr);int i = 0;int c = 0;while (arr[i] != '\0') //这⾥判断是否等于\0,来觉得是否结束 {if (isdigit(arr[i]))c++;i++;}cout << c << endl;return 0;
}

http://www.lryc.cn/news/530154.html

相关文章:

  • 如何使用 ChatBox AI 简化本地模型对话操作
  • 前端面试笔试题目(一)
  • Docker Hello World
  • UE 5.3 C++ 对垃圾回收的初步认识
  • ARM内核:嵌入式时代的核心引擎
  • 需求分析应该从哪些方面来着手做?
  • 【Unity2D 2022:C#Script】DoTween插件的使用
  • 【Docker】ubuntu中 Docker的使用
  • 【数据结构篇】时间复杂度
  • linux 环境安装 dlib 的 gpu 版本
  • springboot集成钉钉,发送钉钉日报
  • 【机器学习】自定义数据集 使用scikit-learn中svm的包实现svm分类
  • 快速提升网站收录:利用网站历史数据
  • 【Git】初识Git Git基本操作详解
  • Python NumPy(11):NumPy 排序、条件筛选函数
  • AJAX综合案例——图书管理
  • JDK自带工具解析与生产问题定位指南(一)
  • FPGA 使用 CLOCK_DEDICATED_ROUTE 约束
  • 《解锁AI黑科技:数据分类聚类与可视化》
  • Java小白入门教程:Object
  • 记6(人工神经网络
  • stm32硬件实现与w25qxx通信
  • 编程题-最接近的三数之和
  • 索引的底层数据结构、B+树的结构、为什么InnoDB使用B+树而不是B树呢
  • 【工欲善其事】利用 DeepSeek 实现复杂 Git 操作:从原项目剥离出子版本树并同步到新的代码库中
  • 网络编程套接字(中)
  • 前端学习-事件委托(三十)
  • 线程池以及在QT中的接口使用
  • c语言操作符(详细讲解)
  • 【自然语言处理(NLP)】深度学习架构:Transformer 原理及代码实现