• 字符串问题


    对于两棵彼此独立的二叉树A和B,请编写一个高效算法,检查A中是否存在一棵子树与B树的拓扑结构完全相同。

    给定两棵二叉树的头结点AB,请返回一个bool值,代表A中是否存在一棵同构于B的子树。

    核心代码:

    class TreeNode {
    	int val = 0;
    	TreeNode left = null;
    	TreeNode right = null;
    	public TreeNode(int val) {
    		this.val = val;
    	}
    }
    public class TreeSearch {
    	public void Search(TreeNode cur,StringBuffer s){
    		if(cur!=null){
    			s.append(cur.val+"");
    			Search(cur.left,s);
    			Search(cur.right,s);
    		}else
    			s.append(" ");
    	}
    	public boolean chkIdentical(TreeNode A, TreeNode B) {
            // write code heref
    		StringBuffer sb = new StringBuffer();
    		Search(A,sb);
    		StringBuffer sb2 = new StringBuffer();
    		Search(B,sb2);
    		if(sb.toString().contains(sb2.toString()))
    			return true;
    		else
    			return false;
        }
    }
    

      

    对于两个字符串A和B,如果A和B中出现的字符种类相同且每种字符出现的次数相同,则A和B互为变形词,请设计一个高效算法,检查两给定串是否互为变形词。

    给定两个字符串AB及他们的长度,请返回一个bool值,代表他们是否互为变形词。

    测试样例:
    "abc",3,"bca",3
    返回:true
    public boolean chkTransform(String A, int lena, String B, int lenb) {
    		Map<Character,Integer> map = new HashMap<Character,Integer>();
    		Map<Character,Integer> map2 = new HashMap<Character,Integer>();
    		for(int i = 0;i < lena; i++)
    			if(map.containsKey(A.charAt(i))){
    				map.put(A.charAt(i), map.get(A.charAt(i))+1);
    			}else
    				map.put(A.charAt(i),1);
    		
    		for(int i = 0;i < lenb; i++)
    			if(map2.containsKey(B.charAt(i))){
    				map2.put(B.charAt(i), map2.get(B.charAt(i))+1);
    			}else
    				map2.put(B.charAt(i),1);
    		
    		for(Map.Entry<Character, Integer> entry:map.entrySet()){
    			int value = entry.getValue();
    			char key = entry.getKey();
    			if(map2.keySet().contains(key)&&map2.get(key)!=value)
    				return false;
    		}
    		
    		
    		for(Map.Entry<Character, Integer> entry:map2.entrySet()){
    			int value = entry.getValue();
    			char key = entry.getKey();
    			if(map.keySet().contains(key)&&map.get(key)!=value)
    				return false;
    		}
    		
    		return true;
    	}
    

      

    对于一个字符串,请设计一个算法,只在字符串的单词间做逆序调整,也就是说,字符串由一些由空格分隔的部分组成,你需要将这些部分逆序。

    给定一个原字符串A和他的长度,请返回逆序后的字符串。

    测试样例:
    "dog loves pig",13
    返回:"pig loves dog"
    核心代码:
    		char[] str = A.toCharArray();
    		for(int i = 0;i <n/2; i++){
    			char temp = str[i];
    			str[i] = str[n-1-i];
    			str[n-1-i] = temp;
    		}
    		
    		for(int i = 0;i < n; i++){
    			if(i==0||str[i-1]==' '){
    				for(int j = i;j<=n;j++)
    					if(j==n||str[j]==' '){
    						for(int k = i;k < j;k++)
    							System.out.print(str[k]);
    						System.out.println();
    						for(int k = i;k<=(i+j-1)/2;k++){
    							char temp = str[k];
    							str[k] = str[j-k+i-1];
    							str[j-k+i-1] = temp;
    						}
    						for(int k = i;k < j;k++)
    							System.out.print(str[k]);
    						System.out.println(" ******"+i+" "+j);
    						
    						break;
    					}
    			}
    		}
    		StringBuffer sb = new StringBuffer();
    		for(int i = 0;i < n; i++)
    			sb.append(str[i]);
    		return sb.toString();
    

      

    对于一个字符串,请设计一个算法,判断其是否为一个合法的括号串。

    给定一个字符串A和它的长度n,请返回一个bool值代表它是否为一个合法的括号串。

    测试样例:
    "(()())",6
    返回:true
    测试样例:
    "()a()()",7
    返回:false
    测试样例:
    "()(()()",7
    返回:false
    核心代码:
       public boolean chkParenthesis(String A, int n) {
            // write code here
            int num = 0;
            for(int i = 0;i < A.length(); i++){
                if(A.charAt(i)=='(')
                    num++;
                else if(A.charAt(i)==')')
                    num--;
                if(num<0)
                    return false;
            }
            if(num!=0)
                return false;
            return true;
        }
    

      

    对于一个字符串,请设计一个算法,将字符串的长度为len的前缀平移到字符串的最后。

    给定一个字符串A和它的长度,同时给定len,请返回平移后的字符串。

    测试样例:
    "ABCDE",5,3
    返回:"DEABC"
        public static String stringTranslation(String A, int n, int len) {
            // write code here
        	char[] data = A.toCharArray();
        	for(int i = 0;i < len/2; i++){
        		char temp = data[i];
        		data[i] = data[len-1-i];
        		data[len-1-i] = temp;
        	}
    //    	System.out.println(len/2);
    //    	for(int i = 0;i < n; i++)
    //    		System.out.print(data[i]);
    //    	System.out.println();
        	
        	for(int i = len;i < len+(n-len)/2; i++){
        		char temp = data[i];
        		data[i] = data[n-(i-len)-1];
        		data[n-(i-len)-1] = temp;
        	}
        	
    //    	System.out.println(len+" "+(n)/2);
    //    	for(int i = 0;i < n; i++)
    //    		System.out.print(data[i]);
    //    	System.out.println();
        	
        	for(int i = 0;i < n/2; i++){
        		char temp = data[i];
        		data[i] = data[n-1-i];
        		data[n-1-i] = temp;
        	}
        	
    //    	for(int i = 0;i < n; i++)
    //    		System.out.print(data[i]);
    //    	System.out.println();
        	
        	StringBuffer sb = new StringBuffer();
        	for(int i = 0;i < n; i++)
        		sb.append(data[i]);
        	//System.out.println(sb.toString()+" "+n);
        	return sb.toString();
        }
    

      

    如果对于一个字符串A,将A的前面任意一部分挪到后边去形成的字符串称为A的旋转词。比如A="12345",A的旋转词有"12345","23451","34512","45123"和"51234"。对于两个字符串A和B,请判断A和B是否互为旋转词。

    给定两个字符串AB及他们的长度lenalenb,请返回一个bool值,代表他们是否互为旋转词。

    测试样例:
    "cdab",4,"abcd",4
    返回:true
    public class Rotation {
    	public boolean chkRotation(String A,int lena,String B,int lenb){
    		if(lena!=lenb)
    			return false;
    		String temp = A+A;
    		if(temp.contains(B))
    			return true;
    		else 
    			return false;
    	}
    }
    

      

    对于一个给定的字符串数组,请找到一种拼接顺序,使所有小字符串拼接成的大字符串是所有可能的拼接中字典序最小的。

    给定一个字符串数组strs,同时给定它的大小,请返回拼接成的串。

    测试样例:
    ["abc","de"],2
    "abcde"
    import java.util.*;
    
    public class Prior {
        public class MyComparator implements Comparator<String> {
            @Override
            public int compare(String a,String b){
                return (a+b).compareTo(b+a);
            }
        }
        public String findSmallest(String[] strs, int n) {
            // write code here
           if(strs==null || n==0){
               return "";
           }
           Arrays.sort(strs,new MyComparator());
           String res = "";
           for(int i=0;i<n;i++)
               res += strs[i];
           return res;
        }
    }
    

      

    对于一个字符串,请设计一个高效算法,找到字符串的最长无重复字符的子串长度。

    给定一个字符串A及它的长度n,请返回它的最长无重复字符子串长度。保证A中字符全部为小写英文字符,且长度小于等于500。

    测试样例:
    "aabcb",5
    返回:3
    import java.util.*;
    
    public class DistinctSubstring {
        public static int longestSubstring(String A, int n) {
            // write code here
        	Map<Character,Integer> posMap = new HashMap<Character,Integer>();
        	int[] strlen = new int[n]; 
        	int pre = 0;
        	strlen[0] = 1;
        	posMap.put(A.charAt(0), 0);
        	for(int i = 1;i < A.length(); i++){
        		int pos = posMap.get(A.charAt(i))==null?-1:(posMap.get(A.charAt(i))+1);
        		if(pos<pre)
        			strlen[i] = i-pre+1;
        		else
        			strlen[i] = i-pos+1;
        		//pre = strlen[i];
        		pre = i+1-strlen[i];
        		posMap.put(A.charAt(i), i);
        	}
        	int max = Integer.MIN_VALUE;
        	for(int i = 0;i < n; i++)
        		if(strlen[i]>max)
        			max = strlen[i];
        	return max;
        }
    }
    

      

  • 相关阅读:
    volumetric rendering ---fog/ light/cloud
    strand based hair rendering
    一个相当复杂的延迟管线
    wenti
    ubunt tmux X Error of failed request
    Python编程练习题
    ubuntu15.04 安装 pylab失败,先记下来,漫漫看
    翻译:打造基于Sublime Text 3的全能python开发环境
    关于web2py外网访问,图形界面不显示等问题的解决办法
    yii2中gii外网访问的配置方法
  • 原文地址:https://www.cnblogs.com/lxk2010012997/p/5495352.html
Copyright © 2020-2023  润新知