计算机挑战赛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);
            }
        }
    }
}
相关推荐
fqbqrr33 分钟前
2601C++,cmake与导入
c++
fqbqrr2 小时前
2601C++,编写自己模块
c++
wearegogog1232 小时前
基于 MATLAB 的卡尔曼滤波器实现,用于消除噪声并估算信号
前端·算法·matlab
一只小小汤圆2 小时前
几何算法库
算法
Evand J2 小时前
【2026课题推荐】DOA定位——MUSIC算法进行多传感器协同目标定位。附MATLAB例程运行结果
开发语言·算法·matlab
leo__5202 小时前
基于MATLAB的交互式多模型跟踪算法(IMM)实现
人工智能·算法·matlab
忆锦紫2 小时前
图像增强算法:Gamma映射算法及MATLAB实现
开发语言·算法·matlab
t198751283 小时前
基于自适应Chirplet变换的雷达回波微多普勒特征提取
算法
guygg883 小时前
采用PSO算法优化PID参数,通过调用Simulink和PSO使得ITAE标准最小化
算法
老鼠只爱大米3 小时前
LeetCode算法题详解 239:滑动窗口最大值
算法·leetcode·双端队列·滑动窗口·滑动窗口最大值·单调队列