Codeforces Round #650 (Div. 3) D,E,F1,F2

题目:D
题意:从一个字符串s中删除一些字符或者不删,构成t字符串,保证t[i]的价值等于b[i],t[i]的价值计算就是t字符串中所有的位置如果t[j]>t[i],那么t[i]的价值就加上abs(i-j)。保证一定有答案。

首先可以考虑到,b[i]的最小值0肯定是t中最大的字符,未产生任何贡献,往后的字符产生的贡献都是一定需要比他大的字符,考虑到数据很小直接暴力。但是同一个字符可能产生多次不然放置不成功,或者这个字符不能放置多次我不能放他,本质其实就是放置最大的个数是多少,次大的是多少,以此类推,最后转化为字符即可。
(代码比较丑)

#include<cmath>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cstdlib>
#include<istream>
#include<vector>
#include<stack>
#include<set>
#include<map>
#include<algorithm>
#include<queue>
#define inf 0x3f3f3f3f
#define llinf 0x3f3f3f3f3f3f3f3f
#define MAX_len 200005*4
using namespace std;
typedef long long ll;
typedef pair<int,int> PP;
const int mod=998244353;
const int MAXlen=1e5+10;
long double eps=1e-9;
char s[55];
int b[110];
int book[30];
int c[110];
bool vis[60];
char ans[60];
int book1[60];
int main()
{
    int T;
    scanf("%d",&T);
    while(T--)
    {
        memset(book,0,sizeof(book));
        memset(book1,0,sizeof(book1));
        scanf("%s",s);
        int n,i,j;
        n=strlen(s);
        int m;
        scanf("%d",&m);
        for(i=1;i<=m;i++)
        {
            scanf("%d",&b[i]);
            c[i]=b[i];
        }
        for(i=0;i<n;i++)
        {
            book[s[i]-'a']++;
        }
        memset(vis,false,sizeof(vis));
        sort(c+1,c+1+m);
        int hh=c[1];
        memset(c,0,sizeof(c));
        int cnt=0;
        int tempdj=1;
        for(i=1;i<=m;i++)
        {
            if(vis[i])
                continue;
            if(b[i]==hh)
            {
                for(j=25;j>=0;j--)
                {
                    if(book[j])
                    {
                        vis[i]=true;
                        cnt++;
                        book1[i]=tempdj;
                        c[tempdj]++;
                        break;
                    }
                }
            }
        }
       tempdj++;
        while(cnt<m)
        {
            for(i=1;i<=m;i++)
            {
                if(vis[i])
                    continue;
                int sum=0;
                for(j=1;j<=m;j++)
                {
                    if(!vis[j]||j==i)
                        continue;
                    if(book1[j]<tempdj)
                    {
                        sum+=abs(j-i);
                    }
                }
                if(sum==b[i])
                {
                    vis[i]=true;
                    cnt++;
                    book1[i]=tempdj;
                    c[tempdj]++;
                    break;
                }
                sum=0;
                tempdj++;
                for(j=1;j<=m;j++)
                {
                    if(!vis[j]||j==i)
                        continue;
                    if(book1[j]<tempdj)
                    {
                        sum+=abs(j-i);
                    }
                }
                if(sum==b[i])
                {
                    vis[i]=true;
                    cnt++;
                    book1[i]=tempdj;
                    c[tempdj]++;
                    break;
                }
                tempdj--;
            }
        }
        int k=25;
        for(i=1;i<=m;i++)
        {
            while(book[k]<c[i])
            {
                k--;
            }
            for(j=1;j<=m;j++)
            {
                if(book1[j]==i)
                {
                    ans[j]='a'+k;
                }
            }
            k--;
        }
 
        for(i=1;i<=m;i++)
            printf("%c",ans[i]);
        printf("\n");
    }
    return 0;
}

题目:E
题意:给定n个元素,组成一条项链,顺时针转完k之后不变,问最大长度。

