一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 358|回复: 1
收起左侧

[算法题] Valid Anagram 编码问题

[复制链接] |试试Instant~ |关注本帖
111180611 发表于 2016-2-2 15:45:07 | 显示全部楼层 |阅读模式

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
leetcode 242 valid anagram
如果字符串编码是ASCII码,我们可以用以下方法
  1. public class Solution {
  2.     /**
  3.      * @param s: The first string
  4.      * @param b: The second string
  5.      * [url=home.php?mod=space&uid=160137]@return[/url] true or false
  6.      */
  7.     public boolean anagram(String s, String t) {
  8.         if (s.length() != t.length()) {
  9.            return false;
  10.         }
  11.         
  12.         int[] count = new int[256];
  13.         for (int i = 0; i < s.length(); i++) {
  14.             count[(int) s.charAt(i)]++;
  15.         }
  16.         for (int i = 0; i < t.length(); i++) {
  17.             count[(int) t.charAt(i)]--;
  18.             if (count[(int) t.charAt(i)] < 0) {
  19.                 return false;
  20.             }
  21.         }
  22.         return true;
  23.     }
  24. }
复制代码
follow up是如果是unicode怎么办 有办法改吗?
或者说如果是Unicode这个方法就不能用了?(排除初始化一个超大的数组)
希望大家对ASCII Unicode 积极发表自己的见解

yucheyang2 发表于 2016-2-2 15:54:55 | 显示全部楼层
HashMap<Character, Integer>啊,Java默认Unicode,每遇到一个char,加入HashMap。扫第二个字符串的时候count--,减到0就删除。多加点判断就行了。
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-3 03:57

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表