题记(41)--简易计算器

目录

一、题目内容

二、输入描述

三、输出描述

四、输入输出示例

五、完整C语言代码


一、题目内容

读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值。

二、输入描述

  测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整数和运算符之间用一个空格分隔。没有非法表达式。当一行中只有0时输入结束,相应的结果不要输出。

三、输出描述

对每个测试用例输出1行,即该表达式的值,精确到小数点后2位。

四、输入输出示例

输入:

1 + 2
4 + 2 * 5 - 7 / 11
0

输出:

3.00
13.36

五、完整C语言代码

AC代码~#include<stdio.h>
#include<string.h>int IsDigit(char s) {if ('0' <= s && s <= '9')return 1;return 0;
}int Isch(char s) {if (s == '+' || s == '-' || s == '*' || s == '/')return 1;return 0;
}double cal(double a, double b, char tmp) {if (tmp == '+')return a + b;else if (tmp == '-')return a - b;else if (tmp == '*')return a * b;elsereturn a / b;
}int main() {double s1[100]; // 数字栈char s2[100];   // 符号栈int top1, top2; // 二者指针char s[200];while (gets(s)) {if (strcmp(s, "0") == 0)break;top1 = top2 = -1;int i = 0;while (s[i] != '\0') {if (IsDigit(s[i])) {int num = 0;while (IsDigit(s[i])) {num = num * 10 + (s[i] - '0');i++;}top1++;s1[top1] = num * 1.0;} else if (Isch(s[i])) {if (top2 != -1) { // 符号栈不空情况if (s[i] == '+' || s[i] == '-') {while (top2 != -1) {char stmp = s2[top2];top2--;double n1 = s1[top1];double n2 = s1[top1 - 1];top1 = top1 - 1;       // 本应减2,后面加1,所以减1double tmp = cal(n2, n1, stmp);s1[top1] = tmp;}} else {while ((s2[top2] == '*' || s2[top2] == '/') && top2 != -1) {char stmp = s2[top2];top2--;double n1 = s1[top1];double n2 = s1[top1 - 1];top1 = top1 - 1;       // 本应减2,后面加1,所以减1double tmp = cal(n2, n1, stmp);s1[top1] = tmp;}}}top2++;s2[top2] = s[i];i++;} elsei++;}while (top2 != -1) {    // 结束后运算栈内剩余char stmp = s2[top2];top2--;double n1 = s1[top1];double n2 = s1[top1 - 1];top1 = top1 - 1;       // 本应减2,后面加1,所以减1double tmp = cal(n2, n1, stmp);s1[top1] = tmp;}printf("%.2f\n", s1[0]);}return 0;
}

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

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

相关文章

信息学奥赛一本通1228:书架

1228&#xff1a;书架 时间限制: 1000 ms 内存限制: 65536 KB 提交数: 18190 通过数: 10557 【题目描述】 John最近买了一个书架用来存放奶牛养殖书籍&#xff0c;但书架很快被存满了&#xff0c;只剩最顶层有空余。 John共有N&#xfffd;头奶牛(1≤N≤20,0001≤…

NULL和nullptr到底是什么?它们的区别又是什么?

目录 1.前言 2.剖析NULL 3. 剖析nullptr 4.nullptr与NULL的区别 1.前言 为了保持良好的编程习惯&#xff0c;我们在声明某个变量时都应该给这个变量合适的初始值&#xff0c;不然容易出现不可预知的错误。对于指针来说更是如此&#xff0c;在c语言中我们就通常将暂时没有指向…

「数据结构」栈和队列

栈 栈的基本概念 定义 栈是只允许在一端进行插入或删除操作的线性表栈顶&#xff1a;线性表允许进行插入删除的那一端栈底&#xff1a;固定的&#xff0c;不允许进行插入和删除的另一端空栈&#xff1a;不含任何元素特点&#xff1a;后进先出&#xff08;LIFO&#xff09; 基…

求排列的逆序数

每日一道算法题之求排列的逆序数 一、题目描述二、思路三、C代码 一、题目描述 一个排列含有逆序的个数称为这个排列的逆序数。例如排列 263451 含有8个逆序(2,1),(6,3),(6,4),(6,5),(6,1),(3,1),(4,1),(5,1)&#xff0c;因此该排列的逆序数就是8。显然&#xff0c;由1,2,…,n …

【Spring MVC篇】返回响应

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【Spring MVC】 本专栏旨在分享学习Spring MVC的一点学习心得&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 一、返回静态页面…

(13)Hive调优——动态分区导致的小文件问题

前言 动态分区指的是&#xff1a;分区的字段值是基于查询结果自动推断出来的&#xff0c;核心语法就是insertselect。 具体内容指路文章&#xff1a; https://blog.csdn.net/SHWAITME/article/details/136111924?spm1001.2014.3001.5501文章浏览阅读483次&#xff0c;点赞15次…

回归预测模型:MATLAB神经网络回归模型

1.神经网络回归模型的基本原理 神经网络是一种由节点&#xff08;或称为“神经元”&#xff09;和边组成的网络结构&#xff0c;用于模拟人脑分析和处理信息的方式。在回归问题中&#xff0c;神经网络旨在预测一个连续值的输出&#xff0c;基于给定的一组输入特征。 一个基本…

