- 在线时间
- 428 小时
- 最后登录
- 2017-2-22
- 注册时间
- 2011-9-18
- 听众数
- 8
- 收听数
- 0
- 能力
- 20 分
- 体力
- 6079 点
- 威望
- 110 点
- 阅读权限
- 200
- 积分
- 3684
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 759
- 主题
- 60
- 精华
- 0
- 分享
- 0
- 好友
- 40
TA的每日心情 | 开心 2017-2-22 14:21 |
|---|
签到天数: 271 天 [LV.8]以坛为家I
群组: 2014年美赛冲刺培训 群组: 物联网工程师考试 群组: 2013年电工杯B题讨论群 群组: 物联网工程师培训 群组: 2013电工杯A题讨论群组 |
定义一个Shape抽象类,建立一个point类,表示平面中的一个点;建立一个line类,表示平面中的一条线段,内含两个point类的对象;建立triangle类,表示一个三角形,内含三个line类的对象构成一个三角形,确定派生关系,编制相应程序输出相关信息,设计triangle类的成员函数完成三条边是否能构成三角形的检验和三角型面积计算,输出相关信息。
: @5 t! O( y: @/ W E, O
; n: Q* k4 K9 o! X# O0 B" Y' X$ t
#include<iostream>" C, q* `( M. j5 F1 F+ D
#include<string>/ f4 B1 Y; f# S: y" [4 t
#include<math.h>1 X* A3 {% N0 R1 l- x6 q
using namespace std;' v0 V3 G0 U. d: V1 j
class Shape# j7 D( R4 G8 u
{public:
" Z5 l1 x1 H7 o5 U};
; z/ P' W9 J" j) d% Z% T f: wclass Point:public Shape1 N% x" _+ a6 h. z+ X3 y1 U
{public:
; E1 l/ ~4 F5 K% r# @4 `Point(float a,float b)
* w0 l2 s; t! }. H* U9 O{x=a;y=b;}9 c( [# u- t( K; |
. b; z- c* O5 W3 }) m
void setPofloat(float a,float b)/ \% \( C" T' ~/ ^
{x=a;y=b;}
% a: F( ^! ]3 O float x,y;4 K& i% w3 N u( q$ [" X
};1 [* c3 M! _2 c8 f* s
class Line
: o! f6 F5 J7 Q8 K3 i{public:4 L# i; ~0 d3 \# i, S; s: a
Line(float a1,float b1,float a2,float b2):, X! c6 ~0 x3 W" I( l' X- J E8 H
p1(a1,b1),p2(a2,b2){}; k% E% D/ Z) ]& H! [
, A2 a- j$ U: h2 e% g
double length()& C0 f" j7 g2 I* s, T
{ return (sqrt((p1.x-p2.x)*(p1.x-p2.x)+(p1.y-p2.y)*(p1.y-p2.y))); }
) I. g' F: A* J2 O3 F- _void setline(){
) @6 P: x! f$ Y, J cin>>p1.x>>p1.y>>p2.x>>p2.y;
7 v# e( c: r: b3 D2 E' D}: D$ E) u( b/ t4 d
protected:' \! ^& U! O p0 R$ M8 p7 \% S
Point p1,p2;7 R# H. s! u5 x9 F- U& u7 P3 {
};
9 o" _0 O, m7 Vclass Triangle
# O$ S: e: W$ j4 G4 m{
. u: G! `' {( e7 o, Y2 xpublic:! X8 p. j, b6 W9 ?; Z
Triangle(float a1,float b1,float a2,float b2, float a3,float b3,float a4,float b4 ,float a5,float b5,float a6,float b6):5 }& S6 O2 O! n7 d" \
l1(a1,b1,a2,b2), l2(a3,b3,a4,b4) , l3(a5,b5,a6,b6){};* X* a* t0 n# N- h" G& A
0 V9 ~: }) Q4 zfloat delta(){, `6 F/ a' u8 h; E# s8 T! R8 d# A9 \( }, F
d1=l1.length();
5 h' P' d3 d2 w6 {! f% r& F" R5 H d2=l2.length();
9 w: r# z# w- p" Z1 ` C! U d3=l3.length();! z. d; ~. B' _$ T6 u$ b
if((d1+d2>d3)&&(d2+d3>d1)&&(d3+d1>d2))
4 d5 w$ ` ^2 V7 j return 1;2 D; g! Y3 m' K- b% C1 ^2 A
else* X# A: P+ ^. M* z& g
return 0;$ P% ]3 Y3 c1 c& N7 D7 n6 M
}
e& T' I# p5 {/ [void sett(){
! D, W* ]( j3 m' ?+ { cout<<"输入3条线的6个点的坐标(12个数字)"<<endl;
9 q( }3 E$ e t6 p% ^ l1.setline();. D& V4 G7 D. n% N: x9 s2 o1 a( Q: l W2 ~
l2.setline();; C) |0 M9 n" s/ @! o+ @
l3.setline();0 ?2 t" J7 V6 V
cout<<"3条线的长度分别为:"<<endl;$ g# z6 J3 N, t
cout<<l1.length()<<", "<<l2.length()<<", "<<l3.length()<<"."<<endl;" @7 h! c: { ^
try & g6 e5 L S4 X: W1 R. e$ q$ b4 D" `
{8 m! K/ a. p& R% p( c
double p=(l1.length()+l2.length()+l3.length())/2;( Y# m x* @( ~( W7 M
if ( (l1.length()+l2.length()<=l3.length()) || (l2.length()+l3.length()<=l1.length()) || (l3.length()+l1.length()<=l2.length()) ) throw l1.length();
' z! ?& g8 ^% r. [; i0 X
) |5 e) j4 L5 k& I double s=sqrt( p*(p-l1.length()) * (p-l2.length()) *(p-l3.length()) );. d' W# `( r- B+ _# s
cout<<"三角形的面积:"<<s<<endl;3 J( [7 b, Z1 j9 F+ I6 S1 ]. K
}1 F5 j; F' n$ b+ q( u
! \9 W6 ?6 J( ~4 \
catch (double)
1 L+ e' K& J# ?& r, p K8 z {cout<<"经过异常处理,发现您所输入的坐标构成的3条线段长度不满足三角形";+ i! K0 ?7 y* a( g, Q5 B
}- f3 I5 a0 h; X. i- u; x
}//sett()
% X2 A4 {+ K; I& h8 kprotected:/ G+ ]3 f/ W* L J3 x
Line l1,l2,l3;* X2 x k7 j+ `0 A) C" K
float d1,d2,d3;
4 z- \" T5 H# N};( {4 J. L! |4 G2 I6 Z/ e
int main()4 L& D3 W+ g3 A1 I, w- O
{- m" D, m% k- Y. q/ a8 T; V8 \
Triangle t1(0,0,1,1, 1,2,3,4 , 4,5,6,7);
K- M2 ?+ @5 X* @ try {
& u; X' n; ^: |6 f: y" f! N6 u float whether=t1.delta();
+ n9 g4 y" c* \9 [' Q" E if(!whether) throw whether;
6 \3 j+ G; C8 j V' R$ e% f t1.sett();
- U0 l' m4 I4 K1 V' n' z }& n) ~ W8 @. i9 B: M+ p; v8 O+ I
catch(float)8 Q" l5 X! |, q, X y, Y* `% S
{cout<<"(0,0)(1,1),(1,2),(3,4),(4,5),(6,7)这几个点不可以构成三角形"<<endl;
5 M M& \0 ~4 U0 }2 i( d; f4 U } m" g: V& i4 V% q
return 0;) X0 P3 n/ `. x/ P6 Q) c
}$ W: Z! X! } X/ ?
|
|