统计字符串中数字个数
![](https://img-blog.csdnimg.cn/img_convert/faea5f69cfde6d244cbca08750e901df.png)
C语言中,字符串是以\0结尾的一些字符的集合,
C++中就引入了String类,它可以看做是一个管理字符串的数据结构。
string是表示字符串的字符串类。
string类是使用char(即它的字符类型)
string支持动态+字符,char不支持
————————————————
循环相克令
![](https://img-blog.csdnimg.cn/img_convert/020454e34fe6d91c63a8ed06ff0f83e0.png)
![](https://img-blog.csdnimg.cn/img_convert/cbb428f2310bbb1716d6e1727d81f53b.png)
tips:字符串采用数字赋值方法,进行字符串比较
3为一个循环,取模%3,
1赢0,
2赢1,
0赢2
因此x==(y+1)%3
————————————————
字符串加空格
一些知识点补充:
cin>> 或 scanf
用法1:输入一个数字或字符
用法2:接收一个字符串,遇“空格”、“TAB”、“回车”就结束,不能接收空格
getline(cin,字符串)
用法:接收一个字符串,可以接收空格并输出,需包含“#include<string>”
cin.getline(字符数组名,接收长度)
用法:接收一个字符串,可以接收空格并输出
属于istream流,而getline()属于string流,是不一样的两个函数
fgets( 数组名,几个元素 , stdin)
从输入流stdin即输入缓冲区中读取多少个字符到数组中
![](https://img-blog.csdnimg.cn/img_convert/f7b367247d3623d80f9c329d7bd6070b.png)
#include<iostream>
#include<string>
using namespace std;
int main(){
string a;
getline(cin, a);
string b;
for(auto c : a) b = b + c + ' ';//遍历a中的元素,赋予给c
//b.pop_back();//把最后一个字符删掉
cout << b << endl;
return 0;
}
C/C++中 auto 的含义是:auto是具有自动存储器的局部变量
auto c : a 遍历a中的元素,赋予给c
#include<iostream>
using namespace std;
int main(){
char str[101];
fgets(str, 101, stdin);
for(int i = 0; str[i] && str[i] != '\n'; i++){
cout << str[i] << " " ;
}
return 0;
}
替换字符
![](https://img-blog.csdnimg.cn/img_convert/7a18dbd31f08b2a86e2228fdb93923e8.png)
替换空格
开一个新的数组,从前往后遍历,赋值,c语言是静态数组
不知道总长度,遍历str数组,求出遍完总长度,分配整个空间,malloc出来一个数组,再从前往后挨个字母往里填
![](https://img-blog.csdnimg.cn/img_convert/634e34f7deb9943f9106d2ba25796336.png)
——————————————————
一些杂七杂八的零碎知识回顾
int str[10];定义了一个整型数组 >> scanf("%d",&str[i]);读入数组
万能头#include <bits/stdc++.h>
%c 单个字符
%d 十进制整数
%f 浮点数(包括float和doulbe)
%o 八进制整数 0123
%x 十六进制整数0f(0F) 0x1234
%p 指针
%s 字符串
scanf对末尾回车符的处理:把回车符保留在缓存中。scanf不会过滤回车
解决方法:
在scanf()中使用’\n’屏蔽回车符号。 scanf("%d\n",&n); //使用’\n’过滤回车scanf("%c",&c);
2.在scanf()格式串最前面添加空格,屏蔽回车字符 scanf("%d",&n);scanf(" %c",&c); //%c前面加空格,过滤回车
3.在接收字符前,使用getchar()来读取一次回车符号 scanf("%d",&n);getchar(); //专门用来读取上次输入的回车符号scanf("%c",&c);
——————————————————