蓝桥杯国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("/");
		}
	}
}
相关推荐
筱昕~呀6 天前
冲刺蓝桥杯-DFS板块(第二天)
算法·蓝桥杯·深度优先
仰泳的熊猫6 天前
蓝桥杯算法提高VIP-种树
数据结构·c++·算法·蓝桥杯·深度优先·图论
筱昕~呀6 天前
冲刺蓝桥杯-DFS板块(第一天)
算法·蓝桥杯·深度优先
yzx9910137 天前
蓝桥杯备考智能体:构建高并发、智能化编程竞赛助手的深度实践
职场和发展·蓝桥杯
仰泳的熊猫8 天前
题目1549:蓝桥杯算法提高VIP-盾神与积木游戏
数据结构·c++·算法·蓝桥杯
仰泳的熊猫8 天前
题目1545:蓝桥杯算法提高VIP-现代诗如蚯蚓
数据结构·c++·算法·蓝桥杯
仰泳的熊猫9 天前
题目1535:蓝桥杯算法提高VIP-最小乘积(提高型)
数据结构·c++·算法·蓝桥杯
仰泳的熊猫9 天前
题目1531:蓝桥杯算法提高VIP-数的划分
数据结构·c++·算法·蓝桥杯
List<String> error_P9 天前
蓝桥杯基础知识点:模拟-数位操作类题目
python·算法·蓝桥杯
yzx9910139 天前
蓝桥杯智能体开发:从入门到实战经验分享
职场和发展·蓝桥杯