蓝桥杯国14 不完整的算式

!!!!!!!!!!!!!!!理清思路 然后一步步写

问题描述

小蓝在黑板上写了一个形如 AopB=C 的算式,其中 A、B、C 都是非负整数,op 是 +、-、*、/(整除)四种运算之一。不过 A、op、B、C 这四部分有一部分被不小心的同学擦掉了。

给出这个不完整的算式,其中被擦掉的部分(被擦掉的部分是被完整的擦掉,不会出现留下若干位数字的情况)用 ? 代替。请你输出被擦掉的部分。

输入描述

输入只有一行,包含一个字符串代表如上文所述的不完整的算式。

输出描述

如果被擦掉的部分是 A、B、C 之一,请输出一个整数代表答案。如果被擦掉的部分是 op,请输出+、-、*、/四个字符之一代表答案。

样例输入1

复制代码
1+?=2

样例输出1

复制代码
1

样例输入2

复制代码
10?3=3

样例输出2

复制代码
/

代码示例

java 复制代码
import java.util.Scanner;
public class Main{
	public static void main(String[]args)
	{
		Scanner sc=new Scanner(System.in);
		String s=sc.nextLine();
		if(s.contains("+")||s.contains("-")||s.contains("*")||s.contains("/"))//当字符串中有+-*/负号,即缺ABC
		{
			String s1[]=s.split("=");//从=字符将整个字符串分成两个字符串,"A op B"是s1[0],"C"是s1[1];
			String s2=s1[0];//即s2="A op B"
			if(s1[1].equals("?"))//即C被?代替了
			{
				int op=0;
				for(int i=0;i<s2.length();i++) {
					if(s2.charAt(i)<'0'||s2.charAt(i)>'9')//检查运算符所在位置的索引
					{
						op=i;
						break;
					}
				}
				int a=Integer.parseInt(s2.substring(0,op));
				int b=Integer.parseInt(s2.substring(op+1,s2.length()));
				if(s.contains("+"))System.out.println(a+b);
				if(s.contains("-"))System.out.println(a-b);
				if(s.contains("*"))System.out.println(a*b);
				if(s.contains("/"))System.out.println(a/b);
			}
			else {//A或B被替代了
				int c=Integer.parseInt(s1[1]);
				int op=0;
				for(int i=0;i<s2.length();i++)
				{
					if(s2.charAt(i)=='+'||s2.charAt(i)=='-'||s2.charAt(i)=='*'||s2.charAt(i)=='/')//检查运算符所在位置的索引
					{
						op=i;
						break;
					}
				}
				int a=0;
				if(s2.charAt(op-1)>='0'&&s2.charAt(op-1)<='9')//有A缺B
				{
					a=Integer.parseInt(s2.substring(0,op));
					if(s.contains("/"))System.out.println(a/c);
					if(s.contains("-"))System.out.println(a-c);
				}else {//有B缺A
					a=Integer.parseInt(s2.substring(op+1,s2.length()));
					if(s.contains("/"))System.out.println(a*c);
					if(s.contains("-"))System.out.println(a+c);
				}
				if(s.contains("+"))System.out.println(c-a);
				if(s.contains("*"))System.out.println(c/a);
				
			}
		}else {//缺运算符
			String s1[]=s.split("=");//从=字符将整个字符串分成两个字符串
			int c=Integer.parseInt(s1[1]);//转换成整数C
			String s2=s1[0];
			int op=0;
			for(int i=0;i<s2.length();i++)
			{
				if(s2.charAt(i)<'0'||s2.charAt(i)>'9')//检查运算符所在位置的索引
				{
					op=i;
					break;
				}
			}
			int a=Integer.parseInt(s2.substring(0,op));//转换成整数A
			int b=Integer.parseInt(s2.substring(op+1,s2.length()));//转换成整数B
			if(a+b==c)System.out.println("+");
			if(a-b==c)System.out.println("-");
			if(a*b==c)System.out.println("*");
			if(a/b==c)System.out.println("/");
		}
	}
}
相关推荐
xnglan2 天前
蓝桥杯手算题和杂题简易做法
数据结构·数据库·c++·python·算法·职场和发展·蓝桥杯
Warren982 天前
MySQL,Redis重点面试题
java·数据库·spring boot·redis·mysql·spring·蓝桥杯
喜喜安3 天前
蓝桥杯备赛 按键、LCD、定时器
职场和发展·蓝桥杯
CUC-MenG4 天前
2025杭电多校第八场 最有节目效果的一集、最自律的松鼠、最甜的小情侣、最努力的活着 个人题解
数学·线段树·高精度·模拟·dp·红黑树·线性dp·平衡树·线段树维护矩阵
echo_pen4 天前
蓝桥杯---第六届省赛单片机组真题
单片机·蓝桥杯
qiuyunoqy7 天前
蓝桥杯算法之搜索章 - 3
c++·算法·蓝桥杯·深度优先·dfs·剪枝
snowfoootball8 天前
2025 蓝桥杯C/C++国B 部分题解
c语言·c++·笔记·学习·贪心算法·蓝桥杯
爱吃生蚝的于勒10 天前
一文学会c++继承 组合
java·c语言·开发语言·数据结构·c++·算法·蓝桥杯
echo_pen10 天前
蓝桥杯----锁存器、LED、蜂鸣器、继电器、Motor
单片机·蓝桥杯
qiuyunoqy12 天前
蓝桥杯算法之搜索章 - 2
算法·蓝桥杯·深度优先