简易看房加权评估案例C++

2023-05-16

最近偶尔关注房子的事情,为了方便对大量房产信息制定最符合个人需求的评估,所以本人决定写个小东西出来,于是今天就着手了。本人看房经验有限,加权系数仅根据个人感官给定,总和为100。一共综合考虑了10个影响因素,最后对其加权求均值计算出结果。采用类的方法进行编写,当然完全可以使用数组,但是为了定义一个对象更加方便,且易于修改,本人采用类进行编写。由于涉及权益,文中不给出详细的盘或开发商的名字,也不给予城市地名等信息。

1.距离 2.首付月供 3.生活配置 4.教育医疗 5.装修程度 6.建造程度交付时间 7.物业 8.布局朝向大小 9.绿化 10.楼层

加权系数分别为:14,15,12,13,10,15,5,8,5,3

 

/*
对多个房进行一次性综合评分
author:@Babysen
 */

#include <iostream>
#include <iomanip>
#include <fstream>
#include <string>
#include <map>
using namespace std;

class home
{ //考虑十个因素,并对其进行加权,总分100分
private:
    int m_distance;      //距离(通勤)14
    int m_down_payments; //首付与月供15
    int m_living;        //生活配置12
    int m_edu_medical;   //教育医疗13
    int m_renovation;    //装修程度10
    int m_time;          //目前所售盘盖的建造程度,交房时间15
    int m_property;      //物业质量5
    int m_house_type;    //房间布局朝向面积8
    int m_environment;   //绿化5
    int m_floor;         //楼层3
public:
    home();
    home(int distance, int down_payments, int living, int edu_medical, int renovation, int time, int property, int house_type, int environment, int floor)
    {
        m_distance = distance;
        m_down_payments = down_payments;
        m_living = living;
        m_edu_medical = edu_medical;
        m_renovation = renovation;
        m_time = time;
        m_property = property;
        m_house_type = house_type;
        m_environment = environment;
        m_floor = floor;
    };

    int getdis() { return m_distance; }
    int getdown() { return m_down_payments; }
    int getapp() { return m_living; }
    int getedu() { return m_edu_medical; }
    int getmed() { return m_renovation; }
    int gettime() { return m_time; }
    int getpro() { return m_property; }
    int gethty() { return m_house_type; }
    int getenvi() { return m_environment; }
    int getfloor() { return m_floor; }

    double sum(home &h);   //求和函数
    double Mean(home &hm); //求均值
    void showmenu();       //菜单函数
    void test(home &ht);   //测试
    // map<string, house> m_house; //这是一个队组,

    //运算符重载,友元函数
    friend ostream &operator<<(ostream &cout, home hh);
};

//设施一个静态全局变量
static int i = 0;

//求和函数
double home::sum(home &h)
{
    return 14 * h.getdis() + 15 * h.getdown() + 12 * h.getapp() + 13 * h.getedu() + 10 * h.getmed() + 15 * h.gettime() +
           5 * h.getpro() + 8 * h.gethty() + 5 * h.getenvi() + 3 * h.getfloor();
}

//求均值函数
double home::Mean(home &hm)
{
    return sum(hm) / (sizeof(hm) / sizeof(int));
}

//菜单函数
void home::showmenu()
{
    cout << "|---------------------------------------------------------|" << endl;
    cout << "|   1.距离 2.首付月供 3.生活配置 4.教育医疗 5.装修程度    |" << endl;
    cout << "| 6.建造程度交付时间 7.物业 8.布局朝向大小 9.绿化 10.楼层 |" << endl;
    cout << "|---------------------------------------------------------|" << endl;
}

//<<运算符重载
ostream &operator<<(ostream &cout, home hh)
{
    string nameseed[13] = {"枫",
                           "高区",
                           "府",
                           "华",
                           "金府",
                           "隆",
                           "清晖",
                           "万星",
                           "香",
                           "雨华",
                           "景清",
                           "山",
                           "金湾"};
    cout << nameseed[i];
    i++;
    return cout;
}

//测试打包函数
void home::test(home &ht)
{
    pair<home, double> pair1 = make_pair(ht, ht.Mean(ht));
    ht.sum(ht);
    ht.Mean(ht);
    cout << pair1.first << "的得分为:" << pair1.second << endl;
}

