删掉字符串中出现次数最少的字符

输入一段字符串,字符串中只包含大小写字母。要求完成函数删除给定字符串中出现次数最少的字符。 输出删除完的字符串。如果有多个出现次数一样的字符,都为最少时,一并删除。例如:输入:abbccd,输出为bbcc。

有两种思路:

一、利用HashMap

1、首先把字符串转换为字符串数组,然后遍历字符串数组,存放到Map中,首先判断hashmap中这个字母是否存在,如果存在value+1,如果不存在就是存入key,value=1。

2、//取出value集合
Collection<Integer> col = map.values();
//取出最小值(也就是出现最少的次数)

int charMinIndex = Collections.min(col);

3、如果次数最小的字符有多个,一同存放到一个字符数组brr,最后对arr - brr (若循环遍历中arr中元素有brr元素出现,直接把arr[i]='#')  , 然后在最后遍历arr输出时,输出字符不等于'#'就可以 ;

代码如下:

package train;
/**
 * 刪除一個字符串中總數最小的字符,最後輸出剩下的字符串
 * @author LarryLao
 */


import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;


public class DelMinCntNumChr {
    public static void main(String[] args) {
   
    Scanner sc = new Scanner(System.in);
    System.out.println("請輸入一長串字符串");
    String str = sc.nextLine();
    Map<Character , Integer> map = new HashMap<Character,Integer>();
    ArrayList<Character>  strArray = new ArrayList<Character> (); 
        char[] chr = str.toCharArray();
        for(char c : chr){
        if(map.get(c) == null){
        map.put(c, 1);
        }else{
        Integer in = map.get(c);
        in ++ ;
        map.put(c, in);
        }
        }
        
        
        //取出value集合
        Collection<Integer> col = map.values();
  
        //取出最小值(也就是出现最少的次数)
        int charMinIndex = Collections.min(col);
                Character minChr = null ;
        for(Map.Entry<Character, Integer> entry : map.entrySet())
         {
            if(entry.getValue().equals(charMinIndex))
            {
                minChr =  entry.getKey();
              
                strArray.add(minChr);
                
             }
         }
        //查找兩個字符數組中的差值
         for(int i = 0; i<chr.length;i++)
        for(int j=0;j<strArray.size();j++){
         
        if(chr[i]==strArray.get(j).charValue()){
               chr[i]='#';
        }
         
        }
         //輸出未被置為'#'的字符
         for(int i=0; i< chr.length;i++){
        if(chr[i]!='#')
           System.out.print(chr[i]);
         }
         
         
        
     }
}

二、直接利用数组下标(参考的)

import java.util.Scanner;
public class DelMinCntNumChr {
    public static void main(String[] args) {
        Scanner sc = new Scanner("Aaddbcvvv");
        while (sc.hasNext()) {
            String line = sc.nextLine();
            int len = line.length();


            // 统计每个字符出现的次数
            int[] arr = new int[52];
            for(int i = 0; i < len; i++) {
                char c = line.charAt(i);
                int index = 0;
                if(c >= 'a' && c <= 'z') {
                    index = c - 'a' + 26;
                    arr[index]++;
                }else if(c >= 'A' && c <= 'Z'){
                    index = c - 'A';
                    arr[index]++;
                }
            }


            // 找到出现次数的最小值
            int min = Integer.MAX_VALUE;
            for(int i = 0; i < arr.length; i++) {
                if(arr[i] > 0) {
                    min = Math.min(min, arr[i]);
                }
            }


            // 如果出现次数大于最小值,就加到sb中
            StringBuilder sb = new StringBuilder();
            for(int i = 0; i < len; i++) {
                char c = line.charAt(i);
                if(c >= 'a' && c <= 'z' && arr[c-'a'+26] > min) {
                    sb.append(c);
                }else if(c >= 'A' && c <= 'Z' && arr[c-'A'] > min){
                    sb.append(c);
                }
            }
            System.out.println(sb.toString());


        }
        sc.close();
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值