题的目标很简单,就是求两个正整数A
和B
的和,其中A
和B
都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。
输入格式:
输入在一行给出A
和B
,其间以空格分开。问题是A
和B
不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。
注意:我们把输入中出现的第1个空格认为是A
和B
的分隔。题目保证至少存在一个空格,并且B
不是一个空字符串。
输出格式:
如果输入的确是两个正整数,则按格式A + B = 和
输出。如果某个输入不合要求,则在相应位置输出?
,显然此时和也是?
。
输入样例1:
123 456
输出样例1:
123 + 456 = 579
输入样例2:
22. 18
输出样例2:
? + 18 = ?
输入样例3:
-100 blabla bla...33
输出样例3:
? + ? = ?
我的做题思路:
本来想用cin>>a>>b,自动识别出空格,然后cin.fail()来判断,发现这样顶多判断个类型不一致,22.,1.2,这种小数都会自动整型,没?儿用。看了大佬代码,“逐帧”分析:
#include<bits/stdc++.h>
using namespace std;
int main() {
string a, b;//a,b belongs to [1,1000];
cin >> a;
getchar();//只有一个空格
getline(cin, b);//吸收前导空格
int A, B;
sscanf(a.c_str(), "%d", &A);//将字符串转变成整数型
sscanf(b.c_str(), "%d", &B);
int st1 = ((int)log10(A) + 1 == a.size() && A <= 1000);
//比较长度,
//判断原字符串是不是就是转化后的整数
int st2 = ((int)log10(B) + 1 == b.size() && B <= 1000);
printf("%s + %s = ", st1 ? a.c_str() : "?", st2 ? b.c_str() : "?");
//st1为真,输出a.c_str(),要是直接输出整型A,不符合%s
if (st1 && st2)
cout << A + B;
else
cout << "?";
}
1.
下面的实例演示了 sscanf() 函数的用法。
#include <stdio.h> #include <stdlib.h> #include <string.h> int main() { int day, year; char weekday[20], month[20], dtm[100]; strcpy( dtm, "Saturday March 25 1989" ); sscanf( dtm, "%s %s %d %d", weekday, month, &day, &year ); printf("%s %d, %d = %s\n", month, day, year, weekday ); return(0); }让我们编译并运行上面的程序,这将产生以下结果:
March 25, 1989 = Saturday
2.
函数c_str()就是将C++的string转化为C的字符串数组,c_str()生成一个const char *指针,指向字符串的首地址。
char *p=s[10];
string a=“welcome”;
strcpy(p,a.c_str());
cout<<p;
结果为"welcome".
3.
a?b:c是什么意思
这个是条件表达式,表示如果a为真,则表达式值为b,如果a为假,则表达式值为c
4.
(int)log10(A) + 1
判断整数位数!
大佬代码原地址:7-1 正整数A+B (15 分)_7-1 大数和-CSDN博客