首页 > 其他 > 详细

ACM-ICPC实验室20.2.22测试-动态规划

时间:2020-02-22 21:51:51      阅读:54      评论:0      收藏:0      [点我收藏+]

C.田忌赛马

直接贪心做就可以~

#include<bits/stdc++.h>
using namespace std;
const int maxn=10014;
int a[maxn],b[maxn];
int main() {
    int n;
    while(~scanf("%d",&n)) {
        for(int i=0;i<n;i++) scanf("%d",&b[i]);
        for(int i=0;i<n;i++) scanf("%d",&a[i]);
        sort(a,a+n);
        sort(b,b+n);
        int x1=0,y1=0;
        int x2=n-1,y2=n-1;
        int ans=0;
        for (int i=0;i<n;i++) {
            if (a[x1]>b[y1]) {
                ans+=100;
                x1++;
                y1++;
            }
            else if(a[x1]<b[y1]) {
                ans-=100;
                x1++;
                y2--;
            }
            else {
                if(a[x2]>b[y2]) {
                    ans+=100;
                    x2--;
                    y2--;
                }
                else if (a[x1]<b[y2]) {
                    ans-=100;
                    x1++;
                    y2--;
                }
            }
        }
        printf("%d\n",ans);
    }
    return 0;
}

D.202020

最简单的dp~

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=1e6+14;
ll dp[maxn],dp1[maxn];
int main () {
    string s;
    cin>>s;
    if (s[0]==2) dp[0]=0,dp1[0]=1;
    else dp[0]=1,dp1[0]=0;
    for (int i=1;i<s.length();i++) {
           if (s[i]==2) dp[i]=dp1[i-1],dp1[i]=dp[i-1]+1;
        else dp[i]=dp[i-1]+1,dp1[i]=dp1[i-1];
    }
    ll ans=0;
    for (int i=0;i<s.length();i++) ans+=dp[i];
    printf ("%lld\n",ans);
    return 0;
}
//2020 

 

ACM-ICPC实验室20.2.22测试-动态规划

原文:https://www.cnblogs.com/zhanglichen/p/12347261.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!