- 締切済み
点の組をキューに入れたいのですが。
以下のプログラムは、小さい順にソートされたx座標を三角形にして分割するプログラムです。 三角形の頂点の組をすべてキューQに入れたいのですがどうしたらよいでしょうか? 初歩的な質問かもしれませんが、回答してくれるかたいましたらよろしくお願いします。 --------------------------------------------- #include <stdio.h> double x[100],y[100]; int n; int main() {int triangle[3]={0,1,2}; int nextVertex; int i; makepoints(&n, x, y); /* 三角形の頂点の組を表示 */ printf("Triangle 1 : "); for(i=0;i<3;i++){ printf("%d ",triangle[i]); } printf("\n"); /* 各頂点の処理 */ for(nextVertex=3;nextVertex < n; nextVertex++){ double m,k; int side1,side2; /* 傾きが極端に大きくなったときに計算誤差が発生。これが起こらないよう、傾きが1を境に処理をxとyで入れ替える*/ if(y[triangle[2]]-y[triangle[1]]<x[triangle[2]]-x[triangle[1]]){ /* 直線の傾き・切片を計算 */ m=(y[triangle[2]]-y[triangle[1]])/(x[triangle[2]]-x[triangle[1]]); k=y[triangle[2]]-m*x[triangle[2]]; /* side1,side2にはy>mx+kが成り立っていれば0以外、成り立たなければ0がそれぞれ入る */ side1=y[triangle[0]]>m*x[triangle[0]]+k; side2=y[nextVertex]>m*x[nextVertex]+k; }else{ /* xyを入れ替えただけ */ m=(x[triangle[2]]-x[triangle[1]])/(y[triangle[2]]-y[triangle[1]]); k=x[triangle[2]]-m*y[triangle[2]]; side1=x[triangle[0]]>m*y[triangle[0]]+k; side2=x[nextVertex]>m*y[nextVertex]+k; } /* 判別結果によって次の三角形の頂点を 選択 */ if(side1^side2){ /* 排他的論理和を使って判別。side1/side2のいずれか一方のみが非0のとき条件成立 */ triangle[0]=triangle[1]; } /* else節はなくても一緒なので略す else{ triangle[0]=triangle[0]; } */ triangle[1]=triangle[2]; triangle[2]=nextVertex; /* 三角形の頂点の組を表示 */ printf("Triangle %d : ",nextVertex-1); for(i=0;i<3;i++){ printf("%d ",triangle[i]); } printf("\n"); } printf("正常に終了しました。何かキーを押してください。"); rewind(stdin); getchar(); }
- みんなの回答 (1)
- 専門家の回答
みんなの回答
- asuncion
- ベストアンサー率33% (2127/6290)
makepoints関数のソースを省略したのには、何か意図があるのですか?
補足
すいません、文字数の問題です。