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

你可能感兴趣的文章
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7性能调优my.ini
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqlreport分析工具详解
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>