免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 16102 | 回复: 11
打印 上一主题 下一主题

如何判断ArrayList中的值是否全相等? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-05-17 18:27 |只看该作者 |倒序浏览
如题

例如:list.get() 出来的的值为:01,01,01 返回true
01,01,02返回false

论坛徽章:
0
2 [报告]
发表于 2007-05-17 20:43 |只看该作者

  1. String a = (String)list.get(0);
  2. for(int i=1; i < list.size(); i++)  {
  3.        String b =  (String)list.get(i);
  4.        if(!a.equals(b)) {
  5.            return false;
  6.        }
  7. }
  8. return true;
复制代码

谁有更好的方法?

论坛徽章:
0
3 [报告]
发表于 2007-05-18 14:42 |只看该作者
重复数据对编程来讲是资源浪费。可以用Set或者Map结构,完了以后看有几个key就可以了

论坛徽章:
0
4 [报告]
发表于 2007-05-18 20:18 |只看该作者
原帖由 perryhg 于 2007-5-18 14:42 发表
重复数据对编程来讲是资源浪费。可以用Set或者Map结构,完了以后看有几个key就可以了

赞一个

论坛徽章:
0
5 [报告]
发表于 2007-05-19 05:34 |只看该作者
原帖由 perryhg 于 2007-5-18 14:42 发表
重复数据对编程来讲是资源浪费。可以用Set或者Map结构,完了以后看有几个key就可以了


说得好,不过Java中已经不可避免的出现好多的资源浪费,或者是代码浪费。楼主的CAST就是一个典型的例子。

论坛徽章:
0
6 [报告]
发表于 2007-05-21 14:36 |只看该作者
从java 5开始(String)list.get()这种cast就已经不需要了。

论坛徽章:
0
7 [报告]
发表于 2007-05-22 17:51 |只看该作者
有时候使用List比Set要方便的多,避免重复的方法就是在放元素进去之前,判断是否已经存在相同元素

if  (!list.contains(e))
    list.add(e)

论坛徽章:
0
8 [报告]
发表于 2007-05-24 17:16 |只看该作者
equals就行

论坛徽章:
0
9 [报告]
发表于 2007-05-26 09:37 |只看该作者
重复数据对编程来讲是资源浪费。可以用Set或者Map结构,完了以后看有几个key就可以了


不明白 如果有个代码实例就好了

论坛徽章:
0
10 [报告]
发表于 2007-05-27 23:39 |只看该作者
原帖由 jakieyoung 于 2007-5-22 17:51 发表
有时候使用List比Set要方便的多,避免重复的方法就是在放元素进去之前,判断是否已经存在相同元素

if  (!list.contains(e))
    list.add(e)


contains(e)要看比较什么样的object,有的object需要重载hashcode()才行的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP