0

我需要从一些给定的数据(来自图表的数据)中找到严重的顶部。数据被放入一个数组中。

顶部定义为在顶部之前的特定间隔中具有较低或相等的元素,在顶部之后的特定间隔中具有较低或相等的元素。我想保持简单,因为我不是专家。

我正在使用一些不同的工具分析一些股票图表。我希望你能帮助我,或者提供一些其他的意见来处理这个问题:)

4

2 回答 2

1

这是一个工作示例:

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Random;

public class Test
{
  static final int[] graph = new int[100]; static { randomGraph(); }
  static final int window = 3;

  public static void main(String[] args) {
    final List<Integer> tops = new ArrayList<Integer>();
    for (int i = 0; i < graph.length; i++)
      if (max(i-window, i) <= graph[i] && graph[i] >= max(i+1, i+1+window))
        tops.add(i);
    System.out.println(tops);
  }
  static int max(int start, int end) {
    int max = Integer.MIN_VALUE;
    for (int i = Math.max(start, 0); i < Math.min(end, graph.length); i++)
      max = Math.max(max, graph[i]);
    return max;
  }

  private static void randomGraph() {
    final Random r = new Random();
    for (int i = 1; i < graph.length; i++)
      graph[i] = graph[i-1] + r.nextInt(10) - 5;
    System.out.println(Arrays.toString(graph));
  }
}
于 2012-05-05T11:18:22.530 回答
0

如果阵列不是太大,蛮力解决方案可能适合。您可以只迭代元素,并检查您为每个元素描述的谓词:

伪代码:

for (int i = 0; i < array.length; i++) { 
   boolean isPick = true;
   for (int j = max(0,i-interval; j < min(array.length,i+interval; j++) 
       if (array[j] > array[i]) isPick=false;
   //do something with the pick, isPick indicates if it is a pick or not.

如果数组非常大,您可能要考虑的启发式解决方案是爬山

于 2012-05-05T09:32:09.633 回答