zoukankan      html  css  js  c++  java
  • 数据结构课程设计题目十二_计算机学院学生会的打印机(优先队列)

    本文出自:http://blog.csdn.net/svitter

    题目12:计算机学院学生会的打印机(优先队列)

    小明抱怨学生会的打印机不符合FIFO的原则,看到很多在他后面来打印的同学比他先打印出来。五分钟前,小明的文件就是下一个候选的,如今小明的文件又排到了后面。学生会的同学给小明解释说,学生会的打印机不是採用传统的队列方式,而是採用一种自定义的优先队列方式:每一个要打印的文件被赋予了一个从19的优先级(9最高,1最低)。打印规定例如以下:

    将队列中要打印的文件f从队列中拿出来;

    假设在队列中有优先级高于f的文件,则不打印f,将f排到队列的最后;否则打印f

    小明知道打印新规以后,询问他的文件到底多长时间可以打印出来,如果没分文件打印的时间都是1分钟,小明的文件在打印队列中,而且不再有新的文件进入到打印队列。请你帮助小明计算一下他还须要等多长时间。建议完毕人数1人。


    加入了小元素的筛选代码


    PriorityQueue.cpp:

    //============================================================================
    // Name        : PriorityQueue.cpp
    // Author      : vit
    // Version     :
    // Copyright   : Your copyright notice
    // Description : Hello World in C++, Ansi-style
    //============================================================================
    
    #include <iostream>
    #include <stdio.h>
    #include "Queue.h"
    using namespace std;
    
    int main() {
    	Queue *q;
    	q = new Queue();
    	int i;
    	int n, m, val, num;
            int mval;
    	Node *p;
    	freopen("test", "r", stdin);
    	while(~scanf("%d%d", &n, &m))
    	{
    		num = 1;
    		for(i = 1; i <= n; i++)
    		{
    			scanf("%d", &val);
    			//printf("第%d号正在增加队列...
    ", i);
    			p = new Node(val, NULL, i);
                            if(i == m)
                            {
                                   mval = val;
                            }
    			q->push(p);
    		}
                    q->check(mval);
    
    
    		//printf("队列增加完毕。
    ");
    		while(!q->IsEmpty())
    		{
    			p = q->top();
    			//printf("当前打印的是第%d号
    ", p->num);
    			if(p->num == m)
    			{
    				printf("小明在第%d分钟打印。
    ", num);
    			}
    			q->pop();
    			num++;
    		}
    	}
    	return 0;
    }
    


    Queue.cpp:

    /*
     * Queue.cpp
     *
     *  Created on: 2014Äê6ÔÂ15ÈÕ
     *      Author: vit
     */
    
    #include <stdio.h>
    #include "Queue.h"
    
    Queue::Queue() {
    	// TODO Auto-generated constructor stub
    	this->front = this->rear = NULL;
    }
    
    bool Queue::IsEmpty(){
    	return this->rear == NULL;
    }
    
    void Queue::push(Node *n){
    	if(IsEmpty())
    	{
    		this->front = this->rear = n;
    	}
    	else
    	{
    		this->rear->next = n;
    		this->rear = n;
    	}
    	return;
    }
    
    void Queue::pop(){
    	if(IsEmpty())
    	{
    		return;
    	}
    	Node *p = this->front;
    	if(this->front == this->rear)
    	{
    		p = this->front;
    		this->front = this->rear = NULL;
    	}
    	else
    	{
    		p = this->front;
    		this->front = this->front->next;
    	}
    	delete p;
    }
    
    Node * Queue::top(){
    	if(IsEmpty()){
    		return NULL;
    	}
    	int value = this->front->value;
    	Node *p = this->front;
    	while(p->next != NULL)
    	{
    		if(p->next->value <= value)
    			p = p->next;
    		else
    		{
    			this->rear->next = this->front;
    			this->rear = p;
    			this->front = p->next;
    			p->next = NULL;
    			p = this->front;
    			value = p->value;
    		}
    	}
    	return this->front;
    }
    
    void Queue::check(int mval)
    {
        Node *p = this->front;
        Node *temp;
        while(p->next != NULL)
        {
            if(p->next->value < mval)
            {
                temp = p->next;
                p->next = p->next->next;
                delete temp;
            }
            //p指向下一个节点
            p = p->next;
        }
    }
    
    
    Queue::~Queue() {
    	// TODO Auto-generated destructor stub
    	while(!IsEmpty())
    	{
    		Node *temp;
    		temp = this->front;
    		this->front= this->front->next;
    		delete temp;
    	}
    }
    
    



    Queue.h:

    /*
     * Queue.h
     *
     *  Created on: 2014年6月15日
     *      Author: vit
     */
    
    #ifndef QUEUE_H_
    #define QUEUE_H_
    
    
    class Node
    {
    public:
        int value;
        int num;
        Node *next;
        Node()
        {
            this->value = 0;
            this->num = 0;
            this->next = 0;
        }
        Node(int value, Node *next, int num)
        {
            this->value = value;
            this->next = next;
            this->num = num;
        }
    };
    
    class Queue
    {
    public:
        Queue();
        virtual ~Queue();
    
        //method
        void push(Node *n);
        void pop();
        Node* top();
        bool IsEmpty();
        void check(int mval);
    
        //member
        Node *front;
        Node *rear;
    };
    #endif /* QUEUE_H_ */
    


  • 相关阅读:
    Go interface{}、类型断言
    相关资料
    php实践
    安装zookeeper
    对象池化,对象池
    java getResourcesAsStream()如何获取WEB-INF下的文件流
    android--SDK Manager下载Connection to http://dl-ssl.google.com refused
    Intellij idea 切换SVN路径
    Intellij Idea @Autowired取消提示
    恢复文件默认打开方式
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/3849357.html
Copyright © 2011-2022 走看看