首页 > 其他 > 详细

字符重排

时间:2020-11-22 09:36:58      阅读:29      评论:0      收藏:0      [点我收藏+]

此博客链接:https://www.cnblogs.com/ping2yingshi/p/14017921.html

字符重排

题目

题目链接:https://leetcode-cn.com/problems/check-permutation-lcci/

给定两个字符串 s1 和 s2,请编写一个程序,确定其中一个字符串的字符重新排列后,能否变成另一个字符串。

示例 1:

输入: s1 = "abc", s2 = "bca"
输出: true
示例 2:

输入: s1 = "abc", s2 = "bad"
输出: false
说明:

0 <= len(s1) <= 100
0 <= len(s2) <= 100

题解

题意:一个字符串的每个字母和另外一个字符串的每个字母一样。

思路:判断一个字符串中的每个字符是否在另外一个字符串中都存在,并且个数相等。

方法:

        1.先判断两个字符串长度是都相等,如果长度都不相等,那么其中一个字符串经过重排一定不肯能变成另外一个字符串。

        2.长度相等时,判断两个字符串中相同字母出现的次数是否相等,如果不相等,那么其中一个字符串经过重排一定不肯能变成另外一个字符串。

 代码

class Solution {
    public boolean CheckPermutation(String s1, String s2) {
        int len1=s1.length();
        int len2=s2.length();
        if(len1!=len2)
           return false;
        char emp []={a,b,c,d,e,f,g,h,i,g,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I,G,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z};

        //char datas[] = {‘a‘, ‘b‘, ‘c‘};
        //最多52个不同字母,26个大小写
        int result1[]=new int[52];
        int result2[]=new int[52];
        if(len1==len2){
            //先判断第一个字符串中每种字母包含多少个
            for(int i=0;i<52;i++)
            {
               for(int j=0;j<len1;j++)
               {
                  if(emp[i]==s1.charAt(j))
                      result1[i]++;
               }
            }
            for(int i=0;i<52;i++)
            {
                for(int j=0;j<len2;j++)
                {
                    if(emp[i]==s2.charAt(j))
                      result2[i]++;
                }
            }
        }
        for(int i=0;i<52;i++)
        {
            if(result1[i]!=result2[i])
                return false;
        }
      return true;
    }
}

 

字符重排

原文:https://www.cnblogs.com/ping2yingshi/p/14017921.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!