- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我从命令行参数中读入,它们如下:
0.5 3 10 50
maxClock 是最后一个参数,在本例中为 50。然后我有一个这样的 for 循环:
for(int k = 1; k < maxClock; k++)
{
<code>
}
但是无论出于何种原因,我的程序都不会计数到 k。有时它只会数到 9,然后是 34,然后是 14,等等......我不知道发生了什么。有人可以给我另一种观点吗?
代码如下:
/* * 驱动.cpp
*
* This program simulates a bank with customers walking in for service and seeing tellers.
* This program implements a classic Queue style system.
*
* Disclaimer:
*
* - For some reason, the program will not run up until the time maxClock given in the command line arguments.
* This prevents the program from being able to print out the averageQueue length, maxQueueLength, etc at the
* bottom right after the for-loop.
*
*
*
*/
////////////////////////////////////////////////////////////////////
///Includes///
////////////////////////////////////////////////////////////////////
#include <iostream>
#include <vector>
#include <cstdlib>
#include "Queue.h"
#include "Customer.h"
#include "QueueNode.h"
#include "Teller.h"
using namespace std;
int main(int argc, char *argv[])
{
srand(time(NULL)); //seeds the random time generator
if(argc != 5)
{
cout << "You must enter at least 5 command line arguments " << endl;
exit(1);
}
/******************Command Line Args-Variables***************************/
double p = atof(argv[1]);
int numTellers = atoi(argv[2]); //number of the tellers (M)
int maxService = atoi(argv[3]);
int maxClock = atoi(argv[4]); //simulation time (N)
/******************Local Variables***************************/
int numberOfCustomers = 0;
int serv;
int randProb;
int totalWait;
unsigned long long AverageWaitTime;
int customerWillBeFinished;
int maxQLength;
int counter;
int AverageQueueLength;
int wait;
int individualWaitTime;
int OtherThanK;
int a = 10000;
//Displays to user to double checks to make sure you entered in the arguments correctly
cout << "------------------------------------------------------------" << endl;
cout << "These are the arguments that you gave the program: " << endl;
cout << endl;
cout << "The p value is: " << p << endl;
cout << "The number of tellers: " << numTellers << endl;
cout << "The max service time is: " << maxService << endl;
cout << "The max clock is: " << maxClock << endl;
cout << endl;
cout << "------------------------------------------------------------" << endl;
cout << "\n";
/******************Declaration of Queue & Vector***************************/
Queue<Customer> line;
vector<Teller> teller(numTellers);
//loop to go through entire clock until the maxClock is reached
for(int k = 1; k < maxClock; k++)
{
OtherThanK = k;
randProb = ((rand() % 100) + 1); //generates a random number seeded with system time
if(randProb < p*100)
{
serv = ((rand() % maxService) + 1); //generates a random number seeded with system time
Customer customer(OtherThanK, serv); //passes in current time and service time (randomizeD)
line.enqueue(customer); //pushes a customer onto the Queue.
cout << "Customer arriving in queue at time: " << OtherThanK << endl;
}
customerWillBeFinished = serv + OtherThanK + 1;
for(int i = 0; i < numTellers; i++)
{
if(teller[i].isFree() && (!line.isempty())) //checks to see if a teller is empty
{
cout << "Teller " << i << " is now free." << endl;
Customer frontCustomer; //declares a customer called frontCustomer. This is the customer who is at the front of the Queue.
line.dequeue(frontCustomer); //pulls off a customer from the Queue.
wait = OtherThanK - frontCustomer.getArrivalTime();
numberOfCustomers++; //increases by 1 each time through to keep tracking of the # of Customers.
totalWait = totalWait + wait;
cout << "Customer going to teller " << i << " at time " << frontCustomer.getArrivalTime() << endl; //retrieves arrival time
cout << "This customer had to wait in line for " << wait << " minutes." << endl; //labs() is a function used to determine absolute value
cout << "This customer will require " << serv << " minutes of service" << endl;
teller[i].addCustomer(frontCustomer);
line.remove(frontCustomer); //once cycled through, removes the customer from the Queue.
}
}
cout << endl;
cout << "Time is: "<< k << endl;
cout << " \n Number of customers: " << numberOfCustomers << " " << "Total wait so far: " << std::labs(totalWait) << endl; //labs() is a function used to determine absolute value
}
///////// WON'T PRINT ANY OF THIS OUT BECAUSE IT WONT EXIT LOOP ///////
cout << "test" <<endl;
AverageWaitTime = totalWait/numberOfCustomers;
cout << "Average wait time is: " << AverageWaitTime*a << endl;
maxQLength = line.getLength();
cout << "The max Queue length is " << maxQLength << endl;
AverageQueueLength = maxQLength/OtherThanK;
cout << "The Average Queue Length is " << AverageQueueLength;
}
输出示例:(每次都变,这次统计到20):
------------------------------------------------------------
These are the arguments that you gave the program:
The p value is: 0.5
The number of tellers: 3
The max service time is: 10
The max clock is: 50
------------------------------------------------------------
Max Clock is 50
Time is: 0
Number of customers: 0 Total wait so far: 0
Max Clock is 50
Time is: 1
Number of customers: 0 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 2
Teller 0 is now free.
Customer going to teller 0 at time 2
This customer had to wait in line for 0 minutes.
This customer will require 4 minutes of service
Time is: 2
Number of customers: 1 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 3
Teller 1 is now free.
Customer going to teller 1 at time 3
This customer had to wait in line for 0 minutes.
This customer will require 10 minutes of service
Time is: 3
Number of customers: 2 Total wait so far: 0
Max Clock is 50
Time is: 4
Number of customers: 2 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 5
Teller 2 is now free.
Customer going to teller 2 at time 5
This customer had to wait in line for 0 minutes.
This customer will require 7 minutes of service
Time is: 5
Number of customers: 3 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 6
Teller 0 is now free.
Customer going to teller 0 at time 6
This customer had to wait in line for 0 minutes.
This customer will require 2 minutes of service
Time is: 6
Number of customers: 4 Total wait so far: 0
Max Clock is 50
Time is: 7
Number of customers: 4 Total wait so far: 0
Max Clock is 50
Time is: 8
Number of customers: 4 Total wait so far: 0
Max Clock is 50
Time is: 9
Number of customers: 4 Total wait so far: 0
Max Clock is 50
Time is: 10
Number of customers: 4 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 11
Teller 0 is now free.
Customer going to teller 0 at time 11
This customer had to wait in line for 0 minutes.
This customer will require 8 minutes of service
Time is: 11
Number of customers: 5 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 12
Teller 2 is now free.
Customer going to teller 2 at time 12
This customer had to wait in line for 0 minutes.
This customer will require 5 minutes of service
Time is: 12
Number of customers: 6 Total wait so far: 0
Max Clock is 50
Time is: 13
Number of customers: 6 Total wait so far: 0
Max Clock is 50
Time is: 14
Number of customers: 6 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 15
Teller 1 is now free.
Customer going to teller 1 at time 15
This customer had to wait in line for 0 minutes.
This customer will require 10 minutes of service
Time is: 15
Number of customers: 7 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 16
Time is: 16
Number of customers: 7 Total wait so far: 0
Max Clock is 50
Customer arriving in queue at time: 17
Teller 2 is now free.
Customer going to teller 2 at time 16
This customer had to wait in line for 1 minutes.
This customer will require 2 minutes of service
Time is: 17
Number of customers: 8 Total wait so far: 1
Max Clock is 50
Time is: 18
Number of customers: 8 Total wait so far: 1
Max Clock is 50
Time is: 19
Number of customers: 8 Total wait so far: 1
Max Clock is 50
Time is: 20
Number of customers: 8 Total wait so far: 1
Max Clock is 50
Customer arriving in queue at time: 21
Teller 0 is now free.
Customer going to teller 0 at time 21
This customer had to wait in line for 0 minutes.
This customer will require 10 minutes of service
Customer.h 类:
/*
* Customer.h
*
*/
#ifndef CUSTOMER_H_
#define CUSTOMER_H_
#include <iostream>
#include "QueueNode.h"
#include "Queue.h"
#include "Teller.h"
#include <cstdlib>
using namespace std;
class Customer
{
public:
int serviceTime;
int arrivalTime;
Customer()
{
serviceTime = 0;
arrivalTime = 0;
}
Customer(int arrival, int maxService)
{
arrivalTime = arrival;
serviceTime = maxService;
}
int getServiceTime()
{
return serviceTime;
}
bool isDone()
{
serviceTime--;
return serviceTime <= 0;
}
int getArrivalTime()
{
return arrivalTime;
}
void MinutePasses()
{
serviceTime--;
}
};
#endif /* CUSTOMER_H_ */
Teller.h 类:
/*
*
*/
#ifndef TELLER_H_
#define TELLER_H_
#include <iostream>
#include "Customer.h"
#include "QueueNode.h"
#include "Queue.h"
using namespace std;
class Teller
{
private:
//bool isOccupied;
Customer customer;
protected:
bool free;
public:
Teller()
{
//isOccupied = false;
free = true;
}
bool isFree()
{
//return free; - > B C
if(!free)
{
customer.serviceTime--;
if(customer.serviceTime == 0)
{
free = true;
return true;
}
else return false;
}
{
return true;
}
}
void addCustomer(Customer C)
{
customer = C;
free = false;
}
void CustMinutePasses()
{
if(!free)
{
customer.MinutePasses();
}
}
Customer & getCustomer()
{
return customer;
}
void setAvailability(bool b)
{
free = b;
}
/*
void setAvailability(bool b)
{
free = b;
}
*/
};
#endif /* TELLER_H_ */
最佳答案
程序确实应该运行到 maxclock-1 (!),除非它因为错误而崩溃(或挂起)。循环中没有其他条件,您似乎没有更改循环索引或边界。
当我使用我在 http://www.cplusplus.com/forum/general/71229/ 中找到的经过调整的队列实现来运行它时,它似乎可以正常工作。 .
由于您不提供队列实现,因此队列可能是错误的来源。
一个可能的原因:我注意到您然后移除 frontCustomer。作为出列的一部分,“我的”队列实现从队列中删除了第一个元素。我使用的原始队列实现没有提供 remove();由于您的方法需要一个参数,因此我假设它将使用默认的运算符==()在整个队列中搜索该特定元素。我不知道当该元素不存在时您的队列会做什么,尤其是当队列为空时。
@Damien Black:完全错了。请修复您的评论。你会因为它而在 comp.lang.c++ 上被贬低,cf。 https://groups.google.com/d/msg/comp.lang.c++/3d9ts9JuA-Q/6PtGSoXSIHQJ
C++ 按值传递,除非形式参数在函数签名中通过前缀 & 符号指定为引用。您可能会将语义与 C# 混淆。
虽然 C# 通过引用处理类,但这些引用是按值 (!) 传递的,除非您限定形参和实参“ref”。
关于c++ - 有人能告诉我为什么我的 for() 循环不会一直计数吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21924885/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!