【C++】P1957 口算练习题

news2025/2/5 16:52:49

在这里插入图片描述

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳]
本文专栏: C++

文章目录

  • 💯前言
  • 💯题目描述
    • 输入格式:
    • 输出格式:
  • 💯我的做法
    • 代码实现:
  • 💯老师的做法
    • 代码实现:
  • 💯对比分析
  • 💯拓展与优化
  • 💯总结
    • 一开始的错误做法


在这里插入图片描述


💯前言

  • 在编程学习过程中,C++ 语言为我们提供了强大的控制能力和灵活的操作方式。在本次学习中,我们面对的是一个简单的算术口算题目的处理任务。任务要求通过程序自动处理多个口算算式,输出完整的算式、其计算结果,并计算算式的总长度。这个问题看似简单,但可以通过多种方式解决,过程中涉及到字符串拼接、运算符判断和数据存储等基础编程技术。
    在本次讨论中,我们将深入分析两种不同的解决方法:我提出的做法与老师的做法。我们将详细对比这两种方法的思路、代码实现,并进行优化和拓展,以便对 C++ 编程的理解更为深刻。
    C++ 参考手册
    在这里插入图片描述

💯题目描述

P1957 口算练习题
在这里插入图片描述

题目要求我们处理一组口算题目,每道题目可能包括加法、减法或乘法操作。每道题的输入由两个或三个数据组成,若有三个数据,第一个表示运算符(a 表示加法,b 表示减法,c 表示乘法),接下来的两个数据为参与运算的数值;若只有两个数据,则表示继承上一道题的运算符。

我们需要输出每道题的完整算式,并且输出算式的总长度。以下是题目的完整描述:

输入格式:

4
a 64 46
275 125
c 11 99
b 46 64

输出格式:

64+46=110
9
275+125=400
11
11*99=1089
10
46-64=-18
9

💯我的做法

我的实现方法着眼于输入的处理与字符串的拼接,基本流程如下:

  1. 输入读取:首先读取题目数量 i,然后循环处理每一道算式。每道算式可以是完整的带有运算符的输入,也可以是继承上题的运算符。
  2. 算式计算:对于每道算式,根据运算符 a, b, 或 c 来决定进行加法、减法或乘法操作。
  3. 字符串拼接:利用字符串的拼接(+=)来构造完整的算式表达式,并计算结果。
  4. 输出:输出每道算式及其结果,最后输出算式的总长度。

代码实现:

#include <iostream>
#include <string>
using namespace std;

int main()
{
	int  i;
	cin >> i;
	int a, b;
	string temp, ysf;
	while(i--)
	{
		string s;
		cin >> temp;
		if(temp == "a" || temp == "b" || temp == "c")
		{
			cin >> a >> b;
			if(temp == "a")
			{
				s += to_string(a);
				s += '+';
				s += to_string(b);
				s += '=';
				s += to_string(a + b);
			}
			else if(temp == "b")
			{
				s += to_string(a);
				s += '-';
				s += to_string(b);
				s += '=';
				s += to_string(a - b);
			}
			else if(temp == "c")
			{
				s += to_string(a);
				s += '*';
				s += to_string(b);
				s += '=';
				s += to_string(a * b);
			}
			ysf = temp;
		}
		else
		{
			a = stoi(temp);
			cin >> b;
			if(ysf == "a")
			{
				s += to_string(a);
				s += '+';
				s += to_string(b);
				s += '=';
				s += to_string(a + b);
			}
			else if(ysf == "b")
			{
				s += to_string(a);
				s += '-';
				s += to_string(b);
				s += '=';
				s += to_string(a - b);
			}
			else
			{
				s += to_string(a);
				s += '*';
				s += to_string(b);
				s += '=';
				s += to_string(a * b);
			}
		}
		
		cout << s << endl;
		cout << s.size() << endl;
	}
	
	return 0;
}

💯老师的做法

老师的做法与我的实现思路相似,但有一些不同之处。老师的代码在结构上稍显复杂,特别是在输入和字符串拼接部分的处理上,且做了更多的优化来处理继承运算符的情况。

代码实现:

int main()
{
    int n = 0;
    cin >> n;
    string op;
    string num1;
    string num2;
    string last;
    int ret = 0;

    while (n--)
    {
        string ans;
        cin >> op;

        if (op == "a" || op == "b" || op == "c")
        {
            cin >> num1 >> num2;
            int n1 = stoi(num1);
            int n2 = stoi(num2);
            ans += num1;

            if (op == "a")
            {
                ret = n1 + n2;
                ans += "+";
            }
            else if (op == "b")
            {
                ret = n1 - n2;
                ans += "-";
            }
            else
            {
                ret = n1 * n2;
                ans += "*";
            }
            last = op;
        }
        else
        {
            num1 = op;
            cin >> num2;
            int n1 = stoi(num1);
            int n2 = stoi(num2);
            ans += num1;

            if (last == "a")
            {
                ret = n1 + n2;
                ans += "+";
            }
            else if (last == "b")
            {
                ret = n1 - n2;
                ans += "-";
            }
            else
            {
                ret = n1 * n2;
                ans += "*";
            }
        }
        ans += (num2 + "=" + to_string(ret));
        cout << ans << endl;
        cout << ans.size() << endl;
    }
    return 0;
}

💯对比分析

  1. 结构差异

    • 我的做法中,我们根据输入的运算符判断是否更新运算符,并且用 last_op 来记住上一题的运算符,保证后续算式的正确计算。
    • 老师的做法稍微复杂一些,采用了更显式的变量存储(如 last 变量)。另外,老师在每次处理完一个算式后,拼接完成的字符串才会输出。
  2. 字符串拼接

    • 我的做法通过直接将 +-* 等运算符拼接进 ans 字符串。
    • 老师的做法在拼接过程中,将运算符的插入和结果的转换更加细化,也做了更精确的类型转换处理(使用 stoi 将字符串转换为整数)。
  3. 处理继承运算符

    • 我的做法是依赖 last_op 来判断是否使用上一题的运算符。
    • 老师的做法在这一点上比较细致,利用了 last 变量来确保后续运算使用的是正确的运算符。

💯拓展与优化

  1. 代码优化

    • 对于运算符和结果拼接部分,使用了 += 拼接字符串,但如果问题较为复杂或涉及到更多操作,可能会导致拼接效率不高。可以考虑使用 ostringstream 来拼接字符串,这样可以提高性能。
  2. 用户输入优化

    • 可以增加输入校验,避免用户输入错误的数据类型(如非数字输入等)。
  3. 更广泛的应用

    • 这类算术问题不仅限于加法、减法和乘法。如果要处理更多运算符(如除法、取余等),可以通过扩展运算符判断来完成。
  4. 函数化

    • 该问题的不同部分(如运算符判断、算式拼接、输出结果等)可以通过函数化进行封装,提高代码的模块化和复用性。

💯总结

本次学习和讨论了如何用 C++ 语言处理简单的口算算式,通过两种不同的实现方法(我的做法与老师的做法),我们掌握了如何判断运算符、处理继承运算符的情况,并输出结果与算式的总长度。通过对比分析,我们看到了两种做法的异同与各自的优缺点。

在优化方面,我们提出了改进的思路,如何提高代码性能、增强可扩展性,以及如何处理更多复杂的运算符类型。总体来说,这道题目的解决方案为我们提供了一个很好的编程练习机会,帮助我们更好地理解字符串操作、控制流程和输入输出的细节。

一开始的错误做法

#include <iostream>
#include <string>
using namespace std;

int main()
{
	int i = 0;
	cin >> i;
	int opera = 0;
	string s;
	while(i--)
	{
		int index = 0, a = 0, b = 0;
		while(cin >> s)
		{
			index++;
			if(index == 1)
			{
				if(s[i] == 'a')
					opera = 1;
				else if(s[i] == 'b')
					opera = 2;
				else if(s[i] == 'c')
					opera = 3;
				else
					a = stoi(string(1, s[i]));  // 将字符 s[i] 转换为字符串后再使用 stoi
			}
			
			if(index == 2 && a != 0)
				b = stoi(string(1, s[i]));
			else if(index == 2 && a == 0)
				a = stoi(string(1, s[i]));
			
			if(index == 3)
				b = stoi(string(1, s[i])); 

		}
		if(opera == 1)
			cout << a << "+" << b << "=" << (a + b) << endl;
		else if(opera == 2)
			cout << a << "-" << b << "=" << (a - b) << endl;
		else
			cout << a << "*" << b << "=" << (a * b) << endl;
	}
	
	return 0;
}

