因为最近要找工作了,所以来刷刷往年的面试题目。好了闲话少说,首先要感谢, 博主Hackbuteer1。提供的关于2015年的华为面试题目。这里运行环境是windows7,eclipse.jdk为1.8.0_45。好了直接上题目、代码,及分析。
题目
1、按要求分解字符串,输入两个数M,N;M代表输入的M串字符串,N代表输出的每串字符串的位数,不够补0。例如:输入2,8, “abc” ,“123456789”,则输出为“abc00000”,“12345678“,”90000000”;
[java]代码
public class HuaWei {
public static void main(String[] args) {
Scanner sca = new Scanner(System.in);
while(true){
int strings = sca.nextInt();
int bits = sca.nextInt();
List<String> l = new ArrayList<String>();
for(int i =0; i<strings; i++){
String inputString = sca.next();
l.add(inputString);
}
for(String s1:l){
trans(s1, bits);
}
// System.out.println(strings+" "+bits);
}
}
public static void trans(String s ,int bits){
int length = s.length();
int kuaiShu = length/bits;
int reminder = length%bits;
for(int i=0; i<kuaiShu; i++){
System.out.println(s.substring(i*bits, (i+1)*bits));
}
if(reminder == 0)System.out.println();
else {
StringBuilder temp =new StringBuilder(s.substring(length-reminder, length));
for(int i =reminder; i<bits; i++){
temp.append("0");
}
// System.out.println(temp.toString());
}
}
}
分析:第一题还是蛮简单的,简单的输入输出。权当是练练手。
2、拼音转数字
输入是一个只包含拼音的字符串,请输出对应的数字序列。转换关系如下:
描述: 拼音 yi er san si wu liu qi ba jiu
阿拉伯数字 1 2 3 4 5 6 7 8 9
输入字符只包含小写字母,所有字符都可以正好匹配
运行时间限制:无限制
内存限制: 无限制
输入: 一行字符串,长度小于1000
输出: 一行字符(数字)串
样例输入: yiersansi
样例输出: 1234
public class PinYinToNum {
public static void main(String[] args) {
Scanner sca = new Scanner(System.in);
while(true){
String tmp = sca.next();
System.out.println(PinYin(tmp));
}
}
public static String PinYin(String s){
StringBuilder sb = new StringBuilder();
int length = s.length();
int i =0;
while(i < length){
switch(s.charAt(i)){
case 'y':
sb.append("1");
i = i+2;
break;
case 'e':
sb.append("2");
i = i+2;
break;
case 's':
if(s.charAt(i+1)=='a'){
sb.append("3");
i = i+3;
}else {
sb.append("4");
i = i+2;
}
break;
case 'w':
sb.append("5");
i = i+2;
break;
case 'l':
sb.append("6");
i = i+3;
break;
case 'q':
sb.append("7");
i = i+2;
break;
case 'b':
sb.append("8");
i = i+2;
break;
case 'j':
sb.append("9");
i = i+3;
break;
}
}
return sb.toString();
}
}
3、去除重复字符并排序
运行时间限制:无限制
内容限制: 无限制
输入: 字符串
输出: 去除重复字符并排序的字符串
样例输入: aabcdefff
样例输出: abcdef
public class Hash {
public static void main(String[] args) {
Scanner sca =new Scanner(System.in);
while(true){
String temp = sca.next();
System.out.println(hash(temp));
}
}
//这里java的char类型是16bits的,而c++是8位。注意区分
public static String hash(String s){
StringBuilder sb = new StringBuilder();
int bits = 256;
int hash[] = new int [bits];
Arrays.fill(hash, 0);
for(char c:s.toCharArray()){
if(0 == hash[c]){
hash[c] = 1;
}
}
for(int i=0; i<bits; i++){
if(hash[i] == 1){
char tem =(char)(i);
sb.append(String.valueOf(tem));
}
}
return sb.toString();
}
}
分析
主要的思想是把char中的数据映射到数组中,顺便进行了排序。而这里的哈希函数就是ascii码表。c/c++中char的char是unsigned,8bits。java的char是16bits的,因为java采用的是Unicode,但是ASCII包含在Unicode之中。
这里你也许会问怎么由char转到int,或者这么由int到char。java中int类型是4byte,这里只要不发生越界就可以用(char)强制转换的方式。
4等式变换
输入一个正整数X,在下面的等式左边的数字之间添加+号或者-号,使得等式成立。
1 2 3 4 5 6 7 8 9 = X
比如:
12-34+5-67+89 = 5
1+23+4-5+6-7-8-9 = 5
请编写程序,统计满足输入整数的所有整数个数。
输入: 正整数,等式右边的数字
输出: 使该等式成立的个数
样例输入:5
样例输出:21
public class CombinNum {
public static void main(String[] args) {
int a[] = new int [8];
Arrays.fill(a, 0);
while(true){
int goal = sca.nextInt();
initArray(0, a, goal);
System.out.println(sta);
}
}
public static String [] s ={"1","2","3","4","5","6","7","8","9"};
public static char add = '+';
public static char mins = '-';
public static int sta = 0;
public static String exp="";
public static void initArray(int index, int operator[], int goal){
if(index == 8){
if(caculate(operator) == goal){
sta++;
}
return;
}
for(int i = 0; i < 3; i++){
operator[index] = i;
initArray(index+1, operator, goal);
operator[index] = 0;
}
}
private static int help(char operatorChar, int sum, String number){
if(operatorChar == '+'){
sum += Integer.parseInt(number);
}else if(operatorChar == '-')
sum -= Integer.parseInt(number);
return sum;
}
public static int caculate(int operator[]){
int sum = 0;
String number = s[0];
String expression = s[0];
char o = add;
for(int i = 0; i < 8; i++){
if(operator[i] == 0){
number += s[i+1];
expression += s[i+1];
}else if(operator[i] == 1){
sum = help(o, sum, number);
o = add;
number = s[i+1];
expression += add;
expression += s[i+1];
}else if(operator[i] == 2){
sum = help(o, sum, number);
o = mins;
number = s[i+1];
expression += mins;
expression += s[i+1];
}
}
exp = expression;
sum = help(o, sum, number);
// System.out.println(expression);
return sum;
}
}
分析
这里这题目首选的方式是暴力方法,讲1-9这九个数字中间的符号每个都考虑一遍。然后逐个计算跟结果值比较。中间0代表组合起来,1代表“+”,2代表“-”。就相当于是三进制的一个8bits,从0000 0000到2222 2222。在caculator函数中也有初始第一次运算是当做加法运算的,这里还是蛮有意思的。可以debug下看看。
总结:初次发java代码文章,如有错误欢迎指正。