题解 | #字符个数统计#

字符个数统计

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

题意整理。

  • 输入一行没有空格的字符串。
  • 统计字符串中不同字符的种数(要求ASCII码在0-127范围内)。

方法一(set)

1.解题思路

  • 新建一个set,用于记录不同字符的种数。
  • 然后遍历整个字符串,将范围内的字符加入到set。由于set中不允许出现重复的元素,所以set的大小即是不同字符的种数。

动图展示: alt

2.代码实现

import java.util.Scanner;
import java.util.HashSet;

public class Main{
    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        String s=sc.nextLine();
        //用于记录不同字符的种数
        HashSet<Character> set=new HashSet<Character>();
        //遍历所有字符
        for(int i=0;i<s.length();i++){
            char c=s.charAt(i);
            //如果在范围内,则加入到set
            if(c>=0&&c<=127){
                set.add(s.charAt(i));
            }
        }
        //set的大小即是不同字符的种数
        System.out.println(set.size());
    }
}

3.复杂度分析

  • 时间复杂度:假设字符串长度为n,需要遍历字符串中每一个字符,所以时间复杂度为O(n)O(n)
  • 空间复杂度:不同字符种数最多为128种,需要set的大小为常数级别,所以空间复杂度为O(1)O(1)

方法二(位图)

1.解题思路

  • 新建位图,用于后续将字符串映射到位图。
  • 然后遍历整个字符串,将范围内的字符set到位图。然后利用cardinality统计不同字符的种数。

与方法一相比,最多只需128位的空间,大大地降低了空间复杂度。

2.代码实现

import java.util.Scanner;
import java.util.BitSet;

public class Main{
    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        String s=sc.nextLine();
        //新建位图
        BitSet bit=new BitSet();
        for(int i=0;i<s.length();i++){
            char c=s.charAt(i);
            //将ASCII码在0-127范围内的字符加入到位图
            if(c>=0&&c<=127){
                bit.set(c);
            }
        }
        //输出统计的字符种数
        System.out.println(bit.cardinality());
    }
}

3.复杂度分析

  • 时间复杂度:假设字符串长度为n,需要遍历字符串中每一个字符,所以时间复杂度为O(n)O(n)
  • 空间复杂度:需要额外常数级别的空间,所以空间复杂度为O(1)O(1)
xqxls的题解 文章被收录于专栏

牛客题解

全部评论

相关推荐

06-13 17:33
门头沟学院 Java
顺序不记了,大致顺序是这样的,有的相同知识点写分开了1.基本数据类型2.基本数据类型和包装类型的区别3.==和equals区别4.ArrayList与LinkedList区别5.hashmap底层原理,put操作时会发生什么6.说出几种树型数据结构7.B树和B+树区别8.jvm加载类机制9.线程池核心参数10.创建线程池的几种方式11.callable与runnable区别12.线程池怎么回收线程13.redis三剑客14.布隆过滤器原理,不要背八股,说说真正使用时遇到了问题没有(我说没有,不知道该怎么回答了)15.堆的内存结构16.自己在写项目时有没有遇见过oom,如何处理,不要背八股,根据真实经验,我说不会17.redis死锁怎么办,watchdog机制如何发现是否锁过期18.如何避免redis红锁19.一个表性别与年龄如何加索引20.自己的项目的QPS怎么测的,有没有真正遇到大数量表21.说一说泛型22.springboot自动装配原理23.springmvc与springboot区别24.aop使用过嘛?动态代理与静态代理区别25.spring循环依赖怎么解决26.你说用过es,es如何分片,怎么存的数据,1000万条数据怎么写入库中27.你说用limit,那么在数据量大之后,如何优化28.rabbitmq如何批次发送,批量读取,答了延迟队列和线程池,都不对29.计网知不知道smtp协议,不知道写了对不对,完全听懵了30.springcloud知道嘛?只是了解反问1.做什么的?短信服务,信息量能到千万级2.对我的建议,基础不错,但是不要只背八股,多去实际开发中理解。面试官人不错,虽然没露脸,但是中间会引导我回答问题,不会的也只是说对我要求没那么高。面完问我在济宁生活有没有困难,最快什么时候到,让人事给我聊薪资了。下午人事打电话,问我27届的会不会跑路,还在想办法如何使我不跑路,不想扣我薪资等。之后我再联系吧,还挺想去的😭,我真不跑路哥😢附一张河科大幽默大专图,科大就是大专罢了
查看30道真题和解析
点赞 评论 收藏
分享
06-26 15:33
青岛工学院 Java
积极的秋田犬要冲国企:他现在邀请我明天面试
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务