定义矩形类(长length,宽widen)求面积(area)(简单例子)

#include<iostream>
using namespace std;

class Rectangle{                                                      //声明Rectangle类
    public:                                                                  //外部接口
        float area();                                                      //计算矩形面积        
    Rectangle(float len,float wide)                             //构造函数
    {
        length=len;
        widen=wide;
    }
    private:                                                                 //私有数据成员
        float length;                                                       //矩形的长
        float widen;                                                       //矩形的宽
    
};
float Rectangle::area(){                                          //计算矩形面积
    return length*widen;}
int main(){                                                               //主函数
    float length,widen;
    cout<<"请输入矩形的长度: ";                             //输入长
    cin>>length;
    cout<<"请输入矩形的宽度: ";                             //输入宽
    cin>>widen;
    Rectangle r(length,widen);                                //建立矩形的对象
    float a=r.area();                                                  
    cout<<"长为"<<length<<"宽为"<<widen<<"的矩形的面积为: "<<a<<endl;//输出矩形面积
    return 0;
}

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个可能的实现: ```python def widen_line(p1, p2, width): dx = p2[0] - p1[0] dy = p2[1] - p1[1] length = (dx**2 + dy**2)**0.5 if length == 0: return [(p1[0] - width/2, p1[1]), (p1[0] + width/2, p1[1])] else: dx_norm = dx / length dy_norm = dy / length return [(p1[0] - width/2*dy_norm, p1[1] + width/2*dx_norm), (p2[0] - width/2*dy_norm, p2[1] + width/2*dx_norm), (p2[0] + width/2*dy_norm, p2[1] - width/2*dx_norm), (p1[0] + width/2*dy_norm, p1[1] - width/2*dx_norm)] # 输入坐标 points = [] for i in range(4): x = float(input('请输入第{}个点的横坐标:'.format(i+1))) y = float(input('请输入第{}个点的纵坐标:'.format(i+1))) points.append((x, y)) # 连线并加 widen_points = [] for i in range(len(points)): j = (i + 1) % len(points) widened = widen_line(points[i], points[j], 2) widen_points.extend(widened) # 输出形成的闭合图形坐标 print('形成的闭合图形坐标为:') for p in widen_points: print('({:.2f}, {:.2f})'.format(p[0], p[1])) ``` 这个程序首先定义了一个 `widen_line` 函数,用于将两个点之间的线段加。该函数接受三个参数:第一个点坐标 `p1`、第二个点坐标 `p2`,以及加度 `width`。函数返回一个包含四个点坐标的列表,表示加后形成的四边形。 接着,程序使用一个循环读取四个点的坐标,并将它们存储在一个列表 `points` 中。 然后,程序使用一个循环对相邻的两个点之间的线段进行加,并将加后的四边形的四个顶点坐标存储在一个列表 `widen_points` 中。 最后,程序输出所有顶点的坐标,形成闭合图形。注意,输出的坐标保留两位小数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值