华为上机试题(java)
一、题目描述:
通过键盘输入一串小写字母(a~z)组成的字符串。请编写一个字符串过滤程序,若字符串中出现多个相同的字符,将非首次出现的字符过滤掉。
比如字符串“abacacde”过滤结果为“abcde”。
public String stringFilter(String str) {
Map<String, Integer> map = new LinkedHashMap<String, Integer>();
String s = "";
for(int i=0; i<str.length(); i++) {
s = String.valueOf(str.charAt(i));
if(map.keySet().contains(s))
map.put(s, map.get(s)+1);
else
map.put(s, 1);
}
String _str = "";
for(Map.Entry<String, Integer> entry : map.entrySet()) {
_str += entry.getKey();
}
return _str;
}
-- 这里要注意,HashMap中元素的遍历顺序,并非按输入顺序,而是按“有利于随机查找的散列(hash)的顺序”。
-- LinkedHashMap 是按加入时的顺序遍历,类似的还有LinkedHashSet。
二、题目描述:
通过键盘输入一串小写字母(a~z)组成的字符串。请编写一个字符串压缩程序,将字符串中连续出席的重复字母进行压缩,并输出压缩后的字符串。
压缩规则:
1、仅压缩连续重复出现的字符。比如字符串"abcbc"由于无连续重复字符,压缩后的字符串还是"abcbc"。
2、压缩字段的格式为"字符重复的次数+字符"。例如:字符串"xxxyyyyyyz"压缩后就成为"3x6yz"。
public String stringZip(String str) {
String _str = "";
int i = 0; //游标位置
char c; //游标字符
while(i<str.length()) {
int n = 1; //相邻相同字符的个数
c = str.charAt(i);
for(int j=i+1; j<str.length(); j++) {
char _c = str.charAt(j);
if(c==_c) {
n++;
} else {
break;
}
}
if(n==1) {
_str += c;
} else if(n>1){
_str += String.valueOf(n) + c;
}
i += n; //游标位置
}
return _str;
}
三、题目描述:
通过键盘输入100以内正整数的加、减、乘、除运算式,请编写一个程序输出运算结果字符串。
输入字符串的格式为:“操作数1 运算符 操作数2”,“操作数”与“运算符”之间以一个空格隔开。
补充说明:
1、操作数为正整数,不需要考虑计算结果溢出的情况。
2、若输入算式格式错误,输出结果为“0”。
public int arithmetic(String str) {
String[] strArr = str.split(" ");
if(strArr.length!=3 || !isNumeric(strArr[0]) || !isNumeric(strArr[2])) {
return 0;
}
String operator = strArr[1]; //运算符
int leftInt = Integer.valueOf(strArr[0]); //左操作数
int rightInt = Integer.valueOf(strArr[2]); //右操作数
int i = 0;
if("+".equals(operator)) {
i = leftInt + rightInt;
} else if("-".equals(operator)) {
i = leftInt - rightInt;
} else if("*".equals(operator)) {
i = leftInt * rightInt;
} else if("/".equals(operator)) {
i = leftInt / rightInt;
}
return i;
}
//判断字符串是否可转化为数字
public static boolean isNumeric(String str){
for (int i=0; i<str.length(); i++){
if (!Character.isDigit(str.charAt(i))){
return false;
}
}
return true;
}
四、题目描述:
求一个字符串中有没有相同的部分,例如abcsabcvx这个字符串中相同的部分是abc,相同的部分至少应该为2位数,如果有相同部分返回true,如果没有返回false。
public boolean hasSameSubString(String str) {
int i = 0;
int length = str.length();
while(i<length){
for(int j=2; j<length-i; j++) {
String s1 = str.substring(i, i+j); //被包含字符串
String s2 = str.substring(i+j, length); //包含字符串
if(s1.length()<=s2.length() && s2.indexOf(s1)!=-1){ //判断条件
return true;
}
}
i++;
}
return false;
}
华为上机试题(java)的更多相关文章
- 华为上机题汇总----java
以下华为上机题目都是网上整理得到的,代码都是自己调试过的,由于网上java答案较少,欢迎大家批评指正,也希望对准备华为上机的童鞋们有一点点帮助.在练习的过程中成长,加油!~~ 第1题:输入字 ...
- C语言面试题大汇总之华为面试题 Eddy整理
1.局部变量能否和全局变量重名? 答:能,局部会屏蔽全局.要用全局变量,需要使用"::" ;局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局 ...
- 牛客网华为机试题之Python解法
牛客网华为机试题之Python解法 第1题 字符串最后一个单词的长度 a = input().split(" ") print(len(a[-1])) 第2题 计算字符个数 a = ...
- 面试题-Java设计模式举例
面试题-Java设计模式举例 1.适配器模式 涉及三个角色:Target目标接口.Adaptee源角色.Adapter适配器:Adapter将源接口适配到目标接口,继承源接口,实现目标接口. Java ...
- 求一个int型整数的两种递减数之和(java)--2015华为机试题
题目描述: 给出一个整数(负数使用其绝对值),输出这个整数中的两种递减数(1.最大递减数:2.递减数中各位数之和最大的数)之和. 递减数:一个数字的递减数是指相邻的数位从大到小排列的数字,不包含相邻的 ...
- java华为面试题
JAVA方面 1 面向对象的特征有哪些方面 2 String是最基本的数据类型吗? 3 int 和 Integer 有什么区别 4 String 和StringBuffer的区别 5运行时异常与一般异 ...
- 华为上机测试题(MP3光标移动-java)
PS:此题满分,可参考 描述: MP3 Player因为屏幕较小,显示歌曲列表的时候每屏只能显示几首歌曲,用户要通过上下键才能浏览所有的歌曲.为了简化处理,假设每屏只能显示4首歌曲,光标初始的位置为第 ...
- 华为上机测试题(数字字符串转二进制-java)
PS:此题满分,可参考 /* * 题目:数字字符串转二进制 * 描述: 输入一串整数,将每个整数转换为二进制数,如果倒数第三个Bit是“0”,则输出“0”,如果是“1”,则输出“1”. 题目类别: ...
- 华为上机测试题(水仙花数升级版-java)
PS:这题满分100,没有做对,大家帮忙看看问题在哪 /* * 题目:水仙花数升级版 * 描述: 水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身.(例如:1 ...
随机推荐
- js上传文件(图片)的格式和大小限制
如果你想快速解决这个问题,看本文就够了.查了好多资料,终于解决了,太耗时间了,本文留给给后来者,希望你们工作的更轻松 本文保存为.html文件用浏览器打开即可测试功能 <form id=&quo ...
- 模板 Fail树
fail树就是将Trie图的Fail指针反指,从而生成一棵树,这个树的性质是:子节点对应字符串为以当前串为后缀,而子节点为原串的前缀,前缀的后缀就是嵌套在原串中的子串. 模板:BZOJ3172 Des ...
- php基础篇之一
1.PHP是什么 官方文档:超文本预处理器 2.PHP能够做一些什么? PHP主要应用在一下领域: (1)服务器端脚本,需要:PHP解析器,PHP服务器,PHP浏览器. (2)命令行脚本,只需要PHP ...
- MFC 任务托盘经常消失问题
经常发现自己写的程序任务托盘会无缘无故的消失,但是进程还是存在的,原来是资源管理器异常的时候,重新生成的时候,程序需要重新添加下任务托盘. 当explorer进程重启,taskbar将会被创建,tas ...
- 2018/8/21 qbxt测试
2018/8/21 qbxt测试 期望得分:0? 实际得分:0 思路:manacher 会写模板但是不会用 qwq 听了某人的鬼话,直接输出0,然后就gg了 #include <cstdio ...
- restcontroller和controller区别
http://www.cnblogs.com/softidea/p/5884772.html#undefined http://blog.csdn.net/blueheart20/article/de ...
- CODEVS——T1332 上白泽慧音 || 洛谷——P1726 上白泽慧音
http://codevs.cn/problem/1332/|| https://www.luogu.org/problem/show?pid=1726#sub 时间限制: 1 s 空间限制: 1 ...
- 18. springboot整合jsp
转自:https://blog.csdn.net/u012562943/article/details/51836729
- 7. 基于Express实现接口
安装Mongoose 创建model //server/models/goods.js var mongoose = require('mongoose');//优先到node_modeles里加载 ...
- WSDL文档框架