题解 | #字符个数统计#

字符个数统计

http://www.nowcoder.com/practice/eb94f6a5b2ba49c6ac72d40b5ce95f50

  1. 统计个数就不需要map,set就可以
  2. toCharArray() 方法将字符串转换为字符数组。
  3. 增强for循环
    图片说明
import java.util.*;
import java.lang.*;

public class Main { 
    public static void main (String[] args) {

        Scanner sc = new Scanner(System.in);

        String str = sc.nextLine();
        Set<Character> set = new HashSet<>();

        for (char ch : str.toCharArray()) {
            if (ch >= 0 && ch < 128) {
                set.add(ch);
            }
        }

        System.out.println(set.size());
    }
}

进一步的,使用BitSet。凡是涉及到去重统计都可以用位图实现。因为每一个不同的数据只需要用二进制的一位存储即可,大大减小了统计所使用的存储空间。注意返回BitSet容量的方法是cardinality(),StringBuilder容量是capacity()。

import java.util.*;
import java.lang.*;

public class Main { 
    public static void main (String[] args) {

        Scanner sc = new Scanner(System.in);

        String str = sc.nextLine();
        BitSet bs = new BitSet(128);

        for (char ch : str.toCharArray()) {
            if (!bs.get(ch)) {
                bs.set(ch);
            }
        }

        System.out.println(bs.cardinality());
    }
}
全部评论

相关推荐

努力学习的小绵羊:我反倒觉得这种挺好的,给不到我想要的就别浪费大家时间了
点赞 评论 收藏
分享
11-30 11:07
河南大学 Java
宇宙厂 测开 n*15
丘丘给个offer:有后选后
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务