zoukankan      html  css  js  c++  java
  • [lintcode]638.Strings Homomorphism

    Given two strings s and t, determine if they are isomorphic.

    Two strings are isomorphic if the characters in s can be replaced to get t.

    All occurrences of a character must be replaced with another character while preserving the order of characters. No two characters may map to the same character but a character may map to itself.

    注意事项:

    You may assume both s and t have the same length.

    样例:

    Given s = "egg", t = "add", return true.

    Given s = "foo", t = "bar", return false.

    Given s = "paper", t = "title", return true.

    解题思路:

    一开始我一直钻到牛角尖里面,一直想着字母一一对应的替换。

    最近在看算法,这道题应该算是一道很简单的哈希表。

    其实就是要记录每一个字母出现的次数和它对应的位置。

    以egg和add为例:

    'g'和'd'出现了两次,就是[1,2,2],[1,2,2]

    'foo':[1,2,2];bar:[1,1,1]

    然后我又再一次陷入了这个存数组的漩涡里面。。。我试图搞一个数组,按照index把出现次数存进去。。。

    后来在网上搜索了一下,其实只要按照string的顺序(位置对应),读出每一个char的出现次数(次数对应)就可以以了。

     1 class Solution {
     2 public:
     3     /*
     4      * @param s: a string
     5      * @param t: a string
     6      * @return: true if the characters in s can be replaced to get t or false
     7      */
     8     bool isIsomorphic(string s, string t) {
     9         // write your code here
    10        map <char, int> word1,word2; //<key:char类型,value:int类型>
    11        for(int i = 0; i<s.size(); i++){
    12            word1[s[i]]++;
    13            word2[t[i]]++;
    14        }
    15        for(int i = 0; i< s.size(); i++){
    16            if(word1[s[i]]!=word2[t[i]]){
    17                return false;
    18            }
    19        }
    20        return true;
    21     }
    22 };
  • 相关阅读:
    服务器性能监控工具(MQTT协议)
    最近很烦
    开关柜无线测温数据中心后台
    合宙DTU数据流模板modbus lua脚本生成器
    4G无线-潮信报警器
    4G无线-sever酱报警器
    url_for函数——快速寻找url
    完整版模板项目实战【实战演练】
    忽略这1点,代码写的再好也没用
    不会汇报工作,工作做得再好也白瞎
  • 原文地址:https://www.cnblogs.com/hopping/p/7724342.html
Copyright © 2011-2022 走看看