小米笔试(09-15)

第一题 有效的括号

leetcode原题,但我一直80%,后面发现是可以多行输入的,猝。。。

public static void main(String[] args) {
	// TODO Auto-generated method stub
	// 定义辅助栈
	Stack<Character> stack = new Stack<>();
    
	Scanner scanner = new Scanner(System.in);
    // 需要处理为多行输入输出
	String string = scanner.nextLine();
	boolean flag = false;
	for(int i = 0; i < string.length(); i++) {
		if( string.charAt(i) == '(')
			stack.push(')');
		else if( string.charAt(i) == '[')
			stack.push(']');
		else if (string.charAt(i) == '{') {
			stack.push('}');
		}
		else if (string.charAt(i) == ' '){
			continue;
		}
		else if(stack.empty() || string.charAt(i) != stack.pop()) {
			flag = true;
			break;
		}	
	}
	scanner.close();
	if(!stack.empty() || flag)
		System.out.println("false");
	else
		System.out.println("true");
}
第二题 去掉重复的字符,只保留第一个

简单,使用HashMap搞定

package zr.xiaomi;
import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		String string = scanner.nextLine();
		Map<Character, Integer> map = new HashMap<Character, Integer>();
		
		for(int i = 0; i < string.length(); i++) {
			if(!map.containsKey(string.charAt(i))) {
				System.out.print(string.charAt(i));
				map.put(string.charAt(i), 1);
			}
		}
			
		scanner.close();
	}
}

其实使用HashSet就行了,可能是HashMap用得太多,一上来就想到HashMap

package zr.xiaomi;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Scanner;
import java.util.Set;

public class Main {

	public static void main(String[] args) {
		
		Scanner scanner = new Scanner(System.in);
		String string = scanner.nextLine();		
		Set<Character> set = new HashSet<>();
		
		for(int i = 0; i < string.length(); i++) {
			if(!set.contains(string.charAt(i))) {
				System.out.print(string.charAt(i));
				set.add(string.charAt(i));
			}
		}			
		scanner.close();	
	}
}

其实C++里面的list也可以搞定,更easy

int main(int argc, char* argv[])
{
    string s;
    getchar();
    getline(cin, s);
    list<char> mylist;

    for(int i = 0; i < s.size(); i++)
        mylist.push_back(s[i]);
	
    // 去重(从右边开始,保留第一个)
    mylist.unique();
    for(auto it = mylist.begin(); it != mylist.end(); it++){
        printf("%c", *it);
    }


    return 0;
}

希望雷神给个面试机会吧,许愿许愿~

posted @ 2020-09-15 21:21  程序员曾奈斯  阅读(156)  评论(0编辑  收藏  举报