program My_3D; uses graph,crt; const max=100; procedure calc(var x,y,z,xt,yt,zt,xan,yan,zan:real); begin Yt:= Y * COS(Xan) - Z * SIN(Xan); Zt:= Y * SIN(Xan) + Z * COS(Xan); Y:= Yt; Z:= Zt; Xt:= X * COS(Yan) - Z * SIN(Xan); Zt:= X * SIN(Yan) + Z * COS(Xan); X:= Xt; Z:= Zt; Xt:= X * COS(Zan) - Y * SIN(Zan); Yt:= X * SIN(Zan) + Y * COS(Zan); X:= Xt; Y:= Yt; end; var gd,gm,i,i1,color:integer; modelx4,modely4,modelz4,modelx1,modely1,modelz1,modelx2,modely2,modelz2,modelx3,modely3,modelz3:array[1..max] of real; xan,yan,zan:real; yt,xt,zt:real; sx1,sx2,sx3,sx4,sy1,sy2,sy3,sy4,sz1,sz2,sz3,sz4:integer; arr: array[1 .. 8] of integer; modelfile:text; path:string; zoom:integer; buf1,buf2,buf3,buf4:real; sum1,sum2:real; min:integer; begin gd:=detect;initgraph(gd,gm,'C:\bp\bgi'); xan:=0.02; yan:=0.02; zan:=0.02; zoom:=50; path:='cube.dat'; assign(modelfile,path); reset(modelfile); readln(modelfile,i); for i1:=1 to i do begin readln(modelfile,modelx1[i1],modely1[i1],modelz1[i1],modelx2[i1],modely2[i1],modelz2[i1], modelx3[i1],modely3[i1],modelz3[i1],modelx4[i1],modely4[i1],modelz4[i1]); end; min:=1; repeat for i1:=1 to i-1 do begin sum1:=modelz1[min]+modelz2[min]+modelz3[min]+modelz4[min]; sum2:=modelz1[i+1]+modelz2[i+1]+modelz3[i+1]+modelz4[i+1]; if sum1