数据范围不大,可以暴力。先分析,k不变的话,那么当len%k!=0的时候全部一样才行。len%k=0的时候,要保证每个相同的字符串有n/k个并且数量大于k则成立,当k%len=0的时候,则直接是len。
将k拆分,直接枚举len。

#include<cmath>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cstdlib>
#include<istream>
#include<vector>
#include<stack>
#include<set>
#include<map>
#include<algorithm>
#include<queue>
#define inf 0x3f3f3f3f
#define llinf 0x3f3f3f3f3f3f3f3f
#define MAX_len 200005*4
using namespace std;
typedef long long ll;
typedef pair<int,int> PP;
const int mod=998244353;
const int MAXlen=1e5+10;
long double eps=1e-9;
char s[2020];
int main()
{
    int T;
    scanf("%d",&T);
    while(T--)
    {
        vector<int>hh;
        int book[30]={0};
        int n,k,i,j;
        scanf("%d %d",&n,&k);
        scanf("%s",s);
        for(i=1;i*i<=k;i++)
        {
            if(k%i==0)
            {
                hh.push_back(i);
                hh.push_back(k/i);
            }
        }
        int MAX=0;
        for(i=0;i<n;i++)
        {
            book[s[i]-'a']++;
            MAX=max(MAX,book[s[i]-'a']);
        }
        //for(i=0;i<26;i++)
        {
        //   printf("%d ",book[i]);
        }
      //  return 0;
        for(i=1;i<=n;i++)
        {
            for(j=0;j<hh.size();j++)
            {
                    int sum=0;
                    if(i%hh[j]==0)
                    {
                        int temp=i/hh[j];
                        for(int u=0;u<26;u++)
                        {
                            if(book[u]>=temp)
                            {
                                sum+=book[u]/temp;
                            }
                        }
                        if(sum>=hh[j])
                        {
                            MAX=max(MAX,i);
                        }
                    }
                    if(hh[j]%i==0)
                    {
                        MAX=max(i,MAX);
                    }
            }
        }
        printf("%d\n",MAX);
    }
    return 0;
}

题目:F1
题意:n长度的数据,每次可以操作,将a[i]置于数组最前或者最后,问最小次数使得a非递减。

分析数据,已经自己有序的子序列我们可以不管,只需要去解决乱序的,其实也就是找最长的连续的子序列。数据不大并且保证每个数据都不相同,暴力。证明的话就是贪心策略,这里的连续表示已经排好序的数据连在一起的,先做一个离散化。

#include<cmath>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cstdlib>
#include<istream>
#include<vector>
#include<stack>
#include<set>
#include<map>
#include<algorithm>
#include<queue>
#define inf 0x3f3f3f3f
#define llinf 0x3f3f3f3f3f3f3f3f
#define MAX_len 200005*4
using namespace std;
typedef long long ll;
typedef pair<int,int> PP;
const int mod=998244353;
const int MAXlen=1e5+10;
long double eps=1e-9;
int a[3020],c[3020];
int dp[3020];
int main()
{
    int T;
    scanf("%d",&T);
    while(T--)
    {
        int n,i,j;
        scanf("%d",&n);
        for(i=0;i<n;i++)
        {
            scanf("%d",&a[i]);
            c[i]=a[i];
        }
        sort(c,c+n);
        for(i=0;i<n;i++)
        {
            for(j=0;j<n;j++)
            {
                if(a[j]==c[i])
                {
                    a[j]=i;
                    break;
                }
            }
        }
        for(i=0;i<n;i++)
        {
            dp[i]=1;
            for(j=0;j<i;j++)
            {
                if(a[i]-a[j]==1)
                {
                    dp[i]=max(dp[i],dp[j]+1);
                }
            }
        }
        int MAX=1;
        for(i=0;i<n;i++)
            MAX=max(MAX,dp[i]);
        printf("%d\n",n-MAX);
    }
    return 0;
}

