博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Lintcode】773. Vlid Anagram
阅读量:188 次
发布时间:2019-02-28

本文共 993 字,大约阅读时间需要 3 分钟。

题目地址:

判断两个字符串是否是anagram。anagram的意思是含字符相同并且每个字符出现次数也相同。

可以用一个数组记录第一个字符串每个字符出现次数,然后遍历第二个字符串的时候遇到一个字符就将其对应的次数减一。如果中途遇到 0 0 0减一的情况就返回false。代码如下:

public class Solution {
/** * @param s: string s * @param t: string t * @return: Given two strings s and t, write a function to determine if t is an anagram of s. */ public boolean isAnagram(String s, String t) {
// write your code here // 如果长度不等直接返回false if (s.length() != t.length()) {
return false; } int len = s.length(); int[] count = new int[256]; for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i); count[c]++; } for (int i = 0; i < t.length(); i++) {
char c = t.charAt(i); if (count[c] == 0) {
return false; } count[c]--; } return true; }}

时间复杂度 O ( n ) O(n) O(n),空间 O ( 1 ) O(1) O(1)

转载地址:http://bqds.baihongyu.com/

你可能感兴趣的文章