字符个数统计

编写一个函数,计算字符串中含有的不同字符的个数。字符在ACSII码范围内(0~127)。不在范围内的不作统计。


import java.util.Scanner;
public class P8 {
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  Scanner in=new Scanner(System.in);
  while(in.hasNext()){
   String s=in.next();
   int[] array=new int[128];
   int c=0;
   for(int i=0;i<s.length();i++){
    char a=s.charAt(i);
    array[a]++;
    if(a >= 0 &&a <= 127&&array[a]==1){
     c++;
    }
    
   }
   System.out.print(c);
   }
 }
}
另一种方法:用hashset

import java.util.Scanner;
import java.util.HashSet;
public class p7 {
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  Scanner in=new Scanner(System.in);
  while(in.hasNext()){
   String s=in.next();
   char ch[]=s.toCharArray();
   HashSet<Character> set=new HashSet<Character>();
   for(int i=0;i<ch.length;i++){
       set.add(ch[i]) ;      
   }
   System.out.println(set.size());
   }
  }

HashSet和HashMap的区别

*HashMap*   *HashSet*
HashMap实现了Map接口   HashSet实现了Set接口
HashMap储存键值对   HashSet仅仅存储对象
使用put()方法将元素放入map中   使用add()方法将元素放入set中
HashMap中使用键对象来计算hashcode值   HashSet使用成员对象来计算hashcode值,对于两个对象来说hashcode可能相同,所以equals()方法用来判断对象的相等性,如果两个对象不同的话,那么返回false
HashMap比较快,因为是使用唯一的键来获取对象   HashSet与Hashmap 存取速度基本一致,HashSet把HashMap进行了封装



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值