博客
关于我
【Lintcode】773. Vlid Anagram
阅读量:191 次
发布时间:2019-02-28

本文共 987 字,大约阅读时间需要 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/

你可能感兴趣的文章
Neo私链
查看>>
NervanaGPU 项目使用教程
查看>>
Nerves 项目教程
查看>>
nessus快速安装使用指南(非常详细)零基础入门到精通,收藏这一篇就够了
查看>>
Nessus漏洞扫描教程之配置Nessus
查看>>
Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
查看>>
nested exception is org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML.
查看>>
nestesd exception is java .lang.NoSuchMethodError:com.goolge.common.collect
查看>>
nestJS学习
查看>>
net core 环境部署的坑
查看>>
NET Framework安装失败的麻烦
查看>>
Net 应用程序如何在32位操作系统下申请超过2G的内存
查看>>
Net.Framework概述
查看>>
NET3.0+中使软件发出声音[整理篇]<转>
查看>>
net::err_aborted 错误码 404
查看>>
NetApp凭借领先的混合云数据与服务把握数字化转型机遇
查看>>
NetAssist网络调试工具使用指南 (附NetAssist工具包)
查看>>
Netbeans 8.1启动参数配置
查看>>
NetBeans IDE8.0需要JDK1.7及以上版本
查看>>
NetBeans之JSP开发环境的搭建...
查看>>