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)不可剥夺条件:进程已获得的资源,在未使用 ...
随机推荐
- 解决初次安装PyCharm后 No Python interpreter selected的问题
原文链接:https://liuzhichao.com/p/1543.html PyCharm 是由JetBrains打造的一款 Python IDE.具有智能代码编辑器,能理解 Python 的特性 ...
- 安装composer Failed to decode zlib stream 问题解决方法
https://getcomposer.org/download/ 页面下载最新版本 composer.phar 放到php.exe 页面下.创建一个.bat文件,存入下面内容 @ECHO OFF p ...
- UVA 10944 Nuts for nuts..
题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=21&p ...
- Acoustic modelling from the signal domain using CNNs
3. Neural network architecture 此处描述了在本文当中所使用的网络结构,和所提取的关键特征(key features).首先,描述了两个新型的网络结构:the networ ...
- Python开发——16.HTML
一.HTML 1.服务端 import socket def main(): sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM) sock. ...
- vue的指令
我之前学了学angular 发现angular和vue的指令有点类似 先说一下 new Vue({ el: "#box", // element(元素) 当前作 ...
- 20155326《网路对抗》Exp8 WEB基础实践
20155326<网路对抗>Exp8 WEB基础实践 实践内容 (1).Web前端HTML(0.5分) 能正常安装.启停Apache.理解HTML,理解表单,理解GET与POST方法,编写 ...
- win32控制台程序 宽字符与短字符转化
由于vs各版本之间存在字符设置不兼容问题,特总结char与tchar的互相转换函数,如下,在之后的工程中可以使用. void TcharToChar(const TCHAR * tchar, char ...
- 《OpenCV3编程入门》学习笔记
把第一章的例程看完了,除了基本的操作函数,还了解了跟视频操作有关的函数,发现在自己的中心偏检测中,不仅可以处理图片,还可以对视频进行处理. 问题解决方案 1.0x7547d36f 处有未经处理的异常: ...
- 蓝桥杯_算法训练_ALGO10_集合运算
这个题实际上思路是比较简单的,但是需要注意细节问题. 思路:读入数组之后进行排序,然后再求交.并.补集. 首先排序:(使用的是冒泡排序) #include<iostream> using ...