标题:停车管理程序
取消只看楼主
谈心
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-9-30
结帖率:0
已结贴  问题点数:20 回复次数:0 
停车管理程序
#include<iostream>
#include<string>
#include<fstream>
#include<stack>
using namespace std;
class Car
{
private:
 string licenceplate;
 int times;
public:
 Car(string x,int y);
 string getlicence();
 int gettimes();
 void settimes();

};
string Car::getlicence()
{
 return licenceplate;
}
int Car::gettimes()
{
 return times;
}
Car::Car(string plate,int time)
{
 this->licenceplate=plate;
 this->times=time;
}
void Car::settimes()
{
 this->times++;
}

void main()
{
 //打开文件,并将数据存入数组中。
 string datas[60];
 ifstream read;
 const int maxsize=5;
 int i=0;

 read.open("data.txt");
 if(!read)
 {
  cout<<"file not open!"<<endl;
  system("pause");
  return;
 }
 for ( i=0; i<60; i++)
 {
  read>>datas[i];
 }
 read.close();
 //声明栈对象
 stack<Car*> cars;
 //循环判断是否为arrive状态
 for( i=0;i<58;i++)
 {

  if(datas[i+1]=="arrives")
  {
   //判断是否为满
   if(cars.size()==maxsize)
   {
    cout<<"Sorry PORSCHE, the lot is full!"<<endl;
    continue;
   }
   else
   {
    Car* a;
    a=new Car(datas[i],0);
    cars.push(a);
   }

  }  
  else if(datas[i+1]=="departs")
  {
   if(cars.empty()==true)
   {
    cout<<" the lot is  empty!"<<endl;
   }
   else
   {
    while((cars.top())->getlicence()!=datas[i])
    {
     cars.top()->settimes();
     cars.pop();
     if(cars.empty())
      break;
    }
    if(!cars.empty())
    {
    cars.top()->settimes();
    cout<<datas[i]<<"  was moved "<<cars.top()->gettimes()<<"  times while it was here"<<endl;
    cars.pop();
    }
   }
  }
 }
 if(cars.empty())
 {
  cout<<"stack is empty!"<<endl;
  system("pause");
  return;
 }
 cout<<cars.top()->getlicence()<<endl;
 system("pause");

}
我是编程菜鸟 ,希望高手帮我改一下这个程序,要求在挪出一辆车时,它前边的车移出后,再移入栈,。,,谢了
搜索更多相关主题的帖子: 管理程序 private include public return 
2011-09-30 20:29



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-351373-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.071717 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved