第八周 项目2-Time类中的运算符

本文详细介绍了如何在C++中实现Time类中的运算符重载,包括比较运算符、加减运算符以及赋值运算符。通过重载运算符,我们可以方便地进行时间的比较、加减操作和赋值操作。
/* 
 * Copyright (c) 2014, 烟台大学计算机学院 
 * All rights reserved. 
 * 文件名称:test.cpp 
 * 作    者:呼亚萍 
 * 完成日期:2015年4月25日 
 * 版 本 号:v1.0 
 * 
 * 问题描述:实现Time类中的运算符重载。
 * 程序输入:相应的程序
 * 程序输出:对应得结果
 */

#include <iostream>

using namespace std;
class CTime
{
private:
    unsigned short int hour;//时
    unsigned short int minute;//分
    unsigned short int second;//秒
public:
    CTime(int h=0,int m=0,int s=0);
    void setTime(int h,int m,int s);
    void display();
    //二目的比较运算符重载
    bool operator>(CTime &t);
    bool operator<(CTime &t);
    bool operator>=(CTime &t);
    bool operator<=(CTime &t);
    bool operator==(CTime &t);
    bool operator!=(CTime &t);
    //二目的加减运算的重载
    CTime operator+(CTime &t);
    CTime operator-(CTime &t);
    CTime operator+(int s);//返回s秒后的时间
    CTime operator-(int s);
    //二目赋值运算符的重载
    CTime operator+=(CTime &t);
    CTime operator-=(CTime &t);
    CTime operator+=(int s);//返回s秒后的时间
    CTime operator-=(int s);
};
CTime::CTime(int h,int m,int s)
{
    hour=h;
    minute=m;
    second=s;
}
void  CTime::setTime(int h,int m,int s)
{
    hour=h;
    minute=m;
    second=s;
}
bool CTime::operator>(CTime &t)
{
    if(hour>t.hour)return true;
    if(hour<t.hour)return false;
    if(minute>t.minute)return true;
    if(minute<t.minute)return false;
    if(second>t.second)return true;
    if(second<t.second)return false;
}
bool CTime::operator<(CTime &t)
{
    if(hour<t.hour)return true;
    if(hour>t.hour)return false;
    if(minute<t.minute)return true;
    if(minute>t.minute)return false;
    if(second<t.second)return true;
    if(second>t.second)return false;
}
bool CTime::operator==(CTime &t)
{
    if((hour==t.hour)&&(minute==t.minute)&&(second==t.second))
        return true;
    else return false;
}
bool CTime::operator>=(CTime &t)
{
    if(*this<t)//可以直接使用重载了的运算实现新运算
        return false;
    else return true;
}
bool CTime::operator<=(CTime &t)
{
    if(*this>t)//可以直接使用重载了的运算实现新运算
        return false;
    else return true;
}
bool CTime::operator!=(CTime &t)
{
    if(*this==t)//可以直接使用重载了的运算实现新运算
        return false;
    else return true;
}
CTime CTime::operator+(CTime &t)
{
    CTime c;
    c.hour=hour+t.hour;
    c.minute=minute+t.minute;
    c.second=second+t.second;
    if(c.second>59)
    {
        c.second=c.second%60;
        c.minute++;
    }
    if(c.minute>59)
    {
        c.minute=c.minute%60;
        c.hour++;
    }
    if(c.hour>23)
    {
        c.hour=c.hour-24;
    }
    return c;
}
CTime CTime::operator+(int s)
{
    int ss=s%60;
    int mm=(s/60)%60;//防止分钟数大于60
    int hh=(s/3600);
    CTime c(ss,mm,hh);
    return (*this+c);//this指针的简便与神奇之处
}
CTime CTime::operator-(CTime &t)
{
    int h=hour-t.hour;
    int m=minute-t.minute;
    int s=second-t.second;
    if(s>59)
    {
        s=s%60;
        m++;
    }
    if(m>59)
    {
        m=m%60;
        h++;
    }
    if(h>23)
    {
        h=h-24;
    }
}
CTime CTime::operator-(int s)
{
    int ss=s%60;
    int mm=(s/60)%60;//防止分钟数大于60
    int hh=(s/3600);
    CTime c(ss,mm,hh);
    return (*this-c);
}
CTime CTime::operator+=(CTime &t)
{
    *this=*this+t;
    return *this;
}
CTime CTime::operator-=(CTime &t)
{
    *this=*this-t;
    return *this;
}
CTime CTime::operator+=(int s)
{
    *this=*this+s;
    return *this;
}
CTime CTime::operator-=(int s)
{
    *this=*this-s;
    return *this;
}
void CTime::display()
{
    cout<<hour<<":"<<minute<<":"<<second<<endl;
}
int main()
{
    CTime t1(8,20,25),t2(11,20,50),t;
    cout<<"t1=";
    t1.display();
    cout<<"t2=";
    t2.display();
    cout<<"下面比较两个时间大小:"<<endl;
    if(t1>t2)cout<<"t1>t2"<<endl;
    if(t1<t2)cout<<"t1<t2"<<endl;
    if(t1>=t2)cout<<"t1>=t2"<<endl;
    if(t1<=t2)cout<<"t1<=t2"<<endl;
    if(t1==t2)cout<<"t1==t2"<<endl;
    if(t1!=t2)cout<<"t1!=t2"<<endl;
    cout<<endl;
    t=t1+t2;
    t=t1-t2;
    t=t1+2000;
    t=t1-5000;
    t1+=t2;
    t1-=t2;
    t1+=2000;
    t1-=5000;
    return 0;
}



运算结果:

知识点总结:

可以直接使用重载了的运算实现新运算,善于使用this指针。

学习心得:

体会到了this指针的简便与神奇之处。

考虑柔性负荷的综合能源系统低碳经济优化调度【考虑碳交易机制】(Matlab代码实现)内容概要:本文围绕“考虑柔性负荷的综合能源系统低碳经济优化调度”展开,重点研究在碳交易机制下如何实现综合能源系统的低碳化与经济性协同优化。通过构建包含风电、光伏、储能、柔性负荷等多种能源形式的系统模型,结合碳交易成本与能源调度成本,提出优化调度策略,以降低碳排放并提升系统运行经济性。文中采用Matlab进行仿真代码实现,验证了所提模型在平衡能源供需、平抑可再生能源波动、引导柔性负荷参与调度等方面的有效性,为低碳能源系统的设计与运行提供了技术支撑。; 适合人群:具备一定电力系统、能源系统背景,熟悉Matlab编程,从事能源优化、低碳调度、综合能源系统等相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①研究碳交易机制对综合能源系统调度决策的影响;②实现柔性负荷在削峰填谷、促进可再生能源消纳中的作用;③掌握基于Matlab的能源系统建模与优化求解方法;④为实际综合能源项目提供低碳经济调度方案参考。; 阅读建议:建议读者结合Matlab代码深入理解模型构建与求解过程,重点关注目标函数设计、约束条件设置及碳交易成本的量化方式,可进一步扩展至多能互补、需求响应等场景进行二次开发与仿真验证。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值