下面随笔给出c++ string类使用及用string类解决整行字符串输入。

string类

  • 使用字符串类string表示字符串

  • string实际上是对字符数组操作的封装

  string类常用的构造函数

  • string(); //默认构造函数,建立一个长度为0的串

  例:

  string s1;

  • string(const char *s); //用指针s所指向的字符串常量初始化string对象

  例:

  string s2 = “abc”;

  • string(const string& rhs); //复制构造函数

  例:

  string s3 = s2;

string类常用操作

  • s + t 将串s和t连接成一个新串

  • s = t 用t更新s

  • s == t 判断s与t是否相等

  • s != t 判断s与t是否不等

  • s < t 判断s是否小于t(按字典顺序比较)

  • s <= t 判断s是否小于或等于t (按字典顺序比较)

  • s > t 判断s是否大于t (按字典顺序比较)

  • s >= t 判断s是否大于或等于t (按字典顺序比较)

  • s[i] 访问串中下标为i的字符

  • 例:

    string s1 = "abc", s2 = "def";

    string s3 = s1 + s2; //结果是"abcdef"

    bool s4 = (s1 < s2); //结果是true

    char s5 = s2[1]; //结果是'e'

 1 //例 string类应用举例
2
3 #include <string>
4
5 #include <iostream>
6
7 using namespace std;
8
9 //根据value的值输出true或false
10
11 //title为提示文字
12
13 inline void test(const char *title, bool value)
14
15 {
16
17   cout << title << " returns "
18
19   << (value ? "true" : "false") << endl;
20
21 }
22
23 int main() {
24
25   string s1 = "DEF";
26
27   cout << "s1 is " << s1 << endl;
28
29   string s2;
30
31   cout << "Please enter s2: ";
32
33   cin >> s2;
34
35   cout << "length of s2: " << s2.length() << endl;
36
37   //比较运算符的测试
38
39   test("s1 <= \"ABC\"", s1 <= "ABC");
40
41   test("\"DEF\" <= s1", "DEF" <= s1);
42
43   //连接运算符的测试
44
45   s2 += s1;
46
47   cout << "s2 = s2 + s1: " << s2 << endl;
48
49   cout << "length of s2: " << s2.length() << endl;
50
51   return 0;
52
53 }

用string类解决输入整行字符串

  • 用cin的>>操作符输入字符串,会以空格作为分隔符,空格后的内容会在下一回输入时被读取

  输入整行字符串

  • getline可以输入整行字符串(要包string头文件),例如:

    getline(cin, s2);

  • 输入字符串时,可以使用其它分隔符作为字符串结束的标志(例如逗号、分号),将分隔符作为getline的第3个参数即可,例如:

    getline(cin, s2, ',');

 1 //例 用getline输入字符串
2
3 include <iostream>
4
5 #include <string>
6
7 using namespace std;
8
9 int main() {
10
11   for (int i = 0; i < 2; i++){
12
13     string city, state;
14
15     getline(cin, city, ',');
16
17     getline(cin, state);
18
19     cout << "City:" << city << “ State:" << state << endl;
20
21   }
22
23   return 0;
24
25 }
26
27 //运行结果:
28
29 Beijing,China
30
31 City: Beijing State: China
32
33 San Francisco,the United States
34
35 City: San Francisco State: the United States

