华为机试编程题(一)

        2019年华为校园招聘已经开启,笔试也在如火如荼的进行中,研发岗位的小伙伴们免不了要参加华为的机试,那么小编就来分享一下往年华为机试的题目。

1、字符串最后一个单词的长度

题目描述:计算字符串最后一个单词的长度,单词以空格隔开

输入描述:一行字符串,非空,长度小于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();
	}
}

2、计算字符个数

题目描述:写出一个程序,接受一个由字母和数字组成的字符串,和一个字符,然后输出输入字符串中有该字符的个数。不区分大小写。

输入描述:输入一个有字母和数字以及空格组成的字符串,和一个字符。

输出描述:输出输入字符串中含有该字符的个数。

思路分析:题目描述中有一点很重要的信息就是:不区分大小写,所以我们接收到字符串和一个字符后,可以统一将他们转化为小写(或在比较的时候忽略大小写),在对字符串进行一次遍历,得到该字符在字符串中出现的次数。参考代码如下所示:

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();
	}
}

3、字符串分隔

题目描述:连续输入字符串,请按长度为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();
	}
}

        本片博文是本系列的第一篇博文,所分享的三个编程题从难度来说还是比较简单的,在后续的文章中小编会继续分享华为公司的上机题目的。希望大家可以继续支持小编哦。

 

你可能感兴趣的:(笔试)