LeetCode_242. Valid Anagram
242. Valid Anagram
Given two strings s and t , 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));
	}
}
LeetCode_242. Valid Anagram的更多相关文章
- 【09_242】Valid Anagram
		Valid Anagram My Submissions Question Total Accepted: 43694 Total Submissions: 111615 Difficulty: Ea ... 
- leetcode面试准备:Valid Anagram
		leetcode面试准备:Valid Anagram 1 题目 Given two strings s and t, write a function to determine if t is an ... 
- 242. Valid Anagram(C++)
		242. Valid Anagram Given two strings s and t, write a function to determine if t is an anagram of s. ... 
- 22. leetcode 242. Valid Anagram(由颠倒字母顺序而构成的字)
		22. 242. Valid Anagram(由颠倒字母顺序而构成的字) Given two strings s and t, write a function to determine if t i ... 
- 【LeetCode】242. Valid Anagram (2 solutions)
		Valid Anagram Given two strings s and t, write a function to determine if t is an anagram of s. For ... 
- [leetcode]242. Valid Anagram验证变位词
		Given two strings s and t , write a function to determine if t is an anagram of s. Example 1: Input: ... 
- leetcdoe Valid Anagram
		题目连接 https://leetcode.com/problems/valid-anagram/ Valid Anagram Description Given two strings s and ... 
- LN : leetcode 242 Valid Anagram
		lc 242 Valid Anagram 242 Valid Anagram Given two strings s and t, write a function to determine if t ... 
- LeetCode 242. 有效的字母异位词(Valid Anagram)
		242. 有效的字母异位词 LeetCode242. Valid Anagram 题目描述 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的一个字母异位词. 示例 1: 输入: s ... 
随机推荐
- Vue 项目环境搭建
			Vue项目环境搭建 ''' 1) 安装node 官网下载安装包,傻瓜式安装:https://nodejs.org/zh-cn/ 2) 换源安装cnpm >: npm install -g cnp ... 
- work,工作模式
			work,工作模式 一个消息只能被一个消费者获取 工作模式就是simple模式多了几个消费者,其他一样 来自为知笔记(Wiz) 
- PostgreSQL 11 新特性之覆盖索引(Covering Index)(转载)
			通常来说,索引可以用于提高查询的速度.通过索引,可以快速访问表中的指定数据,避免了表上的扫描.有时候,索引不仅仅能够用于定位表中的数据.某些查询可能只需要访问索引的数据,就能够获取所需要的结果,而不需 ... 
- Greenplum failed segment的恢复方法--primary与mirror都可修复
			当在使用greenplum过程中有不当的操作时,可能会出现segment节点宕掉的情况(比如在greenplum运行的过程中停掉其中几台segment节点的服务器),通过下面的方法可以恢复segmen ... 
- 使用echarts生成海友网企业全国分布地图
			不分类别的效果 不同分类的分布效果图 从海友网获取各个企业名单保存进mysql cmfishhelper.py 从下列网址得到各个企业名片的网址保存进表cmfish cds = get_cds() h ... 
- bilibili 高并发实时弹幕系统的实现
			高并发实时弹幕是一种互动的体验.对于互动来说,考虑最多的地方就是:高稳定性.高可用性以及低延迟这三个方面. 高稳定性,为了保证互动的实时性,所以要求连接状态稳定: 高可用性,相当于提供一种备用方案,比 ... 
- /etc/shells
			List of acceptable shells for chpass(1). Ftpd will not allow users to connect who are not using one ... 
- Solution
			小五的游戏 小碎骨的子集 芙兰朵露的框框 ⑨要求和 
- 【微信小程序】如何获取用户绑定手机号
			用户调用wx.login()方法,获取登录用户凭证code wx.login({ success: function(res) { console.log('loginCode', res.code) ... 
- (20)打鸡儿教你Vue.js
			vue-cli 快速创建工程,工程化项目目录 npm uninstall -g vue-cli npm install -g @vue/cli https://www.bootcdn.cn/ http ... 
