博客
关于我
【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/

你可能感兴趣的文章
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>
mysql中还有窗口函数?这是什么东西?
查看>>
mysql中间件
查看>>
MYSQL中频繁的乱码问题终极解决
查看>>
MySQL为Null会导致5个问题,个个致命!
查看>>
MySQL为什么不建议使用delete删除数据?
查看>>
MySQL主从、环境搭建、主从配制
查看>>
Mysql主从不同步
查看>>
mysql主从同步及清除信息
查看>>