第六周上机任务4

原创 2012年03月27日 15:22:38
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称:renwu.cpp                              
* 作    者:宋本一                              
* 完成日期:2012 年 3 月 27 日
* 版 本 号:v6.4        
* 对任务及求解方法的描述部分
* 输入描述: 
* 问题描述: 
* 程序输出: 
* 程序头部的注释结束
*/
#include<iostream>     
#include<cmath>   
using namespace std;  
class CPoint  
{  
private:  
    double x;  // 横坐标   
    double y;  // 纵坐标   
public:  
    CPoint(double xx=0,double yy=0);  
    float getx();  
    float gety();  
};

class CTriangle  
{  
public:      
	CTriangle(CPoint &X,CPoint &Y,CPoint &Z,int i=0):A(X),B(Y),C(Z),i(i){} //给出三点的构造函数   
    void setTriangle(CPoint &X,CPoint &Y,CPoint &Z);  
    float perimeter(void);//计算三角形的周长   
    float area(void);//计算并返回三角形的面积   
    void isRightTriangle(); //是否为直角三角形   
    void isIsoscelesTriangle(); //是否为等腰三角形   
    void Distance(CPoint &p,CPoint &q) ;   // 两点之间的距离(一点是当前点,另一点为参数p)   
    float CTriangle::Distance1(CPoint &p,CPoint &q);  
private:  
    CPoint A,B,C; //三顶点   
    float bian[3];  
    int i;  	
};

int main()  
{  
    CPoint c1(0,0),c2(0,1),c3(1,0);  
    CTriangle m(c1,c2,c3);  
    m.setTriangle(c1,c2,c3);  
    m.Distance(c1,c2);  
    m.Distance(c1,c3);  
    m.Distance(c2,c3);  
    cout<<"三角形的周长为:"<<m.perimeter()<<endl;//计算三角形的周长   
    cout<<"三角形的面积为:"<<m.area()<<endl;//计算并返回三角形的面积   
    m.isRightTriangle(); //是否为直角三角形   
    m.isIsoscelesTriangle(); //是否为等腰三角形   
    system("PAUSE");  
	return 0;
}

CPoint::CPoint(double xx,double yy)  
{  
    x=xx;  
    y=yy;  
}

float CPoint::getx()  
{  
    return x;  
}

float CPoint::gety()  
{  
    return y;  
}

void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z)  
{  
    A=X;  
    B=Y;  
    C=Z;    
}

float CTriangle::perimeter(void)//计算三角形的周长   
{  
    float s=0;  
    --i;  
    s=s+bian[i]+bian[i-1]+bian[i-2];  
    return s;  
}

float CTriangle::area(void) //计算并返回三角形的面积   
{   
    float s,m;    
    int i=0;  
    m=(bian[i]+bian[i+1]+bian[i+2])/2;          
    s=sqrt(m*(m-bian[i])*(m-bian[i+1])*(m-bian[i+2]));       
    return s;    
}

void CTriangle::isRightTriangle()   //是否为直角三角形   
{  
	i=0;  
    float m,n,c;  
    m=Distance1(A,B);  
    n=Distance1(A,C);  
    c=Distance1(B,C);  
    if((m+n)==c||(m+c)==n||(c+n)==m)  
    {  
        cout<<"此三角形为直角三角形"<<endl;  
    }  
    else  
    {  
        cout<<"此三角形不是直角三角形"<<endl;  
    }  
}  

void CTriangle::isIsoscelesTriangle() //是否为等腰三角形   
{  
    float m,n,c;  
	i=0;  
    m=bian[i];  
    n=bian[i+1];  
    c=bian[i+2];  
    if(m==n||m==c||n==c)  
    {  
        cout<<"此三角形为等腰三角形"<<endl;  
    }  
    else  
    {  
        cout<<"此三角形不是等腰三角形"<<endl;  
    }  
}

void CTriangle::Distance(CPoint &p,CPoint &q)   
{  
    bian[i]=sqrt((p.getx()-q.getx())*(p.getx()-q.getx())+(p.gety()-q.gety())*(p.gety()-q.gety()));  
    ++i;  	
}

float CTriangle::Distance1(CPoint &p,CPoint &q)   
{  
    bian[i]=(p.getx()-q.getx())*(p.getx()-q.getx())+(p.gety()-q.gety())*(p.gety()-q.gety());  
    ++i;  
    return bian[i-1];  	
}


运行结果:

machine-learning第六周 上机作业

1、如何评估算法好坏:高偏差与高方差的问题; 2、当某个集合中,一个类别远小于另一个类别的时候(如患癌),如何评估在面对偏斜类(Skewed classes)的算法好坏:查准率和召回率; 3、如何选择...
  • dialoal
  • dialoal
  • 2016年02月02日 16:21
  • 1249

quartz实现每周一至周五 非法定节假日 每天9:30-11:30,13:00-15:00执行定时任务

我的定时任务需求是:使用quartz实现每周一至周五,非法定节假日,每天9:30-11:30,13:00-15:00执行定时任务。 经过学习quartz,发现使用SimperTrigger和Cron...
  • ycb1689
  • ycb1689
  • 2016年04月26日 10:41
  • 3659

机器学习(周志华) 参考答案 第六章 支持向量机 6.9

机器学习(周志华) 参考答案 第六章 支持向量机 6.9机器学习(周志华西瓜书) 参考答案 总目录 http://blog.csdn.net/icefire_tyh/article/details/5...
  • icefire_tyh
  • icefire_tyh
  • 2016年08月06日 12:29
  • 1724

Java上机 第六周 任务1 测试三类对象(升级版)

/* * 程序头部注释开始 * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. ...
  • xgcfxl2011
  • xgcfxl2011
  • 2012年09月29日 19:16
  • 1405

第六周上机任务1

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:renwu....
  • dqybzs
  • dqybzs
  • 2012年03月26日 18:16
  • 317

第六周上机任务项目2 程序填空

/* * 程序的版权和版本声明部分 * Copyright (c)2013, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称: object.cpp * 作...
  • GNLFH
  • GNLFH
  • 2013年04月05日 11:10
  • 506

第六周上机任务项目6-工资类

01./* 02.* 程序的版权和版本声明部分 03.* Copyright (c)2013, 烟台大学计算机学院学生 04.* All rightsreserve...
  • zgz1992319
  • zgz1992319
  • 2013年04月07日 13:38
  • 578

第六周上机实践项目4-成员函数、友元函数和一般函数有区别

/* *Copyright (c) 2014,烟台大学计算机学院 *All rights reserved. *文件名称: test.cpp *作 者: 满星辰 *完成日期...
  • manxcc1425
  • manxcc1425
  • 2015年04月14日 20:50
  • 180

第六周上机实践项目-项目4-静态成员应用

/* 问题及代码: *文件名称: *作者:刘涛 完成日期:2016.4.4 * *问题描述:设计含有静态数据成员和成员函数的time类。 *输入描述:无 程序输...
  • lemon_lebron
  • lemon_lebron
  • 2016年04月04日 20:09
  • 156

第六周上机实践项目4——成员函数、友元函数和一般函数有区别

问题及代码 完成求点类中距离的任务。你需要实现求距离函数的三种版本:分别利用成员函数、友元函数和一般函数求两点间距离的函数,并设计main()函数完成测试。 /* * Copyright (...
  • blue_skyrim
  • blue_skyrim
  • 2015年04月12日 17:57
  • 397
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第六周上机任务4
举报原因:
原因补充:

(最多只允许输入30个字)