//主函数
int main()
{
    //数据写入文件
    ofstream ofs("houseview.csv", ios::trunc); //输出结果存储在statis文件中
    if (!ofs)
    {
        cerr << "open err!" << endl;
        exit(1);
    }
    // 1.距离 2.首付月供 3.生活配置 4.教育医疗 5.装修程度 6.建造程度交付时间 7.物业 8.布局朝向大小 9.绿化 10.楼层

    //创建一个gx对象,分别赋予它们各参数的值
    home gx(8, 8, 10, 9, 8, 7, 8, 7, 7, 6);
    gx.showmenu();
    gx.test(gx);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << gx.Mean(gx) << endl;

    home yt(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt.test(yt);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt.Mean(yt) << endl;

    home yt1(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt1.test(yt);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt1.Mean(yt1) << endl;

    home yt2(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt2.test(yt2);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt2.Mean(yt2) << endl;

    home yt3(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt3.test(yt3);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt3.Mean(yt3) << endl;

    home yt4(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt4.test(yt4);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt4.Mean(yt4) << endl;

    home yt5(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt5.test(yt5);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt5.Mean(yt5) << endl;

    home yt6(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt6.test(yt6);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt6.Mean(yt6) << endl;

    home yt7(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt7.test(yt7);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt7.Mean(yt7) << endl;

    home yt8(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt8.test(yt8);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt8.Mean(yt8) << endl;

    home yt9(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt9.test(yt9);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt9.Mean(yt9) << endl;

    home yt10(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt10.test(yt10);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt10.Mean(yt10) << endl;

    home yt11(8, 3, 10, 9, 8, 7, 8, 9, 7, 2);
    yt11.test(yt11);
    // ofs << "scores model" << endl;
    ofs << setprecision(3) << yt11.Mean(yt11) << endl;

    ofs.close();
    cout << "end!" << endl;
    system("pause");
    return 0;
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

简易看房加权评估案例C++ 的相关文章

  • 【数据结构】【期末复习】知识点总结

    算法 线性表 概念明晰 xff1a 随机存取 顺序存取 随机存储和顺序存储 随机存取 顺序存取 随机存储和顺序存储这四个概念是完全不一样的 xff0c 切不可将之混淆 很多人包括我可能认为随机存取就是随机存储 xff0c 顺序存取就是顺序存
  • 【单片机学习】51单片机【定时/计数器】,详细介绍

    51单片机学习 一 先知先会1 CPU时序的有关知识1 1 周期换算2 在学习定时器之前需要明白的3 定时 计数器的工作原理4 51单片机定时器结构 二 定时 计数器的控制1 工作方式寄存器TMOD2 控制寄存器TCON3 定时 计数器的工
  • 【跟着江科大学Stm32】GPIO_LED_流水灯_蜂鸣器

    只要坚持下来了 xff0c 一定会有收获 xff01 一 LED闪烁 span class token macro property span class token directive hash span span class token
  • STM32F103C8T6 PWM驱动舵机(SG90)

    小知识 xff1a 同一个定时器 xff0c 不同通道输出不同输出PWM的特点 对于同一个定时器的不同通道输出PWM xff0c 因为它们是共用一个计数器的 xff0c 所以频率必须一样 xff0c 而占空比由各自的CCR决定 xff0c
  • STM32 PWM周期与频率的计算

    文章目录 STM32 PWM周期与频率的计算频率的计算占空比的计算笔记仅供自学 xff0c 用来回看复习 xff0c 不一定适合你 xff0c 如有错误请指出 STM32 PWM周期与频率的计算 TIM TimeBaseInitTypeDe
  • STM32F103C8T6 实现舵机与电机的控制 2个定时器输出不同频率的PWM

    智能小家居 舵机开门 xff0c 电机做风扇 or 拉窗帘 呼吸灯做提示 xff0c 小OLED屏幕显示当前状态 文章目录 直接上代码main cpwm hpwm cservo hservo cmotor hmotor c笔记仅供自学 xf
  • 【学习记录】Tpro遥控器_暂时取消Tpro的控制权(简易)

    文章目录 按照如下图示配置1 设置好 96 逻辑开关 96 2 选择执行该 96 逻辑开关指令 96 的 96 通道 96 3 配置成功附 xff1a 继电器与R88的接法 按照如下图示配置 1 设置好逻辑开关 2 选择执行该逻辑开关指令的
  • 【Linux】gcc编译工具,断点的设置,gdb调试

    文章目录 注意1 在gcc编译过程中一定要加入选项 96 g 96 xff1b 2 只有在代码处于 96 运行 96 中在 96 暂停 96 状态时才能查看变量值 xff1b 3 设置断点后 xff0c 程序在指定行之前停止 总结主要内容1
  • 【Linux】信号量操作函数

    文章目录 二 实验原理1 semget 函数函数作用 xff1a 参数意义 xff1a 例子 xff1a 2 semop 函数函数作用 xff1a 参数意义 xff1a struct sembuf 结构体定义如下例子 xff1a 再来个完整
  • 【Linux】# 2022 Linux 笔试主要内容 MJ_University

    2022 Linux 笔试主要内容 看前须知道 带 的都是老师复习课上提到的内容 xff0c 但不代表说一定会考哦 xff01 选择题 xff08 20分 xff09 填空题 xff08 20分 xff09 判断题 xff08 10分 xf
  • Ubuntu18.04安装AX210驱动

    Linux Support for Intel Wireless Adapters 从官网可以看到AX210支持的内核版本是5 10 43 如果要在低于5 10的内核版本上安装AX210的驱动的话 xff0c 需要安装以下方法操作 xff1
  • 【Linux】实验四 进程信号通信

    文章目录 一 实验目的二 实验内容三 实验原理1 信号3 1 1 信号的基本概念3 1 2 信号的发送 2 所涉及的系统函数调用3 2 1 fork 3 2 2 kill This is my question 3 2 3 signal 代
  • 报错.SO文件找不到

    此报错大多数可以通过设置环境变量解决 原因 xff1a 当执行函数动态链接 so时 xff0c 此文件不在缺省目录下 lib and usr lib 里 缺省 61 61 默认 解决方案 xff1a 1 find name so文件名 2
  • 头文件(.h) 和实现文件(.cpp)区别

    简单讲 xff0c 一个Package就是由同名的 h和 cpp文件组成 当然可以少其中任意一个文件 xff1a 只有 h文件的Package可以是接口或模板 template 的定义 xff1b 只有 cpp文件的Package可以是一个
  • 坚持学习100天:STL(头大的英文,一个模板库,非得写得我看不懂)

    前言 Hello 我是修齊 学习C 43 43 的第一百零一十八天 18是个美好的数字 xff0c 18岁刚刚好 xff0c 28岁也要用心学习 在这里记录一些学习的东西和学习的心情 内容主要是一些自己学习整理的小笔记 一 指针与引用 1
  • Ubuntu20.04以及ROS系统的安装(避坑指南)

    一 Ubuntu20 04的安装 暑期在我导那里确认好研究方向后 xff0c 一个人摸爬滚打走来确实走了不少弯路 xff0c 遂决定写下这篇文章来帮助有需要的朋友来避坑 本次安装是通过VMware来创建一台虚拟机进行后续操作 xff0c 之
  • Rplidar A2单线雷达实现Cartographer建图

    首先安装rplidar2 xff0c 在工作空间src目录下git clone xff0c catkin make编译后即可使用了 git clone https github com robopeak rplidar ros git 在使
  • 解决Ubuntu非root用户登录时,无法打开Firefox浏览器

    在使用Ubuntu操作系统时 xff0c 创建了一个普通用户 xff0c 登录该用户后发现无法打开Firefox浏览器 xff0c 进行如下步骤可解决问题 提示 Your Firefox profile cannot be loaded I
  • 【C语言】 链表 超详细解析

    目录 一 xff1a 静态存储和动态存储 二 xff1a 存储类别 三 xff1a malloc函数 四 xff1a free函数 五 xff1a 内存初始化函数memset 六 xff1a calloc函数 七 xff1a realloc
  • 2.stm32freeRTOS---创建一个任务

    文章目录 前言一 创建一个任务需要注意哪些 xff1f 1 任务创建函数xTaskCreate2 代码分析 二 动态 静态分配1 动态分配2 静态分配 xff1a 三 删除任务四 一个函数创建两个任务总结 前言 上一次是初步接触实时系统 x

随机推荐

  • 世界上最详细的Linux C udp实现文件传输

    最重要的是掌握UDP的基本概念和使用 UDP h span class token macro property span class token directive hash span span class token directive
  • LidarPointCloud保存PCD文件的方法

    在牵扯到Lidar点云数据相关的开发时 难免需要将LidarPointCloud数据转为PCD文件 来查看点云效果 本文介绍两种办法 1 写文件的方法 根据PCD文件的协议 本样例中使用的数据类型为ara lidar LidarPointC
  • SSD算法解析

    目标检测算法主要分为两类 xff1a Two stage方法 xff1a 如R CNN系列算法 xff0c 主要思路就是通过Selective Search或者CNN网络产生一系列的稀疏矩阵的候选区域 xff0c 然后对这些候选区域进行分类
  • Oracle获取日期&天数

    一 获取当年所有日期 span class token comment select from span span class token keyword select span trunc span class token punctua
  • Oracle where if

    一 where case when Oracle where不能如其他sql直接添加if逻辑 只能使用case when span class token keyword select span span class token opera
  • ASP.net GridView控件(删除/更新功能)

    一 说明 部分代码的运用放在以往的教程中 本部分只讲解删除 更新功能 二 前端 我们在其控件上添加事件 红色为行删除事件 绿色为行更新事件 双击后 即可在后台自动生成对应的方法体 其代码显示 lt 64 Page Language 61 3
  • ASP.net 简单登录界面

    一 说明 此文是小白在学习张晨光老师的视频教学 lt lt Asp Net WEB服务器编程技术 gt gt 中做的学习笔记 一些知识点也是跟着教程走的 大家也可以去老师的主页去学习 谢谢大家 这一篇要练习的是 如下课程的代码 新建项目 因
  • ASP.net 简单注册界面

    一 说明 此文是小白在学习张晨光老师的视频教学 lt lt Asp Net WEB服务器编程技术 gt gt 中做的学习笔记 一些知识点也是跟着教程走的 大家也可以去老师的主页去学习 谢谢大家 这一篇要练习的是 如下课程的代码 先新建img
  • oracle 一行转多行+多行转一行

    1 说明 在一行转多行时 我们多半将一张维护表分成单列的维护数据 然后再进行汇总 关联 这样能避免一些不必要的错误 一个table中 只有要拆分的数据和主键 如果要拆分多行 即将他们拆分为不同的table 2 简单的拆分 此语句是以逗号拆分
  • [vue element-ui]JAVA POST请求+eclipse创建项目

    01 前端 span class token doctype span class token punctuation lt span span class token doctype tag DOCTYPE span span class
  • [JAVA REST]REST请求

    java rest rest请求 01 说明02 前端AJAX优化03 后台的优化04 数据的处理 01 说明 本系列是对 阿发你好 JAVA教程做的个人笔记总结 如果小伙伴们有兴趣 请移步至阿发你好官网JAVA教程 保姆级视频教学 您值得
  • [Oracle]去除某行,单列重复的数据

    Oracle 去除某行 单列重复的数据 01 说明02 添加辅助列03 优先级排序04 去除重复项05 批量删除 01 说明 因为实在找不到可以模拟该方法的案例 就简单的说一下大概的数据和处理逻辑 小伙伴们懂这个逻辑就行 到实战里活学活用
  • 通过API获取rostopic list数据

    当然在终端上执行 rostopic list 会得到当前Master发布的话题信息 这就不说了 如图 那如何通过API获取rostopic list数据呢 先看效果 前提rosmaster已运行 ui部分用到了qt 相关的代码如下 cons
  • ROS学习(四)发布者与订阅者

    目录 一 发布者与订阅者通讯关系 二 发布者 1 一般创建步骤 2 配置CMakeLists txt中的编译规则 3 编译 4 设置环境变量 5 运行发布者 三 订阅者 1一般创建步骤 2 在CMakeLists txt中配置 xff0c
  • Could not find a package configuration file provided by“xxx“

    项目场景 xff1a 编译ros功能包的报错 问题描述 只要错误是 Could not find a package configuration file provided by xxx 原因分析 xff1a ROS找不到 xxx 提供的包
  • 猜数小游戏C++

    游戏简述 xff1a 一共有5组人 xff0c 每组有6个人吃点心 xff0c 每组总共有三十个点心 xff0c 先让玩家判断一共有几组 xff0c 回答正确则继续 xff0c 回答错误则继续猜 xff0c 一共有5次机会 猜不对游戏结束
  • Python画圣诞树和烟花源代码

    最近一直想让女朋友开心开心 xff0c 眼看就到圣诞了 xff0c 就想着来个不一样的 xff0c 给她画个圣诞树玩一玩 xff0c 也算是自己亲手做的 xff0c 用了心思了 看了关于画圣诞树的很多博客 xff0c 人才确实很多啊 xff
  • 学校食堂简易点餐管理系统(含用户登录且密码隐藏)C++

    系统运行步骤陈述 xff1a 运行程序进入用户登陆界面 输入账户及密码如果账户以及密码输入正确则进入系统 xff0c 显示登陆成功紧接着以下 须 按照指示输入 xff0c 所输入字母不区分大小写 进入系统后便可看见菜单选项 xff0c a
  • Windows环境下的多线程编程(上)C++

    1 为什么要用多线程 任务分解 xff1a 耗时的操作 xff0c 任务分解 xff0c 实时响应 数据分解 xff1a 充分利用多核CPU处理数据 数据流分解 xff1a 读写分流 xff0c 解耦合设计 2 并发 xff0c 进程 xf
  • 简易看房加权评估案例C++

    最近偶尔关注房子的事情 xff0c 为了方便对大量房产信息制定最符合个人需求的评估 xff0c 所以本人决定写个小东西出来 xff0c 于是今天就着手了 本人看房经验有限 xff0c 加权系数仅根据个人感官给定 xff0c 总和为100 一