Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1575361
  • 博文数量: 399
  • 博客积分: 8508
  • 博客等级: 中将
  • 技术积分: 5302
  • 用 户 组: 普通用户
  • 注册时间: 2009-10-14 09:28
个人简介

能力强的人善于解决问题,有智慧的人善于绕过问题。 区别很微妙,小心谨慎做后者。

文章分类

全部博文(399)

文章存档

2018年(3)

2017年(1)

2016年(1)

2015年(69)

2013年(14)

2012年(17)

2011年(12)

2010年(189)

2009年(93)

分类: LINUX

2009-12-23 14:54:57

#include
#include
#include
#include
using namespace std;
bool included(int start, int length, int key)
{
    //头交叉
    if(key>=start && key<=start+length-1)
        return true;
    //尾交叉
    if(key+length-1>=start && key+length-1<= start+length-1)
        return true;
    return false;
}
//O(n)复杂度算法
int main()
{
    string file;
    file = "service.in.txt";
    ifstream infile(file.c_str());
    if(!infile)
    {
        cerr<<"can not open the file:"<    }
    string data;
    int seatnumber,unitnum,reqnum;
    infile>>seatnumber>>unitnum;    
    int *start = new int[reqnum];
    for(int i=0;i        infile>>start[i];
    //降序
    sort(start,start+1,greater());
    vector ivec;   //胜者
    vector remain; //败者
    int acceptnumber=0;
    //第一、计算完全可以接受的套票订单的数量,最大全票数
    for(int i=0;i    {
        //第一个无冲突
        if(ivec.empty())
        {
            if(start[i]>0 && start[i]+reqnum-1 <= seatnumber)
            {
                ivec.push_back(start[i]);
                acceptnumber++;
            }
        }else{
            int count=0;
            //检测是否与已接受的冲突
            for(int index=0;index            {
                if(!included(ivec[index],unitnum,start[i]))
                    count++;
            }
            //不冲突则接受
            if(count == ivec.size())
            {
                ivec.push_back(start[i]);
                acceptnumber++;
            }else{
                remain.push_back(start[i]);
            }
        }    
    }
    //第二步、找增益路径,而不是减少路径,总的来说不能减少全票的数目
    int it1=0,it2=0;
    while(  it1!=ivec.size()  )    
    {
        while(it2!=remain.size())
        {
            if(remain[it2]             if(it1+1 != ivec.size() )
            {
                if( remain[it2]<=ivec[it1+1])  //太超前了,及早退出此层循环
                    break;
                else if( remain[it2]-unitnum>ivec[it1+1] &&            //不会与后面的产生冲突,保证是增益的
                     (remain[it2]-1)%unitnum<(ivec[it1]-1)%unitnum )  //余数较小,方便产生更多合理空隙
                        ivec[it1]=remain[it2];
            }else if( (remain[it2]-1)%unitnum<(ivec[it1]-1)%unitnum )  //余数较小,方便产生更多合理空隙
                    ivec[it1]=remain[it2];
            }
            it2++;
        }
        it1++;
    }
    //第三步、计算勉强可以接受的套票订单的数量
    vector::iterator it = ivec.begin();
    while(it != ivec.end())     
    {
        int tempval = *it +unitnum;   //注意这里可不是*it+unitnum-1哦
        //如果在两个已接受订单之间
        if(tempval+unitnum <*(it+1)&&tempval            it=ivec.insert(it+1,tempval);
        else
            it++;
    }
    int sumnumber=0,repindex;
    for(it = ivec.begin();it!=ivec.end();it++)
        sumnumber++;
    repindex = sumnumber;
    if(sumnumber < seatnumber)
    {
        int temp=1;
        while(temp        {
            ivec.insert(ivec.end(),temp);
            temp+=unitnum;
            sumnumber++;
        }
    }
    ofstream outfile("pj");
    outfile<<(sumnumber-acceptnumber)+acceptnumber*2<    for(int i=repindex;i        outfile<    for(int i=0;i        outfile<    infile.close();
    outfile.close();
    return 0;
}
阅读(1246) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~