2014-12-02 110 views
-19

我正在做我的功課,我不想讓別人做我的功課我只想知道我的代碼有什麼問題。C - 類型不匹配

錯誤:

 
C:\Users\Cojik\Desktop\Codeblocks files\zadaca2_zadatak1\main.c||In function 'main':| 
C:\Users\Cojik\Desktop\Codeblocks files\zadaca2_zadatak1\main.c|28|error: invalid operands to binary > (have 'float *' and 'float')| 
C:\Users\Cojik\Desktop\Codeblocks files\zadaca2_zadatak1\main.c|29|error: incompatible types when assigning to type 'float' from type 'float *'| 
C:\Users\Cojik\Desktop\Codeblocks files\zadaca2_zadatak1\main.c|39|error: invalid operands to binary (have 'float *' and 'float')| 
C:\Users\Cojik\Desktop\Codeblocks files\zadaca2_zadatak1\main.c|63|error: incompatible types when assigning to type 'float' from type 'float *'| 
||=== Build failed: 8 error(s), 0 warning(s) (0 minute(s), 0 second(s)) ===| 

代碼:

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

int main() 
{ 
    int n, i ,j; 
    float arr[1000], max1=-999999999999999.0, max4=-999999999999999.0, min2=999999999999999.0, min3=999999999999999.0; 
    printf("Enter the number n: "); 
    scanf("%d", &n); 
    if(n<3||n>30) 
     printf("Worng entry!"); 
    else 
    { 
     for(i=0;i<n;i++) 
     { 
      printf("Enter the elements of %d. row: ", i+1); 
      for(j=0;j<n;j++) 
      { 
       scanf("%f", &arr[i]); 
      } 
     } 
     for(i=0;i<n;i++) 
     { 
      for(j=0;j<n;j++) 
      { 
       if(i>j && i<n-1-j) 
       { 
        if(arr[i]>max1) 
         max1=arr[i]; 
       } 
       if(j>i && j<n-1-i) 
       { 
        if(arr[i]<min2) 
         min2=arr[i]; 
       } 
       if(i>j && j>n-1-i) 
       { 
        if(arr[i]<min3) 
         min3=arr[i]; 
       } 
       if(j>i && i>n-1-j) 
       { 
        if(arr[i]>max4) 
         max4=arr[i]; 
       } 
      } 
     } 
     if(max1==max4 && min2==min3) 
     { 
      printf("Array is simetrical!\n"); 
      printf("Elements: o1 = %.3f, o2 = %.3f, o3 = %.3f, o4 = %.3f", max1, min2, min3, max4); 
     } 
     else 
     { 
      printf("Array is not simetrical!\n"); 
      printf("Elements: o1 = %.3f, o2 = %.3f, o3 = %.3f, o4 = %.3f", max1, min2, min3, max4); 
     } 
    } 
    return 0; 
}  

請問我的數組必須是二維?如果它是二維的,我的代碼會給出錯誤的答案,如果它是一維的,則不會出現此錯誤。

+5

請張貼代碼。看起來你在代碼中使用了錯誤的指針。 – Haris 2014-12-02 15:43:11

+2

'float'和'float *'是不同的類型。 – BLUEPIXY 2014-12-02 15:43:54

+0

從所有的錯誤信息,我認爲他很顯然,他正試圖使用​​一個指針作爲浮動浮動,或不? – OiciTrap 2014-12-02 15:48:04

回答

1

似乎你的編譯器混淆了。無論如何,max1 .. max4的初始值對於一個浮點數來說太大了。使用雙。

我也注意到你做if(max1==max4 && min2==min3),但是,絕對比較兩個浮點值是不好的做法。你應該比較它們在epsilon,機器精度內相等:

#define epsilon 0.0000000001; //(I don't say this value is correct; just an example) 
#define ABS(a) (a<0?-a:a) 

if(ABS(max1-max4)<epsilon && ABS(min2-min3)<epsilon) 
+0

@Aleksandar Misich,感謝您的編輯。我注意到我的示例中有一個錯誤並更新了我的解決方案 – 2017-03-31 16:20:26