洛谷P1957口算练习题题解
前言:
题目传送门:https://www.luogu.com.cn/problem/P1957
其实这很简单
纯模拟撒~~~~
正文开始:
_话说 ,就当本蒟蒻正高高兴兴的刷水题时,居然
碰到了这个laji题_
于是就开始了一顿乱写:
思路部分:
这道题很大的一个痛点就在于输入
4
a 64 46
275 125 //这里咋就没有字母了呢????
c 11 99
b 46 64
看来,三个cin不行
于是,经过几分钟的思考,
我大致确定了两种方案:
1.直接getline一行:
可是.....这个如何转换为数字的问题吗,还是去问前排一波的Ak大佬吧(逃)
2.其他办法:
先cin一个char类型的呗,至于那种毒瘤情况待会再解决
于是代码:
cin>>y;
if(y>='a'&&y<='c'){
w=y;
cin>>s1;
}
cin>>s2;
补充小知识:char可是只会读入一个的oh
于是当275 125 这种数据出现的时候,y,s1,s2会变成这样:
y=‘2’;
s2=75;
s3=125;
好了,于是一种想法就理所应当的产生了:吧y变为数字,再与s2拼起来不就得了?
于是:
char y;long long s1,s2;
cin>>y>>s1>>s2;
s1=(y-'0')*pow(10,line(s1))+s1;
cout<<s1;
return 0;
其中有一句line(s1)是读取s1有几位的函数(当然要自己写啦)
long long line(long long i){
long long j=0,k=i;
if(i<=0){
k=-k;
j++;
}
while(k>0){
k=k/10;
j++;
}
return j;
}
很简单,一个模板而已;
可是,你难道没发现什么bug:当如测试点2的5002时会:变为52!!!!!!!
哪儿有问题呢?
原来,当程序读入5002时灰度为‘5’;002->2!!
所以,另辟新路吧!
仔细想想,原来可以这样!!
可把后面的s1用字符串读入
然后与y一拼,一起化为数字:
cin>>e;
e=y+e;
int le=e.size();int kw=1;int ss=0;
for(int i=le-1;i>=0;i--){
ss+=(kw*(e[i]-'0'));
kw=kw*10;
}
s1=ss;
于是,只需要再注意一些细节问题便好:
int main(){
long long n; cin>>n;
for(long long i=1;i<=n;++i){
getzf();
//cout<<"s1:"<<s1<<" "<<s2<<endl;
if(w=='a'){
cout<<s1<<"+"<<s2<<"="<<s1+s2<<endl;
cout<<line(s1)+2+line(s2)+line(s1+s2)<<endl;
}
else if(w=='b'){
cout<<s1<<"-"<<s2<<"="<<s1-s2<<endl;
cout<<line(s1)+2+line(s2)+line(s1-s2)<<endl;
//cout<<"line:"<<line(s1)<<" "<<line(s2)<<" "<<line(s1-s2)<<endl;
}
else if(w=='c'){
cout<<s1<<"*"<<s2<<"="<<s1*s2<<endl;
cout<<line(s1)+2+line(s2)+line(s1*s2)<<endl;
}
}
return 0;
}
注意不要多输出换行oh!!!!!
那会爆零的!!!
code,完整代码:
#include<bits/stdc++.h>
using namespace std;
string a,e; long long s1,s2;char w,y;//////////////////////iephyhoyhjyeohyohytuohyoihj/////iihjn
long long line(long long i){
long long j=0,k=i;
if(i<=0){
k=-k;
j++;
}
while(k>0){
k=k/10;
j++;
}
return j;
}
void getzf(){
cin>>y;
//cout<<"y:"<<y<<endl;
if(y>='a'&&y<='c'){
w=y;
cin>>s1;
}
else{
cin>>e;
e=y+e;
int le=e.size();int kw=1;int ss=0;
for(int i=le-1;i>=0;i--){
ss+=(kw*(e[i]-'0'));
kw=kw*10;
}
s1=ss;
}
cin>>s2;
//cout<<"s1:"<<s1<<"s2:"<<s2<<endl;
}
int main(){
long long n; cin>>n;
for(long long i=1;i<=n;++i){
getzf();
//cout<<"s1:"<<s1<<" "<<s2<<endl;
if(w=='a'){
cout<<s1<<"+"<<s2<<"="<<s1+s2<<endl;
cout<<line(s1)+2+line(s2)+line(s1+s2)<<endl;
}
else if(w=='b'){
cout<<s1<<"-"<<s2<<"="<<s1-s2<<endl;
cout<<line(s1)+2+line(s2)+line(s1-s2)<<endl;
//cout<<"line:"<<line(s1)<<" "<<line(s2)<<" "<<line(s1-s2)<<endl;
}
else if(w=='c'){
cout<<s1<<"*"<<s2<<"="<<s1*s2<<endl;
cout<<line(s1)+2+line(s2)+line(s1*s2)<<endl;
}
}
return 0;
}
了结!!
总结一下,下次做模拟题需注意:
1.函数化编程!!!!方便调试,方便理解
这才是做较难模拟题的王道!!!!
2.注意细节,避免爆零!!!
极简:将复杂的东西分为小块,像搭积木一样解决各类难题,这也是每个学科创造的大致路径
删繁就简三秋树,标新立异二月花
byebye~~~~!
洛谷P1957口算练习题题解的更多相关文章
- 洛谷 P1957 口算练习题 题解
题目传送门 这道题是考字符串处理,另外输入要使用c++的cin的神奇功能. #include<bits/stdc++.h> using namespace std; int n;char ...
- 洛谷 P1957 口算练习题
洛谷 P1957 口算练习题 题目描述 王老师正在教简单算术运算.细心的王老师收集了i道学生经常做错的口算题,并且想整理编写成一份练习. 编排这些题目是一件繁琐的事情,为此他想用计算机程序来提高工作效 ...
- 洛谷P1720 月落乌啼算钱 题解
题目传送门 初看题目,好难.再看一次,探索规律,发现这就是有名的斐波那契数列. F[i]=f[i-1]+f[i-2] SO 代码很简单,貌似要开long long,又貌似不用开. #include&l ...
- 洛谷P1720 月落乌啼算钱 题解 斐波那契数列/特征方程求解
题目链接:https://www.luogu.com.cn/problem/P1720 题目描述: 给你一个公式 ,求对应的 \(F_n\) . 解题思路: 首先不难想象这是一个斐波那契数列,我们可以 ...
- 洛谷P1783 海滩防御 分析+题解代码
洛谷P1783 海滩防御 分析+题解代码 题目描述: WLP同学最近迷上了一款网络联机对战游戏(终于知道为毛JOHNKRAM每天刷洛谷效率那么低了),但是他却为了这个游戏很苦恼,因为他在海边的造船厂和 ...
- 洛谷P4047 [JSOI2010]部落划分题解
洛谷P4047 [JSOI2010]部落划分题解 题目描述 聪聪研究发现,荒岛野人总是过着群居的生活,但是,并不是整个荒岛上的所有野人都属于同一个部落,野人们总是拉帮结派形成属于自己的部落,不同的部落 ...
- 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)
洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ...
- 2019.06.17课件:[洛谷P1310]表达式的值 题解
P1310 表达式的值 题目描述 给你一个带括号的布尔表达式,其中+表示或操作|,*表示与操作&,先算*再算+.但是待操作的数字(布尔值)不输入. 求能使最终整个式子的值为0的方案数. 题外话 ...
- 洛谷10月月赛II题解
[咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...
随机推荐
- LoraLU
一.定义动画过程中形成的状态用transform transform 分为2D 和 3D,主要包含以下几种变换:旋转rotate.扭曲skew.缩放scale和移动 translate以及矩阵变形ma ...
- RocketMQ 单机版安装并测试
一.安装maven 1.下载maven,http://maven.apache.org/download.cgi,并解压: -bin.tar.gz 2.修改系统环境变量,并验证: vim /etc/p ...
- AndroidManifest.xml文件详解
本文为安全专家李洋的最新一篇专栏文章<AndroidManifest.xml文件详解>.AndroidManifest.xml是一个跟安全相关的配置文件,该配置文件是Android安全保障 ...
- Oracle中的列转行实现字段拼接用例
文章目录 Oracle中的列转行实现字段拼接 场景 在SQL使用过程中经常有这种需求:将某列字段拼接成in('XX','XX','XX','XX','XX','XX' ...)做为查询条件. 实现 s ...
- Quartz Tutorial 11 - Miscellaneous Features of Quartz
文章目录 Plug-Ins Quartz提供了一个接口(org.quartz.spi.SchedulerPlugin) 用于插入附加的功能. 与Quartz一同发布的,提供了各种实用功能的插件可以在o ...
- P1102 A-B 数对
P1102题库链接:https://www.luogu.org/problem/P1102 难度:普及- 算法标签:模拟,数论,排序,HASH,概率论,二分查找 1.朴素 O(n^2) 得分76 将输 ...
- swoole(2)swoole进程结构
一:进程基本概念 系统中正在运行的一个程序,程序一旦运行就是进程 一个进程可以拥有多个线程 核心内容分为两部分:内存(进程创建时从系统分配的,它所创建的变量都会存储在这一块内存中).上下文环境 二:s ...
- 06.深入浅出 Spring Boot - 数据访问之Druid
代码下载:https://github.com/Jackson0714/study-spring-boot.git 一.Druid是什么? 1.Druid是数据库连接池,功能.性能.扩展性方面都算不错 ...
- file_put_contents生成ansi文件
$line_body = array('张三','李四','王五'); $line_body = array_map(function ($element){return iconv('UTF-8', ...
- 解决oninput事件在中文输入法下会取得拼音的值的问题
在做搜索等功能时,很多时候我们需要实时获取用户输入的值,而常常会得到类似 w'm 这样的拼音.为了解决这个问题,我在网上搜索了下相关问题,发现了两个陌生的事件:compositionstart 和 c ...