stringstring ss;
int num;
string s = "123";
ss << s ;
ss >> num; // 此时就成功的完成了转换
连续使用时需要注意清空缓冲区
注意重复使用同一个stringstream对象时要 先继续清空,而清空很容易想到是clear方法,而在stringstream中这个方法实际上是清空stringstream的状态(比如出错等),真正清空内容需要使用.str(“”)方法。
举个例子
口算练习题
题目描述
王老师正在教简单算术运算。细心的王老师收集了i道学生经常做错的口算题,并且想整理编写成一份练习。 编排这些题目是一件繁琐的事情,为此他想用计算机程序来提高工作效率。王老师希望尽量减少输入的工作量,比如 5+8 \texttt{5+8} 5+8 的算式最好只要输入 5 \texttt 5 5 和 8 \texttt 8 8,输出的结果要尽量详细以方便后期排版的使用,比如对于上述输入进行处理后输出 5+8=13 \texttt{5+8=13} 5+8=13 以及该算式的总长度 6 6 6。王老师把这个光荣的任务交给你,请你帮他编程实现以上功能。
输入格式
第一行为数值 i i i
接着的 i i i 行为需要输入的算式,每行可能有三个数据或两个数据。
若该行为三个数据则第一个数据表示运算类型, a \texttt a a 表示加法运算, b \texttt b b 表示减法运算, c \texttt c c 表示乘法运算,接着的两个数据表示参加运算的运算数。
若该行为两个数据,则表示本题的运算类型与上一题的运算类型相同,而这两个数据为运算数。
输出格式
输出 2 × i 2\times i 2×i 行。对于每个输入的算式,输出完整的运算式及结果,第二行输出该运算式的总长度
样例 #1
样例输入 #1
4
a 64 46
275 125
c 11 99
b 46 64
样例输出 #1
64+46=110
9
275+125=400
11
11*99=1089
10
46-64=-18
9
提示
数据规模与约定
对于 50 % 50\% 50% 的数据,输入的算式都有三个数据,第一个算式一定有三个数据。
对于所有数据, 0 < i ≤ 50 0<i\leq 50 0<i≤50,运算数为非负整数且小于 10000 10000 10000。
这道题的关键处理思路是 ,全部用字符串读入, 之后将操作数强制转换为int(这里就用到了我们讲的内容)
#include<bits/stdc++.h>
#include <iostream>
#include <sstream>
using namespace std;
// 积累 s.append() 在 s后面加后缀。
// 使用stringstream 将字符串转换为数字, 连续使用时 要加上ss.clear() 和 ss.str() 去清空字符流
int count(int n){
if(n ==0 ) return 1; //判断整数位数的时候要注意的细节
int cnt = 0;
while(n!=0){
n/=10;
cnt++;
}
return cnt;
}
int main()
{
int n,a,b,cnt = 0;
cin >> n;
string s;
char option , lastoption;
while(n--){
cin >> s;
if(s[0] == 'a' || s[0] == 'b' || s[0] == 'c'){
option =s[0];
cin >> a >> b;
}else{ //这里就是例子
option = lastoption;
stringstream ss;
ss << s ;
ss >> a;
ss.clear(); //清空出错的状态
ss.str(); //清空内容
cin >> b;
}
if(cnt == 0 ) {
lastoption = s[0];
}
if(option == 'a') {
cout <<a<< '+'<<b << '=' << a+b << "\n";
cout << count(a) + count(b) + count(a+b) + 2 << "\n";
}
else if(option == 'b'){
cout<<a << '-'<<b << '=' << a-b << "\n";
if(a-b>=0)
cout << count(a) + count(b) + count(a-b) +2 << "\n";
//小于0多了一个负号所以加三
else cout << count(a) + count(b) + count(a-b) +3 << "\n";
}
else if(option == 'c'){
cout<<a << '*'<<b << '=' << a*b<<"\n";
cout << count(a) +count(b) +count(a*b) +2 << "\n";
}
lastoption = option;
}
return 0;
}
题目链接:大家可以去练练手