字符个数统计

来源:互联网 发布:知茵女装是品牌吗 编辑:程序博客网 时间:2024/06/05 06:19

编写一个函数,计算字符串中含有的不同字符的个数。字符在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()方法用来判断对象的相等性,如果两个对象不同的话,那么返回falseHashMap比较快,因为是使用唯一的键来获取对象   HashSet与Hashmap 存取速度基本一致,HashSet把HashMap进行了封装