赞
踩
2019年华为校园招聘已经开启,笔试也在如火如荼的进行中,研发岗位的小伙伴们免不了要参加华为的机试,那么小编就来分享一下往年华为机试的题目。
题目描述:计算字符串最后一个单词的长度,单词以空格隔开
输入描述:一行字符串,非空,长度小于5000
输出描述:整数N,最后一个单词的长度。
思路分析:本题较为简单,使用Java语言的split()方法可以将字符串分割为字符串数组,根据下标得到字符串数组的最后一个元素,求得其长度即可。参考代码如下所示:
- import java.util.Scanner;
-
- /**
- *
- * @author LXH
- *
- */
-
- public class LastWordLength {
- public static void main(String[] args) {
- Scanner scanner = new Scanner(System.in);
-
- while(scanner.hasNext()) {
- String input = scanner.nextLine();
- String[] array = input.split(" ");
- System.out.println(array[array.length-1].length());
- }
-
- scanner.close();
- }
- }
题目描述:写出一个程序,接受一个由字母和数字组成的字符串,和一个字符,然后输出输入字符串中有该字符的个数。不区分大小写。
输入描述:输入一个有字母和数字以及空格组成的字符串,和一个字符。
输出描述:输出输入字符串中含有该字符的个数。
思路分析:题目描述中有一点很重要的信息就是:不区分大小写,所以我们接收到字符串和一个字符后,可以统一将他们转化为小写(或在比较的时候忽略大小写),在对字符串进行一次遍历,得到该字符在字符串中出现的次数。参考代码如下所示:
- import java.util.Scanner;
-
- /**
- *
- * @author LXH
- *
- */
- public class WhichCharHasHowMany {
- public static void main(String[] args) {
- Scanner scanner = new Scanner(System.in);
-
- while(scanner.hasNext()) {
- int count = 0;
- String input = scanner.next();
- String whichChar = scanner.next();
- input = input.toLowerCase();
- whichChar = whichChar.toLowerCase();
- for(int i = 0; i < input.length(); i++) {
- if(String.valueOf(input.charAt(i)).equals(whichChar)) {
- ++count;
- }
- }
- System.out.println(count);
- }
-
- scanner.close();
- }
- }
题目描述:连续输入字符串,请按长度为8拆分每个字符串后输出到新的字符串数组;长度不是8的整数倍的字符串请在后面补数字0,空字符串不处理。
输入描述:连续输入字符串(输入2次,每个字符串长度小于100)
输出描述:输出到长度为8的新的字符数组
思路分析:本题输入的字符串有四种情况。第一:当字符串长度为0,即空字符串时,不予处理,继续接收下一个字符串。第二:当字符串长度小于8时,在该字符串后补充8 - str.length()个0。第三:当字符串长度等于8时,直接将原字符串输出即可。第四:当字符串的长度大于8时,先输出若干长度为8的字符串,直至剩余字符串长度不足8,在剩余字符串后补充相应的0。参考代码如下所示:
- import java.util.Scanner;
-
- public class PrintStringWith8 {
- public static void main(String[] args) {
- Scanner scanner = new Scanner(System.in);
-
- while(scanner.hasNext()) {
- StringBuffer buffer = new StringBuffer();
- String input = scanner.next();
- if(input.length() == 0) {
- continue;
- }
- if(input.length() < 8) {
- int zeroCount = 8 - input.length();
- buffer.append(input);
- for(int i = 0; i < zeroCount; i++) {
- buffer.append("0");
- }
- System.out.println(buffer.toString());
- } else if(input.length() > 8) {
- int beginIndex = 0;
- while(input.length() - beginIndex > 8) {
- System.out.println(input.substring(beginIndex, beginIndex + 8));
- beginIndex += 8;
- }
- // 若input.length() - beginIndex == 8则说明该字符串的长度为8的倍数,恰好可以整分为长度为8的字符串输出
- // 无需在后面追加0
- int zeroCount = 8 - (input.length() - beginIndex);
- buffer.append(input.substring(beginIndex));
- for(int i = 0; i < zeroCount; i++) {
- buffer.append("0");
- }
-
- System.out.println(buffer.toString());
- } else {
- System.out.println(input);
- }
- }
-
- scanner.close();
- }
- }
本片博文是本系列的第一篇博文,所分享的三个编程题从难度来说还是比较简单的,在后续的文章中小编会继续分享华为公司的上机题目的。希望大家可以继续支持小编哦。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。