c++ string类使用及用string类解决整行字符串输入的更多相关文章

  1. C/C++关于string.h头文件和string类

    学习C语言时,用字符串的函数例如stpcpy().strcat().strcmp()等,要包含头文件string.h 学习C++后,C++有字符串的标准类string,string类也有很多方法,用s ...

  2. hadoop中Text类 与 java中String类的区别

    hadoop 中 的Text类与java中的String类感觉上用法是相似的,但两者在编码格式和访问方式上还是有些差别的,要说明这个问题,首先得了解几个概念: 字符集: 是一个系统支持的所有抽象字符的 ...

  3. 深刻理解Java中final的作用(一):从final的作用剖析String被设计成不可变类的深层原因

    声明:本博客为原创博客,未经同意,不得转载!小伙伴们假设是在别的地方看到的话,建议还是来csdn上看吧(原文链接为http://blog.csdn.net/bettarwang/article/det ...

  4. 一些简单的帮助类(1)-- String的类型验证

    在工作中经常会遇到 验证String 中的值是否属于Int型或者是Bool又或是Date 一般的做法是用方法 类型.TryParse(string,类型) 来做验证. "; int intV ...

  5. JAVA基础--常用类 String,StringBuffer, 基础数据类型包装类, Math类, Enum类

    字符串相关类: String, StringBuffer String类为不可变的字符序列 String s1="hello"; String s2="hello&quo ...

  6. Java常用类之String类、Stringbuffer和Random类练习

    定义一个StringBuffer类对象, 1)使用append方法向对象中添加26个字母,并倒序遍历输入 2)删除前五个字符 package 第十一章常用类; /** * 定义一个StringBuff ...

  7. Java常用类(一)String类详解

    前言 在我们开发中经常会用到很多的常用的工具类,这里做一个总结.他们有很多的方法都是我们经常要用到的.所以我们一定要把它好好的掌握起来! 一.String简介 1.1.String(字符串常量)概述 ...

  8. JAVA不可变类(immutable)机制与String的不可变性

    一.不可变类简介 不可变类:所谓的不可变类是指这个类的实例一旦创建完成后,就不能改变其成员变量值.如JDK内部自带的很多不可变类:Interger.Long和String等. 可变类:相对于不可变类, ...

  9. java中的BigDecimal和String的相互转换,int和String的类型转换,Integer类和String相互转换

    一: /*由数字字符串构造BigDecimal的方法 *设置BigDecimal的小数位数的方法 */ 注:BigDecimal在数据库中存的是number类型. import java.math.B ...

随机推荐

  1. Codeforce 380A Sereja and Prefixes【二分】

    题意:定义两种操作 1 a ---- 向序列中插如一个元素a 2 a b ---- 将序列的前a个元素[e1,e2,...,ea]重复b次插入到序列中 经过一列操作后,为处于某个位置p的元素是多少.数 ...

  2. 2017-2018 ACM-ICPC Latin American Regional Programming Contest PART (11/13)

    $$2017-2018\ ACM-ICPC\ Latin\ American\ Regional\ Programming\ Contest$$ \(A.Arranging\ tiles\) \(B. ...

  3. codeforces#244(div.2) C

    动漫节一游回来之后一直处于一种意识模糊的状态 看到大家都陆陆续续地过了C心里还是有点着急(自己没思路啊囧) 其实当时就在想该如何找到DFS中的一个环,然后再找到环路上最小的一个值 把所有环路上最小的值 ...

  4. Buy the Ticket HDU - 1133 大数dp

    题意: 演唱会门票售票处,那里最开始没有零钱.每一张门票是50元,人们只会拿着100元和50元去买票,有n个人是拿着50元买票,m个人拿着100元去买票. n+m个人按照某个顺序按序买票,如果一个人拿 ...

  5. hdu4686 Arc of Dream

    Time Limit: 2000/2000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others) Total Submission ...

  6. Codeforces Round #177 (Div. 2) B. Polo the Penguin and Matrix (贪心,数学)

    题意:给你一个\(n\)x\(m\)的矩阵,可以对矩阵的所有元素进行\(\pm d\),问能否使得所有元素相等. 题解:我们可以直接记录一个\(n*m\)的数组存入所有数,所以\((a_1+xd)=( ...

  7. Linux程序设计——Linux基础

    1. 什么是Linux 1)Linux系统是一种自由和开放源代码的类UNIX的完整操作系统. 2)林纳斯·本纳第克特·托瓦兹(LinusBenedictTorvalds,1969年~) 3)诞生于19 ...

  8. hdu-1941 Find the Shortest Common Superstring

    The shortest common superstring of 2 strings S 1 and S 2 is a string S with the minimum number of ch ...

  9. int、long long等的取值范围

    unsigned   int   0-4294967295   int   -2147483648-2147483647 unsigned long 0-4294967295long   -21474 ...

  10. 手撕 part1

    1.宏定义三个数最大值 挺有意思 max((a), (b), (c)) (a) > (b)? ((a) > (c)? (a) : (c)) ((b) > (c)? (b) : (c) ...