C++中数字与字符串之间的转换 scanf string总结(复习必读)
1 string的scanf读入操作
C++里面控制台输入直接使用cin操作就可以了;或者getline(istringstream,string);
字符和数字加减就是字符的ASCII码和数字直接加减。
只有内置类型int,float,char,double,bool可以直接赋值,scanf读入string不能直接使用scanf直接赋值,因为string是一个类class,有专门的初始化函数,不能使用scanf,同理gets接收的也是一个char指针。编程语言自带的sizeof也是一样,不能对string进行直接操作。
string s;
s.resize();
scanf("%s",&s[]);
或者:
string s;
char *c = new char();
scanf("%s",c);//scanf("%s",&c[0]);
s = c;//给首地址
strlen是得到输入的有效字符串,而不是开辟的空间大小100.
strlen所作的仅仅是一个计数器的工作,它从内存的某个位置(可以是字符串开头,中间某个位置,甚至是某个不确定的内存区域)开始扫描,直到碰到第一个字符串结束符'\0'为止,然后返回计数器值。--就是指实际字符串或字符数组的实际长度(不是所占空间的字节数)。
char A[6]={'a','b','\0','d','e','r'};
int i=strlen(A); //i为2,因为到’\0’结束,故实际A[]只有2个元素
sizeof()
string s;
char *c = new char();
scanf("%s",c);
int len = strlen(c);
s1.resize(len);//动态编译
s1.assign(c,c + len);//copy(c,c + len,s1.begin());针对其他结构
class X
{
int i;
int j;
char k;
};
X x;
cout<<sizeof(X)<<endl; 结果 12 ===》内存补齐
cout<<sizeof(x)<<endl; 结果 12 同上
解释一下,在class X中,成员中最大的所占的空间为int类型所占的空间4个字节,故内存补齐,最后结果为: ((int)(实际成员所占内存空间的和/4)+1)*4
*所以不能通过sizeof(string) / sizeof(string[0])得到实际char元素个数,不管string等于多少,最后的结果都是28;因为string是一个class。
copy()用法:
此算法接收三个迭代器iterator,前两个表示一个输入范围,第三个表示目的序列的起始位置。
char 和int 的转换:
int = char - '0';
char = int + '0';
2 C++中数字与字符串之间的转换(important)
1、字符串数字之间的转换
(1)string --> char *
string str("OK");
const char * p = str.c_str();
(2)char * -->string
char *p = "OK";
string str(p);
(3)string->double
double d=atof(s.c_str());
常用函数atoi(),itoa(),to_string();
2、数字转字符串:使用sprintf()函数
char str[10];
int a=1234321;
sprintf(str,"%d",a);
--------------------
char str[10];
double a=123.321;
sprintf(str,"%.3lf",a);
--------------------
char str[10];
int a=175;
sprintf(str,"%x",a);//10进制转换成16进制,如果输出大写的字母是sprintf(str,"%X",a)
--------------------
char *itoa(int value, char* string, int radix);
同样也可以将数字转字符串,不过itoa()这个函数是平台相关的(不是标准里的),故在这里不推荐使用这个函数。
3、字符串转数字:使用sscanf()函数
char str[]="1234321";
int a;
sscanf(str,"%d",&a);
.............
char str[]="123.321";
double a;
sscanf(str,"%lf",&a);
.............
char str[]="AF";
int a;
sscanf(str,"%x",&a); //16进制转换成10进制
另外也可以使用atoi(),atol(),atof().
4、使用stringstream类
用ostringstream对象写一个字符串,类似于sprintf()
ostringstream s1;
int i = 22;
s1 << "Hello " << i << endl;
string s2 = s1.str();
cout << s2;
用istringstream对象读一个字符串,类似于sscanf()
istringstream stream1;
string string1 = "25";
stream1.str(string1);
int i;
stream1 >> i;
cout << i << endl; // displays 25
3 string类的所有函数操作总结
1、初始化string
string s = "";
string s("");
string s(n,'c');
string s(s1,pos2);//s是s2从下标pos2开始的字符的拷贝
string s(s1,pos2,len2);//s是s2从下标pos2开始len2个字符的拷贝
2、string基本操作
2.1 输入:以回车或者空格分开,或者文件末尾EOF;
cin >> s;
getline(cin,s);
getline(istringstream,s);
2.2 c风格的string函数(下面的必须以'\0'结尾的字符串)
strlen(p); //返回p的长度,不包含结尾‘\0’
strcmp(p1,p2); //p1 == p1 -> 返回0,p1 > p2 -> 返回正值,p1 < p2返回负值
strcat(p1,p2); // p1 + p2
strcpy(p1,p2);//p2拷贝给p1;
string s = "123";
const char *p = s.c_str();
3、 string作为顺序容器的操作
//子字符串的操作:
s.substr(pos,n) ;//返回s中从pos开始的n个字符的子字符串
s.erase(pos,len);//删除从pos开始的len个字符,len不写的话删除pos 开始的所有字符
s.insert(pos,args);从pos位置插入args
s.assign(args);//将s中的字符替换为args中的字符
s.append(args);
s.replace(range,args);//删除range中的元素,替换为args中的元素
//args具体看primer P323
string的搜索操作:
s.find(args);
s.rfind(args);
s.find_first_of(args);
s.find_last_of(args);
s.find_first_not_of(args);
s.find_last_not_of(args);
每个操作接收一个可选的第二参数,可以用来指定从什么位置开始搜索。例如args = c,pos,代表从pos位置开始搜索c,其中pos参数是可以省略的。
如果搜索失败,则返回一个string::npos的static的成员。
s.find_first_of(args);在s中查找args中任何一个字符第一次出现的位置。
#include<iostream>
#include<string>
#include<vector>
using namespace std;
int main() {
string target("ad2c3d7r4e6");
string numbers("");
string num, alpha;
unsigned int pos = ;
while ( (pos = target.find_first_of(numbers,pos)) != string::npos) {
num.push_back(target[pos]);
++pos;
}
pos = ;
while ( (pos = target.find_first_not_of(numbers, pos)) != string::npos) {
alpha.push_back(target[pos]);
++pos;
}
cout << "numbers is :\n " << num << endl;
cout << "alpha is :\n " << alpha << endl;
system("pause");
return ; }
void findLongestWord() {
ifstream in("input.txt");
string res,tmp,source;
string target("bdfghjklqpy");
unsigned int pos = ;
int maxLen = ;
int resPos = ;
while (getline(in, tmp)) {
istringstream ss(tmp);
while (ss >> source) {
if (pos = source.find_first_of(target, pos) != string::npos) {
continue;
}
if (source.size() > maxLen) {
maxLen = source.size();
res = source;
}
}
}
cout << res << endl; }
compare函数:
根据s是等于、大于、小于参数指定的字符串,s.compare返回0,整数或负数。
数值转换:
int i = 42;
string s = to_string(i);
int i = stoi(s);//string转换为int值。
C++中数字与字符串之间的转换 scanf string总结(复习必读)的更多相关文章
- C++中数字与字符串之间的转换,别人的,
C++中数字与字符串之间的转换 1.字符串数字之间的转换 (1)string --> char * string str("OK"); char * p = st ...
- C++中数字与字符串之间的转换(转)
http://www.cnblogs.com/luxiaoxun/archive/2012/08/03/2621803.html 1.字符串数字之间的转换 (1)string --> char ...
- C++中数字与字符串之间的转换
原文地址:http://www.cnblogs.com/luxiaoxun/archive/2012/08/03/2621803.html 1.字符串数字之间的转换 (1)string --> ...
- C++中数字与字符串之间的转换(使用CString.Format或者sprintf)
1.字符串数字之间的转换 (1)string --> char * string str("OK"); char * p = str.c_str(); (2)char ...
- [C/C++] C/C++中数字与字符串之间的转换
在C中: 方法: 1.C标准库中的sprintf, sscanf 2.C标准库还提供了 atoi, atof, atol, atoll(C++11标准) 函数将字符串转换成int,double, lo ...
- js 中数字与字符串之间的转换
数字转换为字符串 var num = 123: 1.num.toString 2."" + num 3.String(num) 将数字转化为格式化后的字符串 num.toFixe ...
- Java 中基本类型和字符串之间的转换
Java 中基本类型和字符串之间的转换 在程序开发中,我们经常需要在基本数据类型和字符串之间进行转换. 其中,基本类型转换为字符串有三种方法: 1. 使用包装类的 toString() 方法 2. 使 ...
- Java学习--Java 中基本类型和字符串之间的转换
Java 中基本类型和字符串之间的转换 在程序开发中,我们经常需要在基本数据类型和字符串之间进行转换. 其中,基本类型转换为字符串有三种方法: 1. 使用包装类的 toString() 方法 2. 使 ...
- 【Go】IP地址转换:数字与字符串之间高效转换
转载:https://blog.thinkeridea.com/201903/go/ip2long.html IP 地址库中 IP 地址的保存格式一般有两种,一种是点分十进制形式(192.168.1. ...
随机推荐
- kafka2x-Elasticsearch 数据同步工具demo
Bboss is a good elasticsearch Java rest client. It operates and accesses elasticsearch in a way simi ...
- 小程序使用scroll-view横向滑动时,flex布局失效问题
最近在完善以前项目,类目增多,需要进行横向滑动 实现方法1 可以在外盒子scroll-view使用white-space: nowrap来禁止子盒子换行,子盒子使用display: inline-bl ...
- PAT T1005 Programming Pattern
建立后缀数组,遍历height数组找到连续大于len的最长子序列~ #include<bits/stdc++.h> using namespace std; ; char s[maxn]; ...
- FineReport帆软报表需求:根据url传递过来的参数值决定显示隐藏列
需求:角色id传递到报表页面中,然后根据角色id,决定隐藏第1列,显示第2-4列,还是隐藏第2-4列,显示第1列. 解决方法:
- 使用 CocoaPods 遇到的问题记录
1. 在 Terminal 输入 Cocoapods 命令时,有时会一直等待,出现“Performing a deep fetch of the `master` specs repo to impr ...
- web组件化开发第一天
技术选型 html5 css3 jq 应用的插件 FullPage.js 一.建一个测试页面,测试静态的功能 <!DOCTYPE html> <html> <head&g ...
- Periodic-table
1. Periodic table 1.1 元素的排列 1.2 表中的行与列 1.3 元素区块 1.4 周期表中的一些趋势 1.5 元素周期律的本质 1.6 电子排布 2. 更多相关链接 2.1 维基 ...
- KVM虚拟化与容器的区别理解
1.KVM虚拟化是linux内核的虚拟化,提供了内核级别的虚拟进程管理,客户空间的程序QEMU-KVM可以提供资源清单和模拟设备,与KVM交互 QEMU-KVM--可以在宿主机器,建立网络(网桥交换机 ...
- Java 代码空间复杂度查看工具
SourceMonitor 下载地址:http://www.campwoodsw.com/sourcemonitor.html
- 学习打卡8:循环语句for、while
流程图: /*循环结构的基本组成部分,一般可以分成四部分:1.初始化语句:在循环开始最初执行,而且只做唯一一次.2.条件判断:如果成立,则循环继续:如果不成立,则循环退出.3.循环体:重复要做的内容, ...