前提・実現したいこと
.txtによって与えられた第一象限中の(x,y)の中から、1*1正方形の中にある点(x,y)の数を数えるプログラミングです。
(x,y)のデータは高々100個で、.txtには番兵として-1 -1
が入ってます
segmentation fault の解決
発生している問題・エラーメッセージ
segmentation fault
該当のソースコード
c
1#include<stdio.h> 2#include<stdlib.h> 3typedef struct{ 4 double x; 5 double y; 6}Axis; 7 8int input_data(Axis *); 9int square(Axis * ,int); 10 11int main(void){ 12 int n,a; 13 Axis *point; 14 point=(Axis *)calloc(102,sizeof(Axis)); 15 if(point==NULL){ 16 perror("領域の確保に失敗"); 17 } 18 n=input_data(point); 19 20 a=square(point,n); 21 22 printf("データ内の個数:%d",n); 23 printf("正方領域内の個数:%d",a); 24 25 free(point); 26 return 0; 27} 28 29int input_data(Axis *point){ 30 int i=0; 31 do{ 32 33 scanf("%lf %lf",&(point+i)->x,&(point+i)->y); 34 i++; 35 }while((point+i)->x!=-1); 36 37 return i-1; 38} 39 40int square(Axis *point,int n){ 41 int i,a=0; 42 for(i=0;i<n;i++){ 43 if((point+i)->x < 1 || (point+i)->y < 1){ 44 a++; 45 } 46 } 47 return a; 48} 49 50 51
試したこと
確保する領域を202,402のそれぞれで試しましたが解決しませんでした
補足情報(FW/ツールのバージョンなど)
emacs
gcc
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。