package demo;
import java.util.*;
public class Listl {
public static void main(String args[]){
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
for(Integer j:list){
if(i==j) return true;
}
return false;
}
}
欢迎追问
import
java.util.ArrayList;
import
java.util.List;
import
java.util.Random;
public
class ListTest {
publicstaticvoid main(String[] args) {
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;
}
}
}
}
提供思路 需要的话提供代码
List遍历就就俩方法
效率最高的是迭代器吧 然后是临时变量把list当数组看
实现的方法没什么问题 优化的话就作一个二分查找吧
List既然是从数据库里面取出来的 可以在做查询的时候使用排序
然后在找list元素的时候 用二分查找 效率应该会高一点
直接用一个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
for (Integer a : intes) {
list.add(a);
}
checkOutPut(list);
}
private static void checkOutPut(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);
}
}}
下面是我写的测试例子,随机数我也是用的测试数字
看看是否符合你的要求
List
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);