黑马程序员技术交流社区

标题: 关于集合的取数据条件问题 [打印本页]

作者: 黑马华    时间: 2013-4-30 13:38
标题: 关于集合的取数据条件问题
本帖最后由 黑马华 于 2013-4-30 20:14 编辑

下面的题能用正则表达式能按要求快速输出,但是我这种方法错在哪里?代码如下,谁能小小修改只输出123吗?
package com.itheima;

import java.util.HashSet;
import java.util.Set;

public class Dem {

        
        public static void main(String[] args) {
               
                Set<String>t = new HashSet<String>();
               
                t.add("abc");
                t.add("123");
                t.add("heima");
                t.add("a12d");
               
                for(String str: t){
                        //char []a = str.toCharArray();
                        
                        for(int i = 0;i<str.length(); i++){
                                if(str.charAt(i)<0||str.charAt(i)>9) break;
                                System.out.println(str);
                        }
                                
                }
                        
               
        }

}
作者: harborbest    时间: 2013-4-30 13:43
char charAt(int index)
          返回指定索引处的 char 值。 多看api
作者: 丘凤光    时间: 2013-4-30 13:48
本帖最后由 丘凤光 于 2013-4-30 13:49 编辑

这个for(String str: t){}循环已经是将集合中的元素一个个取出,
你在增强型for循环里边在定义一个for循环,遍历的是已经取出的每个字符串中的字符,这步已经多余了
这与你要取的集合中的纯数字元素不符合啊

如果你是要把123
和a12b中的12
都取出来的话,用你这种思想就是对的
作者: 黑马华    时间: 2013-4-30 13:51
丘凤光 发表于 2013-4-30 13:48
这个for(String str: t){}循环已经是将集合中的元素一个个取出,
你在增强型for循环里边在定义一个for循环 ...

第二个for是过滤条件啊
作者: 丘凤光    时间: 2013-4-30 13:58
黑马华 发表于 2013-4-30 13:51
第二个for是过滤条件啊

哦,是,我没看清楚;P
一个个字符过滤效率有点低哦
作者: 黑马华    时间: 2013-4-30 14:04
丘凤光 发表于 2013-4-30 13:58
哦,是,我没看清楚
一个个字符过滤效率有点低哦

这个是啊,正则没看毕老师的最后一节课程,所以玩玩这个试试,这个怎么改?
作者: 丘凤光    时间: 2013-4-30 14:09
本帖最后由 丘凤光 于 2013-4-30 14:13 编辑

我给你找到原因了
  1. package cn.qiu.day5;

  2. /**
  3. * 需求:假设有一个集合,里面装的是字符串,但有的字符串是纯数字,我想把它找出来并打印怎么办?例如下面就找个123这个并打印
  4. */
  5. import java.util.HashSet;
  6. import java.util.Set;

  7. public class Jihe {
  8.     public static void main(String[] args) {
  9.         Set<String>t = new HashSet<String>();        
  10.         t.add("abc");
  11.         t.add("123");
  12.         t.add("heima");
  13.         t.add("a12d");
  14.       //设定匹配规则
  15.         String regex="[\\d]+";
  16.       //增强for循环
  17.         for(String str:t){
  18.                 //如果和规则匹配就是数字,否者不是
  19.             /*if(str.matches(regex)){
  20.              System.out.println(str);
  21.             }else{
  22.                     System.out.println(str+"不是纯数字");
  23.             }*/
  24.                  for(int i = 0;i<str.length(); i++){
  25.                  if(str.charAt(i)<'0'||str.charAt(i)>'9') break;
  26.                          System.out.println(str);
  27.              }               
  28.         }
  29.     }
  30. }
复制代码
你忽略了一点,str.charAt(i)<'0'||str.charAt(i)>'9'这才是正确的。原因:比较的是ascii码,0和9的ascii码不是0和9

按你这种方法比如是"123"就会打印三次。也会和你的要求不符。增加一两句代码就好了,那个很简单,你能解决的啦

——

作者: wudongzhe    时间: 2013-4-30 14:15
把增强for循环 改成这样就可以了

                for (String str : t) {
                        if (str.matches("[0-9]{1,10}")) {//如果是 0-9的数字就输出
                                System.out.println(str);
                        }
                }
作者: 一直在路上    时间: 2013-4-30 14:30
import java.util.HashSet;
import java.util.Set;


public class Test {
          public static void main(String[] args) {
         
          Set<String>t = new HashSet<String>();
         
          t.add("abc");
          t.add("123");
          t.add("heima");
          t.add("a12d");
         
          for(String str: t){
                  
                  for(int i = 0;i<str.length(); i++){
                          if(!Character.isDigit(str.charAt(i))){
                                  break;
                          }
                          System.out.println(str);
                  }                 
          }
          }
}
最简单的就是调用Character.isDigit(str.charAt(i))方法,这样可以直接判断
作者: 一直在路上    时间: 2013-4-30 14:35
你想用的方法时错误的str.charAt(i)<0||str.charAt(i)得到的是char类型的,char类型还要转化为int类型,但是char转化为int的时候还是有差别的,char ='1',转化为int就是49,所以没办法通过>0和<9来判断是否为数字了




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2