zoukankan      html  css  js  c++  java
  • LeetCode_242. Valid Anagram

    242. Valid Anagram

    Easy

    Given two strings s and , write a function to determine if t is an anagram of s.

    Example 1:

    Input: s = "anagram", t = "nagaram"
    Output: true
    

    Example 2:

    Input: s = "rat", t = "car"
    Output: false
    

    Note:
    You may assume the string contains only lowercase alphabets.

    Follow up:
    What if the inputs contain unicode characters? How would you adapt your solution to such case?

    package leetcode.easy;
    
    public class ValidAnagram {
    	public boolean isAnagram1(String s, String t) {
    		if (s.length() != t.length()) {
    			return false;
    		}
    		char[] str1 = s.toCharArray();
    		char[] str2 = t.toCharArray();
    		java.util.Arrays.sort(str1);
    		java.util.Arrays.sort(str2);
    		return java.util.Arrays.equals(str1, str2);
    	}
    
    	public boolean isAnagram21(String s, String t) {
    		if (s.length() != t.length()) {
    			return false;
    		}
    		int[] counter = new int[26];
    		for (int i = 0; i < s.length(); i++) {
    			counter[s.charAt(i) - 'a']++;
    			counter[t.charAt(i) - 'a']--;
    		}
    		for (int count : counter) {
    			if (count != 0) {
    				return false;
    			}
    		}
    		return true;
    	}
    
    	public boolean isAnagram22(String s, String t) {
    		if (s.length() != t.length()) {
    			return false;
    		}
    		int[] table = new int[26];
    		for (int i = 0; i < s.length(); i++) {
    			table[s.charAt(i) - 'a']++;
    		}
    		for (int i = 0; i < t.length(); i++) {
    			table[t.charAt(i) - 'a']--;
    			if (table[t.charAt(i) - 'a'] < 0) {
    				return false;
    			}
    		}
    		return true;
    	}
    
    	@org.junit.Test
    	public void test() {
    		String s1 = "anagram";
    		String t1 = "nagaram";
    		String s2 = "rat";
    		String t2 = "car";
    		System.out.println(isAnagram1(s1, t1));
    		System.out.println(isAnagram1(s2, t2));
    		System.out.println(isAnagram21(s1, t1));
    		System.out.println(isAnagram21(s2, t2));
    		System.out.println(isAnagram22(s1, t1));
    		System.out.println(isAnagram22(s2, t2));
    	}
    }
    
  • 相关阅读:
    iostream迭代器操作"txt文本文件"无法写入的思考
    Qt 相对路径 绝对路径
    "lambda"和“bind”的初步思考
    "partition"和“stable_partition”的思考
    "accumulate"的思考
    顺序容器“inset”的思考
    C++重载函数 const形参 引用指针 const_cast
    C++ 可变参数的函数
    JDK8流式处理常用例子
    JDK8时间新API
  • 原文地址:https://www.cnblogs.com/denggelin/p/11759101.html
Copyright © 2011-2022 走看看