打印材料

题目大意:给出一串打印的优先级,如果打印i点但是后面有比他优先级高的,那么就将他放到后面,打印优先级高于他的。
/*
 * http://poj.org/problem?id=3125
 * 思路:找到第一个优先级最高的任务处理掉,其前面的任务插入队尾。考虑用循环队列实现 
 * 1. 为了节省空间,实际操作不移动最大优先级任务之前的任务,而是将
 *    头指针指向后面一个任务,队列循环使用。
 * 2. 已经处理掉的任务优先级设为 0
 */
#include <iostream>
using namespace std;
const int MAX_SIZE=100;
int main()
{
    int arriQue[MAX_SIZE];
    int iCases, iNum, iPosJob, iTime, iPosMax, iHead;
    int i, iMax;
    cin >> iCases;
    while (iCases--)
    {
        iTime   = 0;
        iPosMax = -1;
        cin >> iNum >> iPosJob;//输入作业的数目和我的作业的位置 
        for (i = 0; i < iNum; ++i)
        {
            cin >> arriQue[i];//输入每个作业的优先级 
        }

        while (iPosMax != iPosJob)//如果我的作业的位置不是最高的优先级的位置 
        {
            iHead   = (iPosMax+1) % iNum;  // 找到优先级最高的任务并处理          
            iMax    = arriQue[iHead];
            iPosMax = iHead;
            for (i = (iHead+1) % iNum; i != iHead;i = (i+1) % iNum)
            {
                if (arriQue[i] > iMax)
                {
                    iMax    = arriQue[i];
                    iPosMax = i;
                }
            }
            ++iTime;
            arriQue[iPosMax] = 0;// 已经处理掉的任务优先级设为 0 
        }
        cout << iTime << endl;
    }

    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值