F2
比F1的数据范围更大,并且存在了相同的数。

思路来源:click
离散化。
本质上0就是开头,2就是结尾的意思。
dp[i][0]:全是a[i],以a[i]结尾的序列。
dp[i][1]:a[i]还没有放完继续接,或者接a[i]-1开头,或者把a[i]-1全部接走。
dp[i][2]:接走全部的a[i],并且最后一个a[i]结束。

#include<cmath>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cstdlib>
#include<istream>
#include<vector>
#include<stack>
#include<set>
#include<map>
#include<algorithm>
#include<queue>
#define inf 0x3f3f3f3f
#define llinf 0x3f3f3f3f3f3f3f3f
#define MAX_len 200005*4
using namespace std;
typedef long long ll;
typedef pair<int,int> PP;
const int mod=998244353;
const int MAXlen=1e5+10;
long double eps=1e-9;
int a[200100],c[200100];
int pos[200100];
int dp[200100][3];// 0表示取相同的数以a[i]为结尾 1表示a[i]没取完  2表示a[i]全部取完以其结尾的最大长度
int main()
{
    int T;
    scanf("%d",&T);
    while(T--)
    {
        map<int,int>hh,cnt;
        map<int,PP>h;
        int n,i,j;
        int len=0;
        scanf("%d",&n);
        int MAX=1;
        pos[0]=0;

        for(i=0;i<=n;i++)
        {
            dp[i][0]=dp[i][1]=dp[i][2]=0;
            pos[i]=0;
        }
        for(i=1;i<=n;i++)
        {
            scanf("%d",&a[i]);
            if(!hh[a[i]])
            {
                c[++len]=a[i];
                hh[a[i]]=1;
            }
        }
        hh.clear();
        sort(c+1,c+len+1);
        for(i=1;i<=n;i++)
        {
            a[i]=lower_bound(c+1,c+len+1,a[i])-c;
        }
        for(i=1;i<=n;i++)
        {
            cnt[a[i]]++;
            MAX=max(cnt[a[i]],MAX);
            if(!hh[a[i]])
            {
                hh[a[i]]=1;
                h[a[i]].first=i;
                h[a[i]].second=i;
                pos[a[i]]=i;
            }
            else
            {
                h[a[i]].second=i;
            }
        }
        for(i=1;i<=n;i++)
        {
            dp[i][0]=dp[pos[a[i]]][0]+1;
            dp[i][1]=max(dp[pos[a[i]]][1]+1,max(dp[pos[a[i]-1]][0]+1,dp[pos[a[i]-1]][2]+1));
            if(i==h[a[i]].second)
            {
                dp[i][2]=dp[h[a[i]].first][1]+cnt[a[i]]-1;
            }
            pos[a[i]]=i;
            for(j=0;j<3;j++)
            {
                MAX=max(MAX,dp[i][j]);
            }
        }
        printf("%d\n",n-MAX);
    }
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip
综合小区管理系统管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、车位管理、车位分配管理、出入管理、字典管理、房屋管理、物业费缴纳管理、公告管理、物业人员投诉管理、我的私信管理、物业人员管理、用户管理、管理员管理。用户的功能包括管理部门以及部门岗位信息,管理招聘信息,培训信息,薪资信息等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 综合小区管理系统管理系统可以提高综合小区管理系统信息管理问题的解决效率,优化综合小区管理系统信息处理流程,保证综合小区管理系统信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理综合小区管理系统信息,包括出入管理,报修管理,报修管理,物业费缴纳等,可以管理操作员。 出入管理界面,管理员在出入管理界面中可以对界面中显示,可以对招聘信息的招聘状态进行查看,可以添加新的招聘信息等。报修管理界面,管理员在报修管理界面中查看奖罚种类信息,奖罚描述信息,新增奖惩信息等。车位管理界面,管理员在车位管理界面中新增。公告管理界面,管理员在公告管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值