zoukankan      html  css  js  c++  java
  • 「HNOI 2010」合唱队

    题目链接

    戳我

    (Solution)

    令:
    (f[i][j])([i,j])中最后排进去的是第i人
    (dp[i][j])([i,j])中最后排进去的是第j人

    则排头的元素即(f[i][j])有两种插入方式:

    1. (a[i]<=a[i+1])
    2. (a[i]<a[j])

    因为你在插入的时候可以放在队列两边

    所以尾部的元素即(dp[i][j])也有两种插入方式

    1. (a[j-1]<a[j])
    2. (a[i]<a[j])

    所以直接枚举(j)转移就好了,复杂度为(O(n^2))

    Code

    #include<bits/stdc++.h>
    #define rg register
    #define int long long
    #define file(x) freopen(x".in","r",stdin);freopen(x".out","w",stdout);
    using namespace std;
    const int mod=19650827;
    int read(){
        int x=0,f=1;
        char c=getchar();
        while(c<'0'||c>'9') f=(c=='-')?-1:1,c=getchar();
        while(c>='0'&&c<='9') x=x*10+c-48,c=getchar();
        return f*x;
    }
    int f[1001][1001],dp[1001][1001],a[1001];
    main(){
        int n=read();
        for(int i=1;i<=n;i++)
            a[i]=read();
        for(int i=1;i<=n;i++)
            f[i][i]=1;
        for(int i=n;i>=1;i--)
            for(int j=i+1;j<=n;j++){
                if(a[i+1]>a[i])
                    f[i][j]+=f[i+1][j];
                if(a[j]>a[j-1])
                    dp[i][j]+=dp[i][j-1];
                if(a[i]<a[j])
                    f[i][j]+=dp[i+1][j],dp[i][j]+=f[i][j-1];
                f[i][j]%=mod,dp[i][j]%=mod;
            }
        printf("%lld",(f[1][n]+dp[1][n])%mod);
    }
    
  • 相关阅读:
    Mybatis使用resultType实现一对一查询
    利用webSocket使网页和服务器通信
    hdu--1728--special bfs
    hdu--1429--状压bfs
    hdu--3006--不知为何wa
    hdu--3001--类似旅行商<tsp>
    hdu--2660--二维费用背包
    hdu--4632--dp
    hdu--4497--数论
    hdu--4496--并查集
  • 原文地址:https://www.cnblogs.com/hbxblog/p/10253422.html
Copyright © 2011-2022 走看看