还有,要注意变量的作用域


在这里插入图片描述


在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

学习C++的建议

C++ 是一门强大且广泛应用的编程语言,无论是系统开发、游戏开发还是高性能计算,它都有不可替代的地位。然而,学习C++的道路可能是陡峭的,为了帮助你更高效地掌握这门语言,我总结了一些学习建议和经验。


1. 理解C++的基础
学习重点:

  1. 掌握基本语法
    • 学会声明变量、条件语句、循环、函数等核心语法。
    • 掌握数组、指针、引用等基础知识。
  2. 熟悉标准输入输出
    • 掌握 cincout 的用法。
    • 理解格式化输出,例如 std::setwstd::fixed
  3. 记住编译器的角色
    • 理解源代码如何通过编译器转换为可执行程序,选择一款好的IDE(如Visual Studio、Clion、VSCode)。

建议:用大量小程序练习这些基础语法,比如写一个计算器、模拟猜数字游戏等。


2. 深入学习C++的特性
学习重点:

  1. 面向对象编程(OOP)
    • 理解类和对象,熟悉如何定义类、成员变量和成员函数。
    • 掌握封装、继承、多态三大核心特性。
  2. 内存管理
    • 理解指针的用法,掌握动态内存分配(newdelete)。
    • 学习如何避免内存泄漏,熟悉智能指针(如std::unique_ptrstd::shared_ptr)。
  3. 标准模板库(STL)
    • 熟悉常用的容器(如vectormapset)和算法(如sortfind)。
    • 掌握迭代器的用法。
  4. 异常处理
    • 学习使用try-catch块处理异常。
    • 理解异常的用途以及如何设计健壮的代码。

建议:尝试开发一个小型项目,比如一个学生管理系统,综合应用类、STL、指针和动态内存分配。


3. 掌握进阶内容
学习重点:

  1. 模板
    • 理解函数模板和类模板,掌握泛型编程思想。
    • 学习模板特化和模板元编程的基本概念。
  2. 多线程与并发
    • 学习 C++11 提供的多线程支持(如std::thread)。
    • 熟悉互斥锁(std::mutex)和条件变量(std::condition_variable)。
  3. C++与C的兼容性
    • 学习如何在C++中使用C语言代码,理解C和C++的区别。
    • 掌握C风格字符串(char[])和C++字符串(std::string)的转换。

建议:在这一阶段,可以挑战更复杂的项目,比如开发一个小型的HTTP服务器,学习网络编程并结合多线程。


