0

同様の問題に関する質問を読んだことがありますが、2Dまたは動的配列の問題はそこで解決されています。(ポインタはありますが、それらなしでやりたいです。)

#include <stdio.h>
#include <stdlib.h>

int interseq ( int, int ); // interval sequence

int main()
{
    int arr[100] = { 75, 47, 64, 45, 67, 51, 55, 36, 63, 30,
                     39, 58, 55, 67, 70, 44, 46, 51, 51, 61,
                     50, 54, 49, 51, 52, 54, 64, 68, 45, 40,
                     48, 60, 55, 37, 36, 13, 62, 53, 37, 53,
                     52, 49, 37, 54, 69, 44, 53, 58, 77, 46,

                     44, 63, 57, 64, 28, 46, 50, 57, 42, 72,
                     12, 69, 52, 53, 77, 50, 45, 49, 49, 46,
                     28, 40, 65, 25, 45, 45, 62, 28, 39, 69,
                     52, 57, 39, 73, 37, 46, 38, 65, 49, 58,
                     63, 30, 51, 48, 47, 56, 48, 41, 30, 54 };

    printf("%d", interseq ( arr, diagArr) );

    return 0;
} 

/* User's function. Description: 'farr' is 'arr' and so on..  */
int interseq ( int farr, int fdiagArr)
{
   int min, i;

   for ( i = 0; i < 100; i++ )    // Finding the 'min' element.
      if ( farr[i+1] < farr[i] )  // there are 2 errors 
          min = farr[i];          // there is 1 error 
      else
          min = farr[i+1];        // there is 1 error 

return 1;
}

エラーは同じです:

error: subscripted value is neither array nor pointer nor vector
4

2 に答える 2

4

それらをポインタにします:

int interseq(int *farr, int *fdiagArr)
                 ^          ^

diagArrあなたのコードの内容がわからないので、その部分は憶測です。


コメントで simonc が指摘しているように、whenは違法i = 99になります。farr[i+1]早めに停止するか、アルゴリズムを変更する必要があります。

于 2013-04-11T10:29:08.970 に答える
1

これを試して:

//int interseq ( int farr, int fdiagArr)
int interseq ( int farr[], int fdiagArr[])
于 2013-04-11T10:31:22.157 に答える