在C++中则把字符串封装成了一种数据类型string,可以直接声明变量并进行赋值等字符串操作。以下是C字符串和C++中string的区别:
C字符串 |
string对象(C++) |
|
所需的头文件名称 |
<string>或<string.h> |
<string>或<string.h> |
需要头文件 原因 |
为了使用字符串函数 |
为了使用string类 |
声明 方式 |
char name[20]; |
string name; |
初始化方式 |
char name[20]="nihao"; |
string name = "nihao"; |
必须声明字符串长度么? |
是 |
否 |
使用一个null字符么? |
是 |
否 |
字符串赋值 的实现方式 |
strcpy(name,"John"); |
name = "John"; |
优点 |
更快 |
更易于使用,优选方案 |
可以赋一个比现有字符更长的字符串么? |
不能 |
可以 |
C++常用字符串函数
char s1[]="I am a student";
char s2[20]="teacher";
char s3[]="student";
int result;
char s4[20],*p;
(1)串长度 int strlen(char *str)
cout<<strlen(s1)<<endl; 输出14
cout<<strlen(s2)<<endl; 输出7
(2)串拷贝 char *strcpy(char *str1,char *str2)
strcpy(s4,s2); //s4为"teacher"
(3)串连接 char *strcat(char *str1,char*str2)
strcat(s2,s3); //s2为"teacherstudent"
(4)串比较 int strcmp(char *str1,char *str) //比较的是对应字符的ASCII码值,如果str1>str2,返回1
result=strcmp(s2,s3); //result>0
result=strcmp(s2,s2); //result=0
result=strcmp(s3,s2); //result<0
(5)串定位 char *strchr(char *str,char ch)
p=strchr(s1,'s'); //找到返回字符在字串中的位置,否则返回-1
strcpy(p,s2); //s1为"I am a teacher"
(6)在一个串中查找是否存在和另一个串相等的子串
(7)截取子串形成一个新串
字符串的输入
(1)方法一:使用输入操符来填充一个C字符串变量
例如:
char a[80];
cin>>a;
注:以这种方式来读取C字符串时,会忽略最初的空白字符(空格、制表符和换行符),而且输入会在下一个空格或者换行符处停止。
(2)方法二:使用预定义函数getline获取整行输入(包括空格)
getline函数有两个参数:第一个参数用于接收输入的C字符串变量;第二个参数用于规定getline最多能接收的字符个数。
例如:
char a[80];
cin.getline(a,80);
当遇到行结束的时候,输入才会停止。
C++ string类的输入
(1)方法一:和C字符串输入的方法一相同。
(2)方法二:使用getline函数。
例如:
string a;
getline(cin,a);
string对象和C字符串之间的转换
可以将C字符串存储在string类型的变量中,例如:
char a[] = "nihao";
string b;
b=a;
但string对象不能自动的转换为C字符串,需要进行显式的类型转换,需要用到string类的成员函数c_str().
例如:
strcpy(a,b.c_str());
字符串到数字的转换
atoi函数获取一个C字符串参数,返回对应的int值。如果参数不与一个int值对应,atoi就会返回0。atoi函数在文件为cstdlib的库中。如果数字太大,不能转换成int类型的值,可以使用atol将字符串转换为long类型的值。
例如:
atoi("1234"); //返回整数1234
atoi("#123"); //返回0
//题目描述
//
//给定n个字符串,请对n个字符串按照字典序排列。
//输入描述 :
//输入第一行为一个正整数n(1≤n≤1000), 下面n行为n个字符串(字符串长度≤100), 字符串中只含有大小写字母。
//
//
//输出描述 :
//数据输出n行,输出结果为按照字典序排列的字符串。
//本题的考察很基础,但是有一些细节问题需要注意,在C语言中应注意C语言的所有字符串的本质是以空字符'\0'结束的字符数组,
//所以在C语言中对于字符串的比较不能使用> < == 这些常规的关系运算符,而要使用C语言标准库函数中的strcmp函数对字符串进行比较,
//比较的原则就是字典顺序,在C++中,string类对> < == 这些运算符进行了重载,可以直接用来比较字符串,比较的原则依然是字典顺序。
//剩下的就是考察排序方法,常用的冒泡排序、选择排序等等都可以实现,但是借助STL更方便
#include<iostream>
using namespace std;
#include<vector>
#include<string>
#include<algorithm>
int main()
{
int num;
while (cin>>num)
{
vector<string> ve;
string temp;
while (num--)
{
//scanf("%s",temp); //getline(cin,a);
//以前不是看的大量输入时用scanf ,printf代替cin ,cout吗??这里不行啊
cin >> temp;
ve.push_back(temp);
}
sort(ve.begin(),ve.end());
for (auto it=ve.begin(); it!= ve.end(); it++)
{
//printf("%s\n", *it); //printf("%s", s.c_str()); //不推荐
cout << *it << endl;
}
}
return 0;
}
C++中int型与string型互相转换
本以为这么多年C#经验,学个C++没多难,现在发现错了。C++真TM难。今天遇到int转string绊了半天,方法很多,不知道为什么搞那么复杂,
我只挑最简单易懂的,管他效率不效率的。
int转string
int n = 0;
std::stringstream ss;
std::string str;
ss<<n;
ss>>str;
string转int
std::string str = "123";
int n = atoi(str.c_str());