做了个关于字符串处理的题

闲着无聊,做题玩

 

//1.将字符串”One world one Dream”进行以下处理
//1) 将每个单词第一个字母转换为大写,然后输出
//2) 将1)得到的结果过滤重复的单词
//3) 将2)得到的结果去掉所有的空格,然后将字符串倒置
//4) 将3) 得到的结果统计各个字符的个数

 

 

实现

  1. package com.sr178.test;
  2. import java.util.HashMap;
  3. import java.util.HashSet;
  4. import java.util.Iterator;
  5. public class StringTest {
  6.  /**
  7.   * @param args
  8.   */
  9.  public static void main(String[] args) {
  10.   // TODO Auto-generated method stub
  11.           String str ="One world one Dream";
  12.           //第一个字母变成大写
  13.           String q1=Q1(str);
  14.           System.out.println("第1题答案:"+q1);
  15.           //第二个过滤重复单词
  16.           String q2=Q2(q1);
  17.           System.out.println("第2题答案:"+q2);
  18.           
  19.           //第三个去掉空格 倒置
  20.           String q3=Q3(q2);
  21.           System.out.println("第3题答案:"+q3);
  22.           
  23.           //第四个 答案
  24.           Q4(q3);
  25.  }
  26.    public static String Q1(String str){
  27.     String[] arr = str.split("//s");
  28.     String str2=" ";
  29.        for(int i= 0;i<arr.length;i++ ){
  30.         arr[i]=arr[i].replaceFirst("([a-z]|[A-Z])",arr[i].substring(01).toUpperCase());
  31.         str2 +=" "+ arr[i];
  32.        }
  33.        return str2.trim();
  34.    }
  35.    
  36.    public static String Q2(String str){
  37.     String str2="";
  38.     String[] arr = str.split("//s");
  39.     HashSet hs = new HashSet();
  40.     for(int i= 0;i<arr.length;i++ ){
  41.          if(!(hs.add(arr[i]))){
  42.           hs.remove(arr[i]);
  43.          }
  44.         }
  45.      for(Object ss:hs){
  46.       str2 +=" "+(String)ss;
  47.      }
  48.     return str2;
  49.    }
  50.    public static String Q3(String str){
  51.     String str2="";
  52.     String[] arr = str.split("//s");
  53.     for(int i=0;i<arr.length;i++){
  54.      str2 += arr[i];
  55.     }
  56.     StringBuffer sb= new StringBuffer(str2);
  57.     str2=sb.reverse().toString();
  58.     return str2;
  59.    }
  60.    public static void Q4(String str){
  61.     char[] temp = str.toCharArray();
  62.     HashMap hm = new HashMap();
  63.     for(int i=0;i<temp.length;i++){
  64.      
  65.     if(!hm.containsKey(temp[i])){
  66.      hm.put(temp[i], new Integer(1));
  67.     }
  68.     else{
  69.      Integer in= (Integer)hm.get(temp[i])+1;
  70.      hm.put(temp[i], in);
  71.     }
  72.      
  73.     }
  74.     Iterator it = hm.keySet().iterator();
  75.     while(it.hasNext()){
  76.      Object o=it.next();
  77.      System.out.println("字符"+o.toString()+"的出现次数是"+hm.get(o));
  78.      }
  79.    }
  80. }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值