Java编程:合并字符串并排序:判断丑陋数:找到最多含有n个不同字符的子串的最长长度

本文介绍了几种实用的字符串处理算法,包括合并并排序两个字符串中的唯一字符、寻找包含特定数量不同字符的最长子串,以及判断一个数是否为丑陋数(质因数仅为2、3、5)。通过具体的Java代码示例,展示了这些算法的设计思路和实现细节。
[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. package com.baiyi;  
  2. import java.util.*;  
  3. public class TestUtils   
  4. {  
  5.       
  6.     /** 
  7.      * 第一题:合并字符串并排序 
  8.      * 
  9.      * @param str1 字符串 
  10.      * @param str2 字符串 
  11.      * @return 字符串 
  12.      */  
  13.     public static String comSort(String str1, String str2) throws Exception   
  14.     {  
  15.         // 请在此添加代码  
  16.         int[] a=new int[26];  
  17.         for(int i=0;i<26;i++)  
  18.         {  
  19.             a[i]=0;  
  20.         }  
  21.         for(int i=0;i<str1.length();i++)  
  22.         {  
  23.             a[str1.charAt(i)-'a']=1;  
  24.         }  
  25.         for(int i=0;i<str2.length();i++)  
  26.         {  
  27.             a[str2.charAt(i)-'a']=1;  
  28.         }  
  29.         String str="";  
  30.         int sum=0;  
  31.         for(int i=0;i<26;i++)  
  32.         {  
  33.             if(a[i]!=0)  
  34.                 sum++;  
  35.         }  
  36.         char[] b=new char[sum];  
  37.         int j=0;  
  38.         char i=0;  
  39.         for(;i<26;i++)  
  40.         {  
  41.             if(a[i]!=0)  
  42.             {  
  43.                 b[j]=(char) ('a'+i);  
  44.                 j++;  
  45.             }  
  46.         }  
  47.         str =String.valueOf(b);  
  48.         return str;  
  49.     }  
  50.       
  51.     /* 
  52.     第二题:找到最多含有n个不同字符的子串的最长长度 
  53.     */  
  54.     public static int change(String s,int n)  
  55.     {  
  56.         LinkedList<Character> list = new LinkedList<Character>();  
  57.         int sum=1,max=0;  
  58.         list.add(s.charAt(0));  
  59.         for(int i=1;i<s.length();i++)  
  60.         {  
  61.             System.out.println(list.toString());  
  62.             if(list.contains(s.charAt(i)))  
  63.             {  
  64.                 list.add(s.charAt(i));  
  65.             }  
  66.             else  
  67.             {  
  68.                 if(sum==n)  
  69.                 {  
  70.                     if(list.size()>max)  
  71.                         max=list.size();  
  72.                     list.removeFirst();  
  73.                     list.add(s.charAt(i));  
  74.                       
  75.                 }  
  76.                 else  
  77.                 {  
  78.                     list.add(s.charAt(i));  
  79.                     sum++;  
  80.                 }  
  81.             }  
  82.   
  83.         }  
  84.         return max;  
  85.     }  
  86.     /* 
  87.     第三题:判断丑陋数,质因数只有2,3,5的数是丑陋数 
  88.     */  
  89.     public static boolean isUgly(int num)   
  90.     {  
  91.         if (num <= 0)  
  92.             return 0;  
  93.         while (num % 2 == 0)   
  94.             num /= 2;  
  95.         while (num % 3 == 0)  
  96.             num /= 3;  
  97.         while (num % 5 == 0)  
  98.             num /= 5;  
  99.         return num==1?1:0;  
  100.     }     
  101. }  
  102. }
输出字符串中段+统计 描述 有给定字符串:“优美胜于丑陋,明了胜于晦涩,简洁胜于复杂,复杂胜于凌乱,扁平胜于嵌套,间隔胜于紧凑。”‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬ 用户输入两个整M和N(M<N),求该字符串中序号第M到第N个字符(注意:要求包含N)组成的子串统计子串中“于”的个。‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬ 分两行输出该字串和其中"于"的个。‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬ 输入输出格式见下面示例。‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬ 输入输出示例 输入 输出 示例 1 0 6 优美胜于丑陋, 1
03-22
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值