java 找出位于其中的元素之间距离最小的位置

k4emjkb1  于 2023-02-02  发布在  Java
关注(0)|答案(3)|浏览(126)

我试图实现的位置,其中的元素位于这些有最小的距离,他们之间?我有这个代码在java 11:

public class Main {
    public static void main(String[] args) {
        int [] arr= {5, 50, 3, 42, 18, 16, 8, 30, 44};      // Array
        menorD l = new menorD();        
        menorD.MinD(arr);   
    }
}

public class  menorD {

    static int arr_zise;

    public static void minD (int [] arr) {
        arr_zise = arr.length;
        int i, j;
        int minD=0;

        for(i=0;i<arr_zise; i++) {
            for(j=0;j<arr_zise; j++) {
                if(arr[i]!=arr[j]) {
                    minD=arr[i]-arr[j];
                    System.out.print(" i="+ arr[i]+ " j="+ arr[j]+ " minD es: "+Math.abs(min));
                    System.out.println();
                }
            }
        }
    }
}

我试着找到这个:

arr = {5, 50, 3, 42, 18, 16, 8, 30, 44}

我的Dmin将是它们之间具有较小距离的数字之间的差,在这种情况下,

Dmin1 = 5-3 = 2;

Dmin2 = 18-16 = 2;

Dmin3 44-42 = 2;

而不重复数组中数字的索引。我已经做了这个代码,但是我很难找到我要找的东西。

wswtfjt7

wswtfjt71#

理想情况下,当处理逻辑分组在一起的数据时,应该抽象出一个类来封装它。在您的情况下,您希望跟踪每个可能的distance组合。每个Combination应该跟踪:
1.值的索引。
1.价值观本身。
1.距离。
1.哪个低哪个高。
其中,3和4可由1和2计算得出。

class Combination {
        int indexA, indexB, valueA, valueB;

        public Combination(int[] array, int indexA, int indexB) {
            this.indexA = indexA;
            this.indexB = indexB;
            this.valueA = array[indexA];
            this.valueB = array[indexB];
        }

        public int getDistance() { ... }
        public int getHigh() { ... }
        public int getLow() { ... }
        public int getHighIndex() { ... }
        public int getLowIndex() { ... }
    }

有了这样的数据结构(类),你就可以为每一种可能的组合构造对象了(当然不能重复--注意j是如何在i + 1处 * 不定地 * 开始的,以避免重复可能的组合):

List<Combination> combinations = new ArrayList<>();
        for (int i = 0; i < array.length; i++) 
            for (int j = i + 1; j < array.length; j++) 
                combinations.add(new Combination(array, i, j));

然后使用CombinationList,可以计算它们之间的最小距离:

int min = combinations.stream()
                .mapToInt(Combination::getDistance)
                .min().getAsInt();

最后,您可以选择与之前计算的最小距离相匹配的组合:

combinations.stream()
            .filter(c -> c.getDistance() == min)
            .forEach(c -> System.out.println(c));

关键是将Combination类抽象到它自己的封装类中,这样它就可以单独负责提供必要的API来检查特定的组合:索引、值、距离、高值、低值和偶数**String**(toString)表示。
以下是此方法的完整演示,运行它可以获得一种感觉:

import java.util.ArrayList;
import java.util.List;

public class MinimumDistance {
    
    public static void main(String[] args) {
        printMinimums(5, 50, 3, 42, 18, 16, 8, 30, 44);
    }

    public static void printMinimums(int... array) {
        List<Combination> combinations = new ArrayList<>();
        for (int i = 0; i < array.length; i++) 
            for (int j = i + 1; j < array.length; j++) 
                combinations.add(new Combination(array, i, j));
        
        int min = combinations.stream()
                .mapToInt(Combination::getDistance)
                .min().getAsInt();
        
        combinations.stream()
            .filter(c -> c.getDistance() == min)
            .forEach(c -> System.out.println(c));
    }
    
    static class Combination {
        int indexA, indexB, valueA, valueB;

        public Combination(int[] array, int indexA, int indexB) {
            this.indexA = indexA;
            this.indexB = indexB;
            this.valueA = array[indexA];
            this.valueB = array[indexB];
        }

        public int getDistance() {
            return getHigh() - getLow();
        }

        public boolean isValueAHigh() {
            return valueA > valueB;
        }

        public int getHigh() {
            return isValueAHigh() ? valueA : valueB; 
        }

        public int getLow() {
            return isValueAHigh() ? valueB : valueA; 
        }

        public int getHighIndex() {
            return isValueAHigh() ? indexA : indexB; 
        }

        public int getLowIndex() {
            return isValueAHigh() ? indexB : indexA; 
        }

        public String toString() {
            return String.format("%d[%d] - %d[%d] = %d", 
                                    getHigh(), getHighIndex(), 
                                    getLow(), getLowIndex(), 
                                    getDistance());
        }
    }
}

Complete code on GitHub

7kqas0il

7kqas0il2#

我在网上找到的。你在做这个练习吗?
参考:https://www.geeksforgeeks.org/find-the-minimum-distance-between-two-numbers/

public class MinimumDistance {
    int minDist(int arr[], int n, int x, int y)  
    { 
        int i, j; 
        int min_dist = Integer.MAX_VALUE; 
        for (i = 0; i < n; i++)  
        { 
            for (j = i + 1; j < n; j++)  
            { 
                if ((x == arr[i] && y == arr[j] 
                    || y == arr[i] && x == arr[j]) 
                    && min_dist > Math.abs(i - j))  
                    min_dist = Math.abs(i - j); 
            } 
        } 
        return min_dist; 
    } 

    public static void main(String[] args)  
    { 
        MinimumDistance min = new MinimumDistance(); 
        int arr[] = {3, 5, 4, 2, 6, 5, 6, 6, 5, 4, 8, 3}; 
        int n = arr.length; 
        int x = 3; 
        int y = 6; 

        System.out.println("Minimum distance between " + x + " and " + y  
                + " is " + min.minDist(arr, n, x, y)); 
    } 
}
j1dl9f46

j1dl9f463#

在迭代for循环时,可以将Integer距离的Map填充到索引Map<Integer,List<Integer>>List(甚至是实际值,这取决于您的用例)。如果您总是将两个索引一起添加到List,那么你就知道它们在List中总是彼此相邻的,以便以后作为对来检索。然后只需要使用你的最小距离作为Map的关键来拉取相邻对的列表。请记住,如上所述,此列表将有重复项。

相关问题