XiangTan Univ. invitational Contest 2010Allocation of Memory

纠结的模拟题

#include <stdio.h>

int q[510];

int n, m;

int a;

int b, ans;

bool put()

{

     int counter = 0;

     int check = 0;

     for (int i = 1; i <= n; i ++){

         if (!q[i]){

            counter ++;

            if (!check){

               check = i;

            }

            if (counter == b){

               for (int j = check; j <= i; j ++){

                   q[j] = a;    

               }

               ans = check;

               return true;  

            }          

         }

         else {

              check = counter = 0;     

         }

     }

     return false;

}

bool check(int s)

{

    for (int i = s+1; i <= n; i ++){

        if (q[i])return true;    

    }    

    return false;

}

void move()

{

     for (int i = 1; i <= n; i ++){

         if(q[i])

         {

              int t = i - 1;

              while(q[t] == 0 && t > 0)  t--;

              q[t+1] = q[i];

              if(t+1 != i)  q[i] = 0;

         }

     }         

}

int main()

{

    int t;

    scanf("%d", &t);

    int nc = 0;

    while (t --){

          scanf("%d %d", &n, &m);

          printf("Case %d:/n", ++nc);

          char x[10];

          for (int i = 1; i <= n; i ++){

              q[i] = 0;

          }

          for (int i = 0; i < m;i ++){

              scanf("%s", x);

              if (x[0] == 'N'){  

                 scanf("%d%d", &a, &b);

                 ans = -1;

                 if (!put()){

                    move();

                    if (put()){

                       printf("%d/n", ans);  

                    }

                    else {

                         printf("-1/n");

                    }

                 }

                 else {

                      printf("%d/n", ans);

                 }

              }

              else {

                   scanf("%d", &a);

                   for (int i = 1; i <= n; i ++){

                       if (q[i] == a){

                          q[i] = 0;         

                       }    

                   }

              }

          }    

    } 

    return 0;    

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值