Java 作业 MaxSumTest

标签 java data-structures

我目前正在尝试为我的数据结构类修改 Java 家庭作业程序,该程序在表格中显示 MaxSumTest 程序的输出。

我创建了四个数组,并将它们放在计算时间信息的循环之一中。我试图用一种算法的计时信息填充每个数组。所以每个数组都有 4 个元素。但是,每次我运行程序的修订版时,都会出现越界错误。

Here is the Original

我修改的唯一方法是getTimingInfo。这是我的修改:

public static void getTimingInfo( int n, int alg )
{
    int [] test = new int[ n ];

    long startTime = System.currentTimeMillis( );;
    long totalTime = 0;



   //create an array for each Algorithm
    long[] alg4;
    long[] alg3;
    long[] alg2;
    long[] alg1;

    //allocate memory for 5 long ints 

    alg4 = new long[5];
    alg3 = new long[5];
    alg2 = new long[5];
    alg1 = new long[5];

   int i;
   int j;
   int index = 0;

   for( i = 0; totalTime < 4000; i++ )
   {
       for( j = 0; j < test.length; j++ )
           test[ j ] = rand.nextInt( 100 ) - 50;
    index = j;
       switch( alg )
       {
         case 1:
           maxSubSum1( test );
           break;
         case 2:
           maxSubSum2( test );
           break;
         case 3:
           maxSubSum3( test );
           break;
         case 4:
           maxSubSum4( test );
           break;
       }

       totalTime = System.currentTimeMillis( ) - startTime;

   }

    alg1[index] = totalTime * 1000 / i;
    alg2[index] = totalTime * 1000 / i;
    alg3[index] = totalTime * 1000 / i;
    alg4[index] = totalTime * 1000 / i;

    //Build first column of table
    System.out.println("Size of N Algorithms\t" + "250\t" + "2500\t" + "25000\t" + "250000");

    System.out.println("Alg #4\t" + alg4[0] + "\t" + alg4[1] + "\t" + alg4[2] + "\t" + alg4[3] + "\t" + alg4[4]);
    System.out.println("Alg #3\t" + alg3[0] + "\t" + alg3[1] + "\t" + alg3[2] + "\t" + alg3[3] + "\t" + alg3[4]);
    System.out.println("Alg #2\t" + alg2[0] + "\t" + alg2[1] + "\t" + alg2[2] + "\t" + alg2[3] + "\t" + alg2[4]);
    System.out.println("Alg #1\t" + alg1[0] + "\t" + alg1[1] + "\t" + alg1[2] + "\t" + alg1[3] + "\t" + alg1[4]);


    /*

    System.out.println( "Algorithm #" + alg + "\t"
         + "N = " + test.length
         + "\ttime = " + ( totalTime * 1000 / i ) + " microsec" );
    */


 }

任何正确方向的建议或指示将不胜感激。

最佳答案

更新数组元素的行不应该在内循环中吗?

alg1[index] = totalTime * 1000 / i;
alg2[index] = totalTime * 1000 / i;
alg3[index] = totalTime * 1000 / i;
alg4[index] = totalTime * 1000 / i;

您在循环外分配它们,其中 index 的值为 5,因此超出范围。

关于Java 作业 MaxSumTest,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9298553/

相关文章:

data-structures - 谁说的 "data structure(s) is half the code"?

python - 替代合并排序的效率?

java - 在 Blackberry ListField 中选择一个项目

java - 需要修复我的递归代码(get 需要返回 int 或 stackoverflow 错误)

java重命名一堆文件并将它们移动到新文件夹

java - Spring Boot(使用 Gradle)+WebSphere Liberty = 未找到上下文根

c++ - 使用链表实现错误队列

c++ - 非递归二叉树插入()方法不起作用

python - Grep 多层可迭代的字符串匹配(Python)

java - 如何使用 BouncyCaSTLe 进行 TLS?