计算机挑战赛3

老式的计算机只能按照固定次序进行运算,华安大学就有这样一台老式计算机,计算模式为A@B#C,@和#为输入的运算符(可能是+、-或*,运算符优先级与C++一致),现给出A,B,C的数值以及@和#对应的运算符,请你编写程序,验证老式计算机的运行结果。输入说明:第一行是一个整数N(IN≤10000),表示有N组计算数据需要处理,接下来N行,每行是相应的数据,包括三个整数和两个运算符,分别对应A、@、B、#和C。输出说明:对每行输入的数据,输出计算结果。输入样例:

3

1 - 12 + 12

12 * 1 - 8

13 + 13 * 2

输出样例:

23

4

39

代码:

C++:

cpp 复制代码
#include<iostream>
using namespace std;
int main() {
	int n;
	cin >> n;
	for (int i = 0; i < n; i++) {
		int a, b, c;
		char d, e;
		cin >> a >> d >> b >> e >> c;
		if (d == '+' && e == '+') {
			cout << a + b + c << endl;
		}
		else if (d == '+' && e == '-') {
			cout << a + b - c << endl;
		}
		else if (d == '+' && e == '*') {
			cout << a + b * c << endl;
		}
		else if (d == '-' && e == '-') {
			cout << a - b - c << endl;
		}
		else if (d == '-' && e == '+') {
			cout << a - b + c << endl;
		}
		else if (d == '-' && e == '*') {
			cout << a - b * c << endl;
		}
		else if (d == '*' && e == '+') {
			cout << a * b + c << endl;
		}
		else if (d == '*' && e == '-') {
			cout << a * b - c << endl;
		}
		else if (d == '*' && e == '*') {
			cout << a * b * c << endl;
		}
	}
	return 0;
}

Python:

python 复制代码
n = int(input())
for i in range(0, n, 1):
    a, d, b, e, c = map(str, input().split())
    if d == '+' and e == '+':
        print(int(a) + int(b) + int(c))
    elif d == '+' and e == '-':
        print(int(a) + int(b) - int(c))
    elif d == '+' and e == '*':
        print(int(a) + int(b) * int(c))
    elif d == '-' and e == '+':
        print(int(a) - int(b) + int(c))
    elif d == '-' and e == '-':
        print(int(a) - int(b) - int(c))
    elif d == '-' and e == '*':
        print(int(a) - int(b) * int(c))
    elif d == '*' and e == '+':
        print(int(a) * int(b) + int(c))
    elif d == '*' and e == '-':
        print(int(a) * int(b) - int(c))
    elif d == '*' and e == '*':
        print(int(a) * int(b) * int(c))

Java:

java 复制代码
package com.my.gududu;

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        for (int i = 0; i < n; i++) {
            int a, b, c;
            char d, e;
            a = input.nextInt();
            d = input.next().charAt(0);
            b = input.nextInt();
            e = input.next().charAt(0);
            c = input.nextInt();
            if (d == '+' && e == '+') {
                System.out.println(a + b + c);
            }
            else if (d == '+' && e == '-') {
                System.out.println(a + b - c);
            }
            else if (d == '+' && e == '*') {
                System.out.println(a + b * c);
            }
            else if (d == '-' && e == '+') {
                System.out.println(a - b + c);
            }
            else if (d == '-' && e == '-') {
                System.out.println(a - b - c);
            }
            else if (d == '-' && e == '*') {
                System.out.println(a - b * c);
            }
            else if (d == '*' && e == '+') {
                System.out.println(a * b + c);
            }
            else if (d == '*' && e == '-') {
                System.out.println(a * b - c);
            }
            else if (d == '*' && e == '*') {
                System.out.println(a * b * c);
            }
        }
    }
}
相关推荐
WBluuue14 小时前
Codeforces 1096 Div3(ABCDEFGH)
c++·算法
wanzehongsheng14 小时前
基于天文算法的双轴太阳能追踪系统:从原理到工程实现
算法
誰能久伴不乏14 小时前
ibmodbus “Invalid argument“ 错误的排查与修复
c++·qt·modbus
basketball61614 小时前
Kadane算法 C++实现
java·c++·算法
handler0114 小时前
【C++】二叉搜索树详解及其模拟实现(代码)
开发语言·c++·算法·c··二叉搜索树·搜索树
luj_176814 小时前
残熵算法的稳健防灾逻辑
c语言·开发语言·c++·经验分享·算法
玖釉-14 小时前
二叉树基础详解:TreeNode、buildTree、deleteTree 与 printTree 的实现原理(C++)
c++·windows·算法
Severus_black14 小时前
【初阶数据结构与算法】八大排序之非比较排序(计数排序),一次性讲清!
数据结构·算法·排序算法
罗西的思考15 小时前
【Agentic RL / 强化学习 / OPD】OpenClaw-RL 源码阅读笔记 --- (4)--- 系统架构
人工智能·算法·机器学习
QiLinkOS15 小时前
从技术到资产的跃迁:企业专利布局的深层逻辑
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源