zoukankan      html  css  js  c++  java
  • BZOJ:1609: [Usaco2008 Feb]Eating Together麻烦的聚餐

    Description

    为了避免餐厅过分拥挤,FJ要求奶牛们分3批就餐。每天晚饭前,奶牛们都会在餐厅前排队入内,按FJ的设想所有第3批就餐的奶牛排在队尾,队伍的前端由设定为第1批就餐的奶牛占据,中间的位置就归第2批就餐的奶牛了。由于奶牛们不理解FJ的安排,晚饭前的排队成了一个大麻烦。 第i头奶牛有一张标明她用餐批次D_i(1 <= D_i <= 3)的卡片。虽然所有N(1 <= N <= 30,000)头奶牛排成了很整齐的队伍但谁都看得出来,卡片上的号码是完全杂乱无章的。 在若干次混乱的重新排队后,FJ找到了一种简单些的方法:奶牛们不动,他沿着队伍从头到尾走一遍把那些他认为排错队的奶牛卡片上的编号改掉,最终得到一个他想要的每个组中的奶牛都站在一起的队列,例如111222333或者333222111。哦,你也发现了,FJ不反对一条前后颠倒的队列,那样他可以让所有奶牛向后转,然后按正常顺序进入餐厅。 你也晓得,FJ是个很懒的人。他想知道,如果他想达到目的,那么他最少得改多少头奶牛卡片上的编号。所有奶牛在FJ改卡片编号的时候,都不会挪位置。

    Input

    第1行: 1个整数:N 第2..N+1行: 第i+1行是1个整数,为第i头奶牛的用餐批次D_i

    Output

    第1行: 输出1个整数,为FJ最少要改几头奶牛卡片上的编号,才能让编号变成他设想中的样子

    Sample Input

    5
    1
    3
    2
    1
    1
    输入说明:

    队列中共有5头奶牛,第1头以及最后2头奶牛被设定为第一批用餐,第2头奶牛的预设是第三批用餐,第3头则为第二批用餐。

    Sample Output

    1

    输出说明:

    如果FJ想把当前队列改成一个不下降序列,他至少要改2头奶牛的编号,一种可行的方案是:把队伍中2头编号不是1的奶牛的编号都改成1。不过,如果FJ选择把第1头奶牛的编号改成3就能把奶牛们的队伍改造成一个合法的不上升序列了。
     
     
     
    这东西……就是个DP
    用dp[i][j]表示前i个数最后一个数为j时的最少更改次数,升降各做一遍,然后随手还可以滚动一下,把空间压到O(1)。
    SXt的代码鲁棒性一点都不好……

    (用的云神的号)

    #include<cstdio>
    #include<algorithm>
    using namespace std;
    
    const int INF=100000000;
    int n,m,dp[2][3],dq[2][3];
    int main(){
     scanf("%d",&n);
     for (int i=1;i<=n;i++){
      scanf("%d",&m);
      m--;
      for (int j=m;j<3;j++) dp[0][m]=min(dp[1][j],dp[0][m]);
      for (int j=0;j<3;j++)
      if (j!=m){
       dp[0][j]=dp[1][j]+1;
       for (int k=j+1;k<3;k++) dp[0][j]=min(dp[0][j],dp[1][k]+1);
      }
      for (int j=0;j<3;j++) dp[1][j]=dp[0][j],dp[0][j]=INF;
      for (int j=0;j<=m;j++) dq[0][m]=min(dq[1][j],dq[0][m]);
      for (int j=0;j<3;j++)
      if (j!=m){
       dq[0][j]=dq[1][j]+1;
       for (int k=0;k<j;k++) dq[0][j]=min(dq[0][j],dq[1][k]+1);
      }
      for (int j=0;j<3;j++) dq[1][j]=dq[0][j],dq[0][j]=INF;
     }
     printf("%d
    ",min(min(dp[1][0],min(dp[1][1],dp[1][2])),min(dq[1][0],min(dq[1][1],dq[1][2]))));
    }
    
     
  • 相关阅读:
    C#删除只读文件
    在超链接href中实现form的提交
    C#中复制数组
    C#判断字符串中是否包含一个子字符串是可以直接使用Contains()方法
    C#使用System.xml.linq来生成XML文件
    C# 获取SHA256码
    C#中要使ListBox使用AddRange()时,能够触发SelectedValueChanged事件
    报错:[Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop's value. Prop bei
    elementUI el-select 中disabled设置
    实现element-ui中table点击一行展开
  • 原文地址:https://www.cnblogs.com/Enceladus/p/4979001.html
Copyright © 2011-2022 走看看