假期作业 2月15日

字符串练习 1、选择题 1.1、有以下程序 int main() { char a[7]"a0\0a0\0";int i,j; isizeof(a); jstrlen(a); printf("%d %d\n",i,j); } //strlen求出字符串的长度&#xff0c;其实是字符串中字符的个数&#xff0c;不包括\0 程序运行后的输出…

如何买卖基金

一、从哪买卖&#xff1f; &#xff08;一&#xff09;购买渠道 有两种购买渠道&#xff1a;直销平台和代销平台。 1.直销平台 就是基金公司。 每个基金公司只能卖自家基金产品。比如招商基金只能卖招商基金管理的基金&#xff0c;而不能卖广发基金的产品。 如何去基金公司购…

2024年最新onlyfans虚拟信用卡订阅教程

一、Onlyfans是什么&#xff1f; OnlyFans是一个允许创作者分享自己的独家内容的平台&#xff0c;简称o站。这个平台允许创作者创建一个订阅服务&#xff0c;粉丝需要支付费用才能访问其独家内容。 本文将教你如何使用虚拟卡在OnlyFans上进行充值。 二、如何使用虚拟卡支付 O…

变形金刚:第 2 部分:变形金刚的架构

目录 一、说明 二、实现Transformer的过程 第 1 步&#xff1a;代币化&#xff08;Tokenization&#xff09; 第 2 步&#xff1a;对每个单词进行标记嵌入 第 3 步&#xff1a;对每个单词进行位置嵌入 第 4 步&#xff1a;输入嵌入 第 5 步&#xff1a;编码器层 2.5.1 多头自注…

洛谷 9242.接龙数列

这道题有点难度&#xff0c;是动态规划经典问题最长上升序列的变式&#xff0c;需要压缩dp数组。 思路&#xff1a;从题目中知道了&#xff0c;数的大小其实是无所谓的&#xff0c;我们只关心这个数的首位和末尾是怎么样的。显然&#xff0c;如果说强力暴力分析的话&#xff0…

【MySQL】高度为2和3时B+树能够存储的记录数量的计算过程

文章目录 题目答案高度为2时的B树高度为3时的B树总结 GPT4 对话过程 题目 InnoDB主键索引的Btree在高度分别为 2 和 3 时&#xff0c;可以存储多少条记录&#xff1f; 答案 高度为2时的B树 计算过程&#xff1a; 使用公式 ( n 8 ( n 1 ) 6 16 1024 ) (n \times 8 …

二维数组及函数的非函数实现

2024年2月14日 1.请编程实现二维数组的杨慧三角 #include<stdio.h> #include<stdlib.h> #include<string.h> void Yanghui(int n,int (*p)[n]) {for(int i0;i<n;i){for(int j0;j<i;j){if(j0||ij){*(*(pi)j)1;}else{*(*(pi)j)*(*(pi-1)j-1)*(*(pi-1)j)…

vim命令编辑完文件后,按ESC键退出编辑模式,无法进入命令模式解决方案

发现问题 在Vim编辑器中&#xff0c;我们通常需要按Esc键来退出编辑模式并进入命令模式。但有时&#xff0c;你可能会发现即使按了Esc键&#xff0c;也无法进入命令模式。这可能是由于某些设置或插件导致的。不过&#xff0c;有一个解决办法可以帮助你解决这个问题。 解决办法…

相机图像质量研究(15)常见问题总结:光学结构对成像的影响--暗角

系列文章目录 相机图像质量研究(1)Camera成像流程介绍 相机图像质量研究(2)ISP专用平台调优介绍 相机图像质量研究(3)图像质量测试介绍 相机图像质量研究(4)常见问题总结&#xff1a;光学结构对成像的影响--焦距 相机图像质量研究(5)常见问题总结&#xff1a;光学结构对成…

456. 车站分级(拓扑排序,虚拟点建图)

活动 - AcWing 一条单向的铁路线上&#xff0c;依次有编号为 1, 2, …, n1,  的 n 个火车站。 每个火车站都有一个级别&#xff0c;最低为 1 级。 现有若干趟车次在这条线路上行驶&#xff0c;每一趟都满足如下要求&#xff1a;如果这趟车次停靠了火车站 x&#xff0c;…

实现常用string

成员变量 class string{public: private:char* _str;size_t _size;size_t _capacity;}; 构造函数 string()//1:_str(new char[1])//:_str(nullptr),_size(0),_capacity(0){_str[0] \0;} new char[1]为了统一析构数组 string(const char* str "\0"):_size(strlen(…

Elasticsearch:特定领域的生成式 AI - 预训练、微调和 RAG

作者&#xff1a;来自 Elastic Steve Dodson 有多种策略可以将特定领域的知识添加到大型语言模型 (LLM) 中&#xff0c;并且作为积极研究领域的一部分&#xff0c;正在研究更多方法。 对特定领域数据集进行预训练和微调等方法使 LLMs 能够推理并生成特定领域语言。 然而&#…

指针练习题

一&#xff0e;选择题 1.变量的指针&#xff0c;其含义是指该变量的 B 。 A&#xff09;值 B&#xff09;地址 C&#xff09;名 D&#xff09;一个标志 2.已有定义int k2;int *ptr1,*ptr2;且ptr1和ptr2均已指向变量k&…