代码之家  ›  专栏  ›  技术社区  ›  Chloe13

如何遍历arraylist以查看是否有任何对象具有相同的值

  •  1
  • Chloe13  · 技术社区  · 6 年前

    我有一个汽车的数组列表,我想遍历这个数组列表,看看两辆车是否在完全相同的位置,这样我就可以看到它们是否发生了碰撞。我写了下面这些,但我得到的是“没有碰撞”,即使他们已经碰撞。我用了两种方法。我的假设是,既然两个循环都是从同一点开始循环的,那么它们只是不断地一起检查同一辆车还是类似的东西?所以如果我!(碰撞)每次都会被触发吗?如果是,我该如何阻止?

    public void carCollision(Car collided) {
    
        for (Car i: cars) {
            if(i != collided && i.getLane() == collided.getLane() && 
                i.getPosition() == collided.getPosition()) {
                System.out.println("collision");
            } else {
                System.out.println("no collisions");
            }
        }
    }
    
    public void check() {
        for (Car a: cars) {
            carCollision(a);
        }
    }
    

    汽车类-

    /** State of a car on the road */
    public class Car {
    
    /** Position of this car on the road (i.e. how far down the road it is) in pixels */
    private double position;
    /** Current speed in pixels per second */
    private double speed;
    /** Lane that this car is on */
    private int lane;
    /** Colour of this car's display */
    private Color color;
    
    public Car(double position, double speed, int lane, Color color) {
        this.position = position;
        this.speed = speed;
        this.lane = lane;
        this.color = color;
    }
    
    /** @return a new Car object with the same state as this one */
    public Car clone() {
        return new Car(position, speed, lane, color);
    }
    
    /** Update this car after `elapsed' seconds have passed */
    public void tick(Environment environment, double elapsed) {
        position += speed * elapsed;
    }
    
    public double getPosition() {
        return position;
    }
    
    public int getLane() {
        return lane;
    }
    
    public Color getColor() {
        return color;
    }
    

    这是我的主要类,用来显示我是如何调用方法的,我在addcars方法中使用e.check();的-

    public class Main extends Application {
    public static void main(String[] args) {
        launch(args);
    }
    
    public void start(Stage stage) {
    
        final Environment environment = new Environment();
        final Display display = new Display(environment);
        environment.setDisplay(display);
    
        VBox box = new VBox();
    
        stage.setTitle("Traffic");
        stage.setScene(new Scene(box, 800, 600));
    
        HBox controls = new HBox();
        Button restart = new Button("Restart");
        controls.getChildren().addAll(restart);
        box.getChildren().add(controls);
    
        restart.setOnMouseClicked(e -> {
                environment.clear();
                display.reset();
                addCars(environment);
            });
    
        box.getChildren().add(display);
    
        addCars(environment);
    
        stage.show();
    }
    
    /** Add the required cars to an environment.
     *  @param e Environment to use.
     */
    private static void addCars(Environment e) {
        /* Add an `interesting' set of cars */
        Random r = new Random();
        e.add(new Car(  0, 63, 2, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.add(new Car( 48, 79, 0, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.add(new Car(144, 60, 0, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.add(new Car(192, 74, 0, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.add(new Car(240, 12, 1, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.add(new Car(288, 77, 0, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.add(new Car(336, 28, 1, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.add(new Car(384, 32, 2, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.add(new Car(432, 16, 1, new Color(r.nextFloat(), r.nextFloat(), r.nextFloat(), 1.0)));
        e.check();
    }
    };
    

    public class Environment implements Cloneable {
    
    /** All the cars that are on our road */
    private ArrayList<Car> cars = new ArrayList<Car>();
    /** The Display object that we are working with */
    private Display display;
    /** Number of lanes to have on the road */
    private int lanes = 4;
    private long last;
    
    /** Set the Display object that we are working with.
     */
    public void setDisplay(Display display) {
        this.display = display;
    
        /* Start a timer to update things */
        new AnimationTimer() {
            public void handle(long now) {
                if (last == 0) {
                    last = now;
                }
    
                /* Update the model */
                tick((now - last) * 1e-9);
    
                /* Update the view */
                double furthest = 0;
                for (Car i: cars) {
                    if (i.getPosition() > furthest) {
                        furthest = i.getPosition();
                    }
                }
                display.setEnd((int) furthest);
                display.draw();
                last = now;
            }
        }.start();
    }
    
    /** Return a copy of this environment */
    public Environment clone() {
        Environment c = new Environment();
        for (Car i: cars) {
            c.cars.add(i.clone());
        }
        return c;
    }
    
    /** Draw the current state of the environment on our display */
    public void draw() {
        for (Car i: cars) {
            display.car((int) i.getPosition(), i.getLane(), i.getColor());
        }
    }
    
    /** Add a car to the environment.
     *  @param car Car to add.
     */
    public void add(Car car) {
        cars.add(car);
    }
    
    public void clear() {
        cars.clear();
    }
    
    /** @return length of each car (in pixels) */
    public double carLength() {
        return 40;
    }
    
    /** Update the state of the environment after some short time has passed */
    private void tick(double elapsed) {
        Environment before = Environment.this.clone();
        for (Car i: cars) {
            i.tick(before, elapsed);
        }
    }
    
    /** @param behind A car.
     *  @return The next car in front of @ref behind in the same lane, or null if there is nothing in front on the same lane.
     */
    public Car nextCar(Car behind) {
        Car closest = null;
        for (Car i: cars) {
            if (i != behind && i.getLane() == behind.getLane() && i.getPosition() > behind.getPosition() && (closest == null || i.getPosition() < closest.getPosition())) {
                closest = i;
            }
        }
        return closest;
    }
    
    public void carCollision(Car collided) {
    
        for (Car i: cars) {
            double MIN_DIS = 0.1;
            if(!(i.equals(collided)) && i.getLane() == collided.getLane() && 
                (Math.abs(i.getPosition() - collided.getPosition()) < MIN_DIS )) {
                System.out.println("collision");
            } else {
                System.out.println("no collisions");
            }
        }
    }
    
    public void check() {
        for (Car a: cars) {
            carCollision(a);
        }
    
    }
    
    public void speed() {
        for (Car a : cars) {
            a.setSpeed();
        }
    }
    
    /** @return Number of lanes */
    public int getLanes() {
        return lanes;
    }
    

    }

    更新-尚未修复,但我想我正在接近。我使用“nextCar”方法添加了以下代码-

    public Car nextCar(Car behind) {
        Car closest = null;
        for (Car i: cars) {
            if (i != behind && i.getLane() == behind.getLane() && i.getPosition() > behind.getPosition() && (closest == null || i.getPosition() < closest.getPosition())) {
                closest = i;
            }
        }
        return closest;
    }
    
    public void collision() {
        Environment e = Environment.this.clone();
        double MIN_DIS = 0.5;
        for (Car i : cars) {
            e.nextCar(i);
            for (Car a : cars) {
                if(!(i.equals(a)) && i.getLane() == a.getLane() && 
                    (Math.abs(i.getPosition() - a.getPosition()) < MIN_DIS)) {
                System.out.println("collision");
            } else {
                System.out.println("no collision");
            }
    
                System.out.println("closest car is" + i);
            }
        }
    }
    

    4 回复  |  直到 6 年前
        1
  •  0
  •   ciamej    6 年前

    你会调用 check() 在每辆车上 cars 检查() .

    但必须提醒您,使用浮点位置,这确实很棘手。如果两辆车的初始位置相同,速度和 tick 是用同样的方法 elapsed 争论,然后他们会有同样的 position . 然而,在任何其他情况下,由于舍入误差,它们的位置可能相差很小,比如 0.00000000001 .

    你必须给我们展示一个完整的例子,一组汽车,以及你如何称呼 在他们身上。

        2
  •  0
  •   Abubakar Azeem    6 年前

    位置是双倍值,因此位置不能完全相同。因此,定义一个最小距离值,并在该值以下考虑碰撞 MIN_DIS = 0.1 .

    public void carCollision(Car collided) {
    
        for (Car i: cars) {
            if(!(i.equals(collided)) && i.getLane() == collided.getLane() && 
                (Math.abs(i.getPosition() - collided.getPosition()) < MIN_DIS)) {
                System.out.println("collision");
            } else {
                System.out.println("no collisions");
            }
        }
    }
    
    public void check() {
        for (Car a: cars) {
            carCollision(a);
        }
    }
    

    还有你的汽车课。

    import java.awt.Color;
    import org.omg.CORBA.Environment;
    
    /** State of a car on the road */
    public class Car {
    
        /**
         * Position of this car on the road (i.e. how far down the road it is) in
         * pixels
         */
        private double position;
        /** Current speed in pixels per second */
        private double speed;
        /** Lane that this car is on */
        private int lane;
        /** Colour of this car's display */
        private Color color;
    
        public Car(double position, double speed, int lane, Color color) {
            this.position = position;
            this.speed = speed;
            this.lane = lane;
            this.color = color;
        }
    
        /** @return a new Car object with the same state as this one */
        public Car clone() {
            return new Car(position, speed, lane, color);
        }
    
        /** Update this car after `elapsed' seconds have passed */
        public void tick(Environment environment, double elapsed) {
            position += speed * elapsed;
        }
    
        public double getPosition() {
            return position;
        }
    
        public int getLane() {
            return lane;
        }
    
        public Color getColor() {
            return color;
        }
    
        public double getSpeed() {
            return speed;
        }
    
        @Override
        public boolean equals(Object obj) {
            if (obj instanceof Car){
                Car car = (Car) obj;
                return car.getPosition() == this.position && car.getLane() == this.lane && car.getColor().equals(this.color) && car.getSpeed() == this.speed; 
            }
            return false;
        }
    }
    
        3
  •  0
  •   TongChen    6 年前

    我有办法不直接解决你的问题,希望能帮助你。

    第一组,假设你有一个汽车清单:

    // init the cars
    List<Car> cars = new ArrayList<>();
    
    // first group
    Map<Tuple2<Double,Integer>,List<Car>> groupResult = cars.stream()
        .collect(Collectors.groupingBy(new Function<Car, Tuple2<Double,Integer>>() {
            @Override
            public Tuple2<Double, Integer> apply(Car car) {
                return new Tuple2<>(car.getPosition(),car.getLane());
            }
        }));
    

    如果组结果中列表的大小不是1,则在同一位置上有车