HW2018校招软件类笔试题
一、
1、题目
输入一个字符串,输出字符串中最长的数字串。如果有多个数字串长度相等且都是最长的,则按照字符串顺序输出最后一个最长的数字串。
2、解答
【code】
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
//输入字符串
String s = sc.nextLine();
// 替换字符串中的字母为空格
String s1 = s.replaceAll("[a-z]", " ");
// 分割字符串
String[] strArray = s1.split(" ");
///创建HashMap,存储分割的子数字串,key存储长度,value存储数字串
HashMap<Integer, String> hashMap = new HashMap<>();
//把字符串中的各个子数字串存入linkedHashMap,key存储长度,value存储数字串.在map中,key不能重复,如果有相同的key,后面添加的值会覆盖前面添加的值
for (int i = 0; i < strArray.length; i++) {
if ((strArray[i].length() != 0) && (strArray[i].charAt(0) != ' ')) {
hashMap.put(strArray[i].length(), strArray[i]);
}
}
//输出最长的数字串
int length = 0;
String num = "";
for (Integer key : hashMap.keySet()) {
if (key >= length) {
length = key;
num = hashMap.get(key);
}
}
System.out.println(num + "," + length);
}
sc.close();
}
}
二、
1、题目
输入字节数组长度uiIutputLen, 如:3;
输入字节数组aInputByte,如: 0x62 0x80 0x00 ;
输入解析数值个数uiElementNum,如:2
输入第一个解析数值的位数,如:4
输入第一个解析数值的位数,如:5
输出解析出的第一个数值:5
输出解析出的第二个数值:6
2、输入输出描述
输入:
3
0x62 0x80 0x00
2
4
5
输出:
6
5
2、解答
【code】
import java.util.Scanner;
public class Main1 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
//输入字节数组长度uiIutputLen
int uiIutputLen = sc.nextInt();
//输入字节数组aInputByte: 0x62 0x80 0x00
String str = "";
String[] aInputByte = new String[uiIutputLen];
for (int i = 0; i < aInputByte.length; i++) {
aInputByte[i] = sc.next();
str += aInputByte[i];
}
//输入解析数值个数uiElementNum
int uiElementNum = sc.nextInt();
//输入各个解析数值的位数
int[] array = new int[uiElementNum];
for (int i = 0; i < array.length; i++) {
array[i] = sc.nextInt();
}
//字节数组aInputByte[3]为{0x62, 0x80, 0x00},对应二进制为“0110 0010, 1000 0000, 0000 0000”;
//去掉16进制数前的0x
String newStr = str.replaceAll("0x", " ");
String[] strArray = newStr.split(" ");
//把16进制数转换成二进制数,并且连接到一起
String binaryString = "";
for (int i = 0; i < strArray.length; i++) {
if ((strArray[i].length() != 0) && (strArray[i].charAt(0) != ' ')) {
binaryString += hexString2binaryString(strArray[i]);
}
}
//二进制数转十进制,输出结果
int begin = 0;
int end = array[0];
for (int i = 0; i < uiElementNum; i++) {
String s = binaryString.substring(begin, end);
System.out.println(Integer.parseInt(s, 2));
begin = end;
//判断有没有超出数组范围
if ((i + 1) >= uiElementNum) {
break;
}
end = array[i + 1] + begin;
}
}
sc.close();
}
//16进制转2进制
public static String hexString2binaryString(String hexString) {
if (hexString == null || hexString.length() % 2 != 0)
return null;
String bString = "", tmp;
for (int i = 0; i < hexString.length(); i++) {
tmp = "0000"
+ Integer.toBinaryString(Integer.parseInt(hexString
.substring(i, i + 1), 16));
bString += tmp.substring(tmp.length() - 4);
}
return bString;
}
}
HW2018校招软件类笔试题的更多相关文章
- 剑指Offer——网易校招内推笔试题+模拟题知识点总结
剑指Offer--网易校招内推笔试题+模拟题知识点总结 前言 2016.8.2 19:00网易校招内推笔试开始进行.前天晚上利用大约1小时时间完成了测评(这个必须做,关切到你能否参与面试).上午利用2 ...
- 华为2018软件岗笔试题之第一题python求解分享
闲来无事,突然看到博客园首页上有人写了篇了华为2018软件岗笔试题解题思路和源代码分享.看了下题目,感觉第一题能做出来,就想着用刚刚学的python试着写一下,花费的时间有点长~~,看来又好长时间没练 ...
- c#软件工程师笔试题
近来有打算重新找工作,还没提离职,投了几家公司简历,其中一家比较中意的公司给发了面试题,其实,好像是好几天前的事了,主要是Gmail邮箱很少用,所以一直都没去看,今天看到题目给解了. 题目如下: 题目 ...
- 2015-01-19 .Net 软件工程师 笔试题
填空题 1.String是__类型(值类型或引用类型) 2.int的基类是__ 3.实现__的类,可以应用foreach语句 4.要输出一段XML文档,用__类来实现能够确保输出正确格式的XML,输出 ...
- 2015-01-16 .Net 中级软件工程师 笔试题
一 C#方面 1.请简述多线程需要考虑的主要因素 答:1.线程管理 同一核上的两个线程不会以两倍的时长完成,可能需要用两倍再加10 %左右的时间来完成.与一个线程相比较的话,三个线程在同一核上想占用1 ...
- 蘑菇街2015校招 Java研发笔试题 详解
1. 对进程和线程描述正确的是( ) A. 父进程里的所有线程共享相同的地址空间,父进程的所有子进程共享相同的地址空间. B. 改变进程里面主线程的状态会影响其他线程的行为,改变父进程的状态不会影 ...
- 牛客网 —— 爱奇艺2020校招C++方向笔试题 总结
错了5,6个,主要集中在数据库和操作系统上. C++还需要提高熟练度. 总结 第6题: 折半查找树:根据二分查找构造得到的树,它一定是一个二叉排序树,是一个特殊的二叉排序树. (接近于平衡二叉 ...
- 2014-04-17-网易有道-研发类-笔试题&參考答案
一套卷子,共10道小题,3道编程大题 一.填空&选择 1.选择:给了一个递归求Fibonacci的代码,问算法复杂度 指数复杂度 2.选择:忘记了,应该不难 3.选择:给你52张除掉大小王的扑 ...
- 牛客网-声网2020校招-通用C++笔试题-2020.9.3
1. 操作系统中两个进程争夺同一个资源会发生什么情况? 答:不一定死锁 解析:产生死锁的四个必要条件为 (1)互斥条件:一个资源每次只能被一个进程使用. (2)不可剥夺条件:进程已获得的资源,在未使用 ...
随机推荐
- Play中JSON序列化
总的来说在scala体系下,对于习惯了java和c#这些常规开发的人来说,无论是akka-http还是play,就处理个json序列化与反序列化真他娘够费劲的. 根据经验,Json处理是比较简单的,但 ...
- Scikit-learn 安装
Scikit-Learn 3 pip 安装 如果安装了Python,没有安装pip,使用Windows + R,输入cmd,回车打开命令行,输入 python -m pip install -U pi ...
- 【转】【机器学习】R 正则化函数 scale
源:http://blog.163.com/shen_960124/blog/static/60730984201582594011277/ 1. 数据的中心化 所谓数据的中心化是指数据集中的各项数据 ...
- ibatis中的resultMap
优点: resultMap可以实现一种功能 当你是1对多 这种多张表查询的时候 你没办法 通过表连接来实现一个集合设置到一个实例里,但是通过resultMap里可以做到 根据关联的字段 查询到一个集合 ...
- SQL: Cannot create JDBC driver of class '' for connect URL
使用数据库数据源的web 项目,发布后,访问数据库500报错: 浏览器端: 控制台: 数据库连接池在不启动Tomcat的情况下,测试类通过,没有问题. 一旦在服务器发布,就会出现问题,考虑是Tomca ...
- Python从入门到精通之Second!
初识Python基础! -基础 -扩展名可以是任意的,但是导入模块时,如果不是.py文件就会报错. -两种执行方式 1.python解释器 文件名.py 文件路径 -Li ...
- mount的几个选项
一.mount -o noatime表示在读文件时不去更改文件的access time属性了,所以该选项会提升mount操作的执行效率. 二.mount --bind:等同于 -o bind可用于挂载 ...
- python time库
https://www.cnblogs.com/tkqasn/p/6001134.html
- Python 处理 json
Python在处理json数据中有四个重要的函数:dump,load:dumps,loads. 序列化(dict 包装成 json文件) dump(转储):将字典dic对象 转化为 json文件 AP ...
- echarts 调整图表 位置 的方法
###内部图表大小是与div容器大小位置相关的,如果想调整图表大小位置,调整div的属性就可以了### ###如果是想调整图表与div间上下左右留白,则设置grid属性就可以了### 如图所示: 具体 ...