前言:

题目传送门: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口算练习题题解的更多相关文章

  1. 洛谷 P1957 口算练习题 题解

    题目传送门 这道题是考字符串处理,另外输入要使用c++的cin的神奇功能. #include<bits/stdc++.h> using namespace std; int n;char ...

  2. 洛谷 P1957 口算练习题

    洛谷 P1957 口算练习题 题目描述 王老师正在教简单算术运算.细心的王老师收集了i道学生经常做错的口算题,并且想整理编写成一份练习. 编排这些题目是一件繁琐的事情,为此他想用计算机程序来提高工作效 ...

  3. 洛谷P1720 月落乌啼算钱 题解

    题目传送门 初看题目,好难.再看一次,探索规律,发现这就是有名的斐波那契数列. F[i]=f[i-1]+f[i-2] SO 代码很简单,貌似要开long long,又貌似不用开. #include&l ...

  4. 洛谷P1720 月落乌啼算钱 题解 斐波那契数列/特征方程求解

    题目链接:https://www.luogu.com.cn/problem/P1720 题目描述: 给你一个公式 ,求对应的 \(F_n\) . 解题思路: 首先不难想象这是一个斐波那契数列,我们可以 ...

  5. 洛谷P1783 海滩防御 分析+题解代码

    洛谷P1783 海滩防御 分析+题解代码 题目描述: WLP同学最近迷上了一款网络联机对战游戏(终于知道为毛JOHNKRAM每天刷洛谷效率那么低了),但是他却为了这个游戏很苦恼,因为他在海边的造船厂和 ...

  6. 洛谷P4047 [JSOI2010]部落划分题解

    洛谷P4047 [JSOI2010]部落划分题解 题目描述 聪聪研究发现,荒岛野人总是过着群居的生活,但是,并不是整个荒岛上的所有野人都属于同一个部落,野人们总是拉帮结派形成属于自己的部落,不同的部落 ...

  7. 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)

    洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ...

  8. 2019.06.17课件:[洛谷P1310]表达式的值 题解

    P1310 表达式的值 题目描述 给你一个带括号的布尔表达式,其中+表示或操作|,*表示与操作&,先算*再算+.但是待操作的数字(布尔值)不输入. 求能使最终整个式子的值为0的方案数. 题外话 ...

  9. 洛谷10月月赛II题解

    [咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...

随机推荐

  1. fabric 初步实践

    在集群部署时,我们经常用到堡垒机作为跳板,堡垒机和集群的其他的用户名.密码.端口号都是不同的,fabric如何进行配置不同的用户.端口号和密码. fabric作为一种强大的运维工具,可以让部署运维轻松 ...

  2. UEditor问题整理

    网上可以使用的富文本编辑器有很多,但是经过慎(sui)重(shou)思(yi)考(cha),选择了UEditor,毕竟是百度的东西,质量上应该经得起推敲,另外,使用别人的插件,总要去适应别人的编码习惯 ...

  3. 5G时代,什么将会消失?

    ​​5G时代说着说着就来了,当然,它不可能一撮而就,但正如4G.移动互联网和WIFI这些东西基本上是日益精进的水平,现如今饭馆的生意是否火爆,不仅仅在于其菜品和服务的质量,更在于他们有没有WIFI以及 ...

  4. Oracle的LOB(CLOB)大字段以及(SYS_LOB***$$)清理

    文章结构如下: 1.背景: 生产上查询那些大表然后进行清理,然而发现有SYS_LOB0000093441C00002$$这中表段占用30G(只保留一个月,如果保留更久会更大). 2.LOB介绍 Ora ...

  5. Go技术日报(2020-02-28)

    go 语言中文网(每日资讯)_2020-02-28 一.Go 语言中文网 Gopher 学习效率低怎么办?曹大谈工程师应该怎么学习 Go 的 http 包中默认路由匹配规则 [每日一库]Web 表单验 ...

  6. 使用Vagrant部署虚拟分布式开发和测试环境

    同步更新到笔者个人博客,可以访问我的博客查看原文:https://www.rockysky.tech 创建自动化配置开发环境 最近由于最近研究和学习的关系,需要经常配置和搭建多个虚拟机组成的分布式系统 ...

  7. CMSampleBufferRef解析

    CMTime:64位的value,32位的scale, media的时间格式 CMVideoFormatDesc:video的格式,包括宽高.颜色空间.编码格式.SPS.PPS CVPixelBuff ...

  8. ASP.NET CORE 启动过程及源码解读

    在这个特殊的春节,大家想必都在家出不了们,远看已经到了回城里上班的日子,但是因为一只蝙蝠的原因导致我们无法回到工作岗位,大家可能有的在家远程办公,有些在家躺着看书,有的是在家打游戏:在这个特殊无聊的日 ...

  9. Yuchuan_linux_C 编程之八 文件操作相关函数

    一.整体大纲 st_mode整体介绍: st_mode详细介绍: 二. Linux文件操作相关函数 1. stat 作用:获得文件信息,也可以获取文件大小. 头文件 #include <sys/ ...

  10. Yuchuan_Linux_C 编程之四动态库(共享库)制作

    一.整体大纲 二.共享库的制作 1. 命名规则: lib + 名字 + .so 2. 制作步骤: 1) 生成与位置无关的代码 (生成与位置无关的.o)    2) 将.o打包成共享库(动态库) 3. ...