java遍历list集合问题

2025-01-31 10:06:09
推荐回答(5个)
回答1:

package demo;
import java.util.*;
public class Listl {
public static void main(String args[]){
List list = new ArrayList(); // 此处换成你自己的List即可
list.add(1);
list.add(2);
list.add(5);
list.add(6);
list.add(7);
list.add(8);
list.add(9);
Random r = new Random();
Integer a =r.nextInt(13);
Listl ll = new Listl();
while(ll.isExist(a,list)){
a=a-1;
continue;
}
System.out.println(a);
System.out.println(list);
}
public boolean isExist(Integer i,List list){
for(Integer j:list){
if(i==j) return true;
}
return false;
}
}
欢迎追问

回答2:

import
java.util.ArrayList;

import
java.util.List;

import
java.util.Random;

public
class ListTest {

publicstaticvoid main(String[] args) {

List list =
new ArrayList();

list.add(1);
list.add(31);
list.add(5);
list.add(6);
list.add(7);
list.add(9);
list.add(10);

Integer a =
new Random().nextInt(50);

String str = list.toString();
a = 7;
//force a = 2,7,9 to test

while(true){

if(str.indexOf(a.toString()) == -1){

System.
out.println(a.toString());

break;

}
else{

a = a -1;
}
}

}

}

回答3:

提供思路 需要的话提供代码
List遍历就就俩方法
效率最高的是迭代器吧 然后是临时变量把list当数组看
实现的方法没什么问题 优化的话就作一个二分查找吧
List既然是从数据库里面取出来的 可以在做查询的时候使用排序
然后在找list元素的时候 用二分查找 效率应该会高一点

回答4:

直接用一个while循环搞定,下面是代码,仅供参考

package com.service.test;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;

public class TestClient {
public static void main(String[] args) throws Exception {
Integer[] intes = { 1, 3, 4, 6, 8, 10, 7, 9, 5 };

List list = new ArrayList();
for (Integer a : intes) {
list.add(a);
}
checkOutPut(list);

}
private static void checkOutPut(List list) {
Random r = new Random();
Integer temp = r.nextInt(10);

if (list != null) {
while (list.contains(temp)) {
temp = temp - 1;
continue;
}
System.out.println(temp);

}
}}

回答5:

下面是我写的测试例子,随机数我也是用的测试数字
看看是否符合你的要求

List list = new ArrayList();
list.add(3);
list.add(1);
list.add(5);
list.add(6);
list.add(7);
list.add(9);
list.add(10);
Random r = new Random();
Integer a = 7;// 随机生成一个数
Object [] obj=list.toArray();
Arrays.sort(obj);
for (int i = obj.length-1; i >=0; i--) {
if(obj[i]==a){
a--;
}
}
System.out.println(a);