常见Java问题及笔试题(十七)——阿里2017实习生研发题

2024-06-03 10:58

本文主要是介绍常见Java问题及笔试题(十七)——阿里2017实习生研发题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:一个对于一个单行的逆波兰表达式,由如下元素构成:

数字:十进制数字字符构成的正整数,比如 223

运算符:支持三种运算符^+和*,分别代表自增,加法和乘法

分隔符:一个或者多个空格

例如下面的字符串就是个逆波兰表达式

2 3 4 * ^ 5 +

逆波兰表达式在一个基于栈的虚拟机中求解,虚拟机的栈能保存16个整数,虚拟机从左向右扫描表达式,遇到整数就压栈,遇到表达式则从栈顶弹出若干个整数进行计算,计算结果重新压回栈中。其中运算符^从栈顶弹出一个整数,增加1之后压栈;运算符+和*从栈顶弹出两个整数,分别做相加和相乘运算后压栈。如果遇到运算符的时候,栈内没有足够的整数,称为下溢出,返回-1;把整数压栈的时候,如果栈没有足够的空间,称为上溢出,返回-2;如果整个计算过程中没有发生溢出,在整个表达式求解完成后,返回栈顶的整数。

分析:其实这题,之前我是写过的,LeetCode上面有这道题,但是当时没有异常处理,还是小编机智,发现了这个点,一开始,我在本地测试都是对的,但是不知道为什么每次在线测试都是通过率都是0,后来才发现没有处理异常。好了代码如下:

import java.util.ArrayDeque;

import java.util.ArrayList;

import java.util.Scanner;

public class Main {

public static void main(String[] args) {

ArrayList<Integer> inputs = new ArrayList<Integer>();

Scanner in = new Scanner(System.in);

String line = in.nextLine();

if (line != null && !line.isEmpty()) {

int res = resolve(line.trim());

System.out.println(String.valueOf(res));

}

}

public static int resolve(String expr) {

ArrayDeque<Integer> stack = new ArrayDeque<>();

String[] str = expr.split(" ");

if (str.length > 16) {

return -2;

}

for (int i = 0; i < str.length; i++) {

if (str[i].matches("\\d+$")) {

stack.push(Integer.parseInt(str[i]));

if (stack.size() > 16) {

return -2;

}

} else {

String temp = str[i];

switch (temp) {

case "^":

try {

int i1 = (int) stack.pop() + 1;

stack.push((Integer) i1);

break;

} catch (Exception e) {

return -1;

}

case "+":

try {

int right = stack.pop();

int left = stack.pop();

stack.push(right + left);

break;

} catch (Exception e) {

return -1;

}

case "*":

try {

int right1 = stack.pop();

int left1 = stack.pop();

stack.push(right1 * left1);

break;

} catch (Exception e) {

return -1;

}

}

}

}

return stack.pop();

}

}

代码已通过在线测试!只是个人觉得代码好像不是很漂亮!

最后小编依然欢迎大家评论!小编会在第一时间回复,如果喜欢的话,欢迎订阅哦!一起交流学习进步,毕竟头条的读者中编程大神大有人在啊!

这篇关于常见Java问题及笔试题(十七)——阿里2017实习生研发题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026797

相关文章

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Spring MVC如何设置响应

《SpringMVC如何设置响应》本文介绍了如何在Spring框架中设置响应,并通过不同的注解返回静态页面、HTML片段和JSON数据,此外,还讲解了如何设置响应的状态码和Header... 目录1. 返回静态页面1.1 Spring 默认扫描路径1.2 @RestController2. 返回 html2

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去