4. 学习资源与实践方法
学习资源:

  1. 书籍
    • 《C++ Primer》:非常适合初学者的经典书籍。
    • 《Effective C++》:进阶学习C++最佳实践的指南。
    • 《The C++ Programming Language》:Bjarne Stroustrup(C++之父)的权威著作。
  2. 在线课程
    • Coursera 上的 C++ 编程课程。
    • YouTube 上免费的 C++ 系列教程。
  3. 社区与文档
    • 参与C++相关的论坛(如CSDN、Stack Overflow)。
    • 阅读官方文档(https://en.cppreference.com)。

实践方法:

  1. 多写代码,多调试
    • 每学一个概念后,写至少两个示例代码并进行调试。
  2. 做小项目
    • 从简单的控制台程序开始,比如文件读写、计算器、小游戏等。
    • 慢慢过渡到图形界面或网络程序开发。
  3. 阅读他人代码
    • 阅读开源项目的代码,理解优秀代码的设计思路。
  4. 参加编程比赛
    • 比如 LeetCode 或 Codeforces,可以帮助你提升算法能力和C++的熟练度。

5. 保持耐心与兴趣
学习C++可能会面临以下困难:

  1. 复杂的语法:如模板、智能指针、多线程等。
  2. 调试困难:指针错误、内存泄漏、未定义行为可能让人头疼。

如何应对:

  • 将大问题拆解成小问题,逐步解决。
  • 不断重复基础知识,以加深理解。
  • 保持兴趣,尝试一些有趣的项目,比如写一个游戏、制作一个简单的图形程序。

小结
学习C++需要一个循序渐进的过程,从基础语法到面向对象编程,再到进阶的模板和并发编程,每一步都需要耐心和实践。通过充分利用学习资源、进行大量编码练习,以及挑战实际项目,你一定可以成为C++的高手。记住,学习的核心在于理解,而非死记硬背。

祝你学有所成,享受C++编程的乐趣!


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2293397.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Workbench 中的热源仿真

探索使用自定义工具对移动热源进行建模及其在不同行业中的应用。 了解热源动力学 对移动热源进行建模为各种工业过程和应用提供了有价值的见解。激光加热和材料加工使用许多激光束来加热、焊接或切割材料。尽管在某些情况下&#xff0c;热源 &#xff08;q&#xff09; 不是通…

CCF-GESP 等级考试 2023年12月认证C++八级真题解析

2023年12月真题 一、单选题&#xff08;每题2分&#xff0c;共30分&#xff09; 正确答案&#xff1a;C 考察知识点&#xff1a;数学问题 解析&#xff1a;本题可抽象为分类计数问题&#xff0c;应使用加法原理&#xff0c;而不是乘法原理。答案为 ACB 的方案数 2 加上 ADB 的…

vscode搭建git

vscode搭建git 一、安装git二、vscode上搭建git(1) 先创建本地仓库再上传到远程仓库&#xff0c;远程仓库名是根据本地仓库名一致(2) 先创建远程仓库&#xff0c;再将本地仓库上传到指定远程仓库 一、安装git 网络教程很多&#xff0c;在此就不赘述了 参考&#xff1a;git安装…

解决Mac安装软件的“已损坏,无法打开。 您应该将它移到废纸篓”问题

mac安装软件时&#xff0c;如果出现这个问题&#xff0c;其实很简单 首先打开终端&#xff0c;输入下面的命令 sudo xattr -r -d com.apple.quarantine 输入完成后&#xff0c;先不要回车&#xff0c;点击访达--应用程序--找到你无法打开的app图标&#xff0c;拖到终端窗口中…

ChatGPT-4o和ChatGPT-4o mini的差异点

在人工智能领域&#xff0c;OpenAI再次引领创新潮流&#xff0c;近日正式发布了其最新模型——ChatGPT-4o及其经济实惠的小型版本ChatGPT-4o Mini。这两款模型虽同属于ChatGPT系列&#xff0c;但在性能、应用场景及成本上展现出显著的差异。本文将通过图文并茂的方式&#xff0…

读书笔记--分布式架构的异步化和缓存技术原理及应用场景

本篇是在上一篇的基础上&#xff0c;主要对分布式应用架构下的异步化机制和缓存技术进行学习&#xff0c;主要记录和思考如下&#xff0c;供大家学习参考。大家知道原来传统的单一WAR应用中&#xff0c;由于所有数据都在同一个数据库中&#xff0c;因此事务问题一般借助数据库事…

BUU10 [极客大挑战 2019]LoveSQL1

万能用户名&#xff08;密码随便&#xff09; 登录进去以后发现是这个东西&#xff0c;然而并没有什么卵用 然后就开始爆破数据库名字--表名--列名 注意&#xff1a;这道题需要将所有的表名都爆出来&#xff0c;需要在payload里头写 group_concat()&#xff0c;否则页面只会显…

tomcat核心组件及原理概述

目录 1. tomcat概述 1.1 概念 1.2 官网地址 2. 基本使用 2.1下载 3. 整体架构 3.1 核心组件 3.2 从web.xml配置和模块对应角度 3.3 如何处理请求 4. 配置JVM参数 5. 附录 1. tomcat概述 1.1 概念 什么是tomcat Tomcat是一个开源、免费、轻量级的Web服务器。 Tomca…

冰蝎v4.0.5 来啦

webshell始终是渗透测试的热门&#xff0c;上次护网写冰蝎检测规则&#xff0c;加密流量&#xff0c;有点压力&#xff0c;今天终于有空来复现一下&#xff0c;我知道玩知乎的大佬很多&#xff0c;轻一点喷&#xff0c;学习新知识不丢人&#xff5e; ailx10 1949 次咨询 4.9 …

【C++】B2120 单词的长度

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目描述&#x1f4af;我的做法代码实现&#xff1a;思路解析&#xff1a; &#x1f4af;老师的第一种做法代码实现&#xff1a;思路解析&#xff1a; &#x1f4af;老师的…

使用线性回归模型逼近目标模型 | PyTorch 深度学习实战

前一篇文章&#xff0c;计算图 Compute Graph 和自动求导 Autograd | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 使用线性回归模型逼近目标模型 什么是回归什么是线性回归使用 PyTorch 实现线性回归模型代码执行结…

深入浅出:频谱掩码 Spectral Masking —— 噪音消除利器

在语音处理领域&#xff0c;噪声是一个常见的敌人。无论是语音通话、语音识别&#xff0c;还是语音合成&#xff0c;噪声都会大大降低语音的质量和可理解性。为了解决这个问题&#xff0c;Spectral Masking&#xff08;频谱掩码&#xff09; 模型应运而生。它通过从带噪信号的频…

C++ Primer 多维数组

欢迎阅读我的 【CPrimer】专栏 专栏简介&#xff1a;本专栏主要面向C初学者&#xff0c;解释C的一些基本概念和基础语言特性&#xff0c;涉及C标准库的用法&#xff0c;面向对象特性&#xff0c;泛型特性高级用法。通过使用标准库中定义的抽象设施&#xff0c;使你更加适应高级…

Mac M1 ComfyUI 中 AnyText插件安装问题汇总?

Q1&#xff1a;NameError: name ‘PreTrainedTokenizer’ is not defined ? 该项目最近更新日期为2024年12月&#xff0c;该时间段的transformers 版本由PyPI 上的 transformers 页面 可知为4.47.1. A1: transformers 版本不满足要求&#xff0c;必须降级transformors &#…

C++基础(2)

目录 1. 引用 1.1 引用的概念和定义 1.2 引用的特性 1.3 引用的使用 2. 常引用 3. 指针和引用的关系 4. 内联函数inline 5. nullptr 1. 引用 1.1 引用的概念和定义 引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0c;编译器不会为引用变量开…

electron typescript运行并设置eslint检测

目录 一、初始化package.json 二、安装依赖 三、项目结构 四、配置启动项 五、补充&#xff1a;ts转js别名问题 已整理好的开源代码&#xff1a;Type-Electron: 用typescript开发的electron项目脚手架&#xff0c;轻量级、支持一键配置网页转PC - Gitee.com 一、初始化pac…

modbus协议处理

//------------------------0x01-------------------------------- //MDA_usart_send: aa 55 01 00 06 00 02 00 05 //转modbusTCP——Master——send&#xff1a;地址00002&#xff0c;寄存器数量&#xff1a;00005 00 00 00 00 00 06 01 01 00 02 00 05 //ModbusTCP——Slave…

java-(Oracle)-Oracle,plsqldev,Sql语法,Oracle函数

卸载好注册表,然后安装11g 每次在执行orderby的时候相当于是做了全排序,思考全排序的效率 会比较耗费系统的资源,因此选择在业务不太繁忙的时候进行 --给表添加注释 comment on table emp is 雇员表 --给列添加注释; comment on column emp.empno is 雇员工号;select empno,en…

c++可变参数详解

目录 引言 库的基本功能 va_start 宏: va_arg 宏 va_end 宏 va_copy 宏 使用 处理可变参数代码 C11可变参数模板 基本概念 sizeof... 运算符 包扩展 引言 在C编程中&#xff0c;处理不确定数量的参数是一个常见的需求。为了支持这种需求&#xff0c;C标准库提供了 &…

linux 函数 sem_init () 信号量、sem_destroy()

&#xff08;1&#xff09; &#xff08;2&#xff09; 代码举例&#xff1a; #include <stdio.h> #include <stdlib.h> #include <pthread.h> #include <semaphore.h> #include <unistd.h>sem_t semaphore;void* thread_function(void* arg) …