zoukankan      html  css  js  c++  java
  • 面向对象程序设计 作业二

    根据作业一关于电梯作业的要求:

    文字描述C语言程序实现的步骤:

    输入n,判断几个乘客请求,输入第n个请求,建立一个电梯状态的结构体,包含电梯的层数,当前层,当前时间,目的信息,按时间顺序输入请求更新电梯目的信息,电梯当有目的为完成时继续向目的移动,到目标楼层后删除请求并弹出当前楼层和当前时间作为输出,处理完所有请求后程序结束

    C++面向对象实现的类图:

    区别

    C语言是把电梯的操作拆开成各个分开的函数和对变量的删改,按照求解的顺序调用函数得出答案

    C++面向对象则是把电梯抽象成类,各种函数和变量被封装在类中,结构更加优美,扩展性好,而且命名在类内容易识别不易冲突,公有私有成员提高了程序的安全性。

    电梯类

    .h

    #pragma once
    
    class elevator_new
    
    {
    
    public:
    
    	elevator_new(int n,int k=0);
    
    	~elevator_new();
    
    	int ask_floor();
    
    	int ask_for_state();
    
    	int update_state(int floor);//到达某一层标记
    
    	int downdate_state(int floor);//清除到达某一层标记
    
    	void run();
    
    private:
    
    	void get(int people);
    
    	void out(int people);
    
    	void MoveUp();
    
    	void MoveDowm();
    
    	int aim[50];//电梯运行的目的标记楼层
    
    	int state;//电梯运行状态 1空载2有客
    
    	int people_num;//电梯内乘客数量
    
    	int elevator_place;//电梯当前位置
    
    	int timer;//电梯当前时间
    
    };
    

    .cpp

    #include "elevator_new.h"
    
    elevator_new::elevator_new(int n,int k=0)//一个有n个连续目的楼层的电梯,起始楼层k;
    
    {
    
    state = 1;//empty
    
    for (int i = 0; i <= n; i++) {
    
    	aim[i] = 0;
    
    }
    
    elevator_place = k;
    
    }
    
    
    elevator_new::~elevator_new()
    
    {
    
    }
    
    void elevator_new::MoveDowm() {
    
    elevator_place--;
    
    }
    
    void elevator_new::MoveUp() {
    
    elevator_place++;
    
    }
    
    void elevator_new::get(int people) {
    
    people_num += people;
    
    }
    
    void elevator_new::out(int people) {
    
    people_num -= people;
    
    }
    
    int elevator_new::ask_floor() {
    
    return elevator_place;
    
    }
    
    int elevator_new::ask_for_state() {
    
    return state;
    
    }
    
    int elevator_new::update_state(int floor) {
    
    if (floor == -1) {
    
    	state = 1;
    
    	return 0;
    
    }
    
    else {
    
    	state = 2;
    
    	aim[floor] = 1;
    
    	return 1;
    
    }
    
    }
    
    int elevator_new::downdate_state(int floor) {
    
    aim[floor] = 0;
    
    bool k = 0;
    
    for (int i = 0; i <= 10; i++) {
    
    	if (aim[i] == 1)
    
    		k = 1;
    
    }
    
    if (k == 0)
    
    	state = 1;
    
    return 1;
    
    }
    
    int elevator_new::run() {
    
    }
    

    `

  • 相关阅读:
    Educational Codeforces Round 66 (Rated for Div. 2)
    数学模板整理
    多项式全家桶
    [Scoi2016]背单词(trie+贪心)
    Codeforces Round #563 (Div. 2) 划水记
    应届生秋招可能会遇到的三个问题
    基于vue(element ui) + ssm + shiro 的权限框架
    ASP.NET 分页+组合查询 练习
    登录,注册页面练习
    HTML css 样式表
  • 原文地址:https://www.cnblogs.com/passguan/p/8994931.html
Copyright © 2011-2022 走看看