中软机试失败总结

2024-03-02 21:08
文章标签 总结 失败 机试 中软

本文主要是介绍中软机试失败总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天早晨参加中软的机试,机试规定是在四十分钟内做完一道java题,如果通过可以直接入职了。可惜我今天失败了,现在吧经验总结一下,供大家分享。

题目: 输入一串数据,删除重复的数据。注意:读取字符串的顺序为从右往左,如果结果是以0结束,则删除0;如果结果有负号'-' 需要保留。

例如:输入 99876673 输出 37689 , 输入: 0542564  output: 4652 输入: -235432 output:  -2345

我的代码如下: 

package com.albertshao.interview;import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;public class Main {private static Map<String, Integer> resultMap = new HashMap<String, Integer>();public static void main(String[] args) {Scanner cin = new Scanner(System.in);String inputStr = cin.nextLine();String numStr = new StringBuffer(inputStr).toString();String resultStr = "";char[] numCharArray = numStr.toCharArray();for (int i = 0; i < numCharArray.length; i++) {char[] singleChar = { numCharArray[i] };String cellStr = new String(singleChar);if (!resultMap.containsKey(cellStr)) {resultMap.put(cellStr, 1);} else {				int temp = (resultMap.get(cellStr)).intValue();resultMap.put(cellStr, temp + 1);}}for (String key : resultMap.keySet()) {resultStr += key;}if (resultStr.endsWith("0")) {resultStr = resultStr.substring(0, resultStr.length() - 1);}System.out.println(resultStr);}
}
执行结果: 

99876673
37698
主要原因: 1> 在resultMap 中的数据不是会进行重新排列,不是按照输入进去的顺序

                     2> 如何把字符数据(例如‘9’)对于为int 9. 

                     3> 题目没有看清楚,等到考试结束后我才看到原来是从右到做读数据流。

现在解决方案:

                       1.增加一个numberlist,由于numberlist的数据时按照输入时候的顺序便利的,我只要保证输入到list数据时唯一即可。

                        2. 在顺序输入字符串后对其进行翻转。


更改后代码:

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;public class Main {public static void main(String[] args) {Main m = new Main();Scanner cin = new Scanner(System.in);String inputStr = cin.nextLine();boolean flag = false;if (inputStr.startsWith("-")) {flag = true;inputStr = inputStr.substring(1,inputStr.length());}String resultStr = m.getResultString(inputStr);if (resultStr.endsWith("0")) {resultStr = resultStr.substring(0, resultStr.length() - 1);}if (flag) {resultStr = "-" + resultStr;}System.out.println(resultStr);}public String getResultString(String inputStr) {Map<String, Integer> resultMap = new HashMap<String, Integer>();String numStr = new StringBuffer(inputStr).reverse().toString();char[] numCharArray = numStr.toCharArray();String result = "";for (int i = 0; i < numCharArray.length; i++) {String cellStr = String.valueOf(numCharArray[i]);if (!resultMap.containsKey(cellStr)) {resultMap.put(cellStr, 1);result += cellStr;} else {//do nothing}}return result.trim();}
}



运行结果:

99876673 37689
0542564
4652
-235432
-2345






这篇关于中软机试失败总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

Docker镜像pull失败两种解决办法小结

《Docker镜像pull失败两种解决办法小结》有时候我们在拉取Docker镜像的过程中会遇到一些问题,:本文主要介绍Docker镜像pull失败两种解决办法的相关资料,文中通过代码介绍的非常详细... 目录docker 镜像 pull 失败解决办法1DrQwWCocker 镜像 pull 失败解决方法2总

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

pip无法安装osgeo失败的问题解决

《pip无法安装osgeo失败的问题解决》本文主要介绍了pip无法安装osgeo失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 进入官方提供的扩展包下载网站寻找版本适配的whl文件注意:要选择cp(python版本)和你py

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

Python依赖库的几种离线安装方法总结

《Python依赖库的几种离线安装方法总结》:本文主要介绍如何在Python中使用pip工具进行依赖库的安装和管理,包括如何导出和导入依赖包列表、如何下载和安装单个或多个库包及其依赖,以及如何指定... 目录前言一、如何copy一个python环境二、如何下载一个包及其依赖并安装三、如何导出requirem

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英