CF思维训练,2020长春CCPC(A,D)

news2025/1/15 16:30:41

D. Knowledge Cards(华容道GAME)

题意:给定n*m的矩阵,初始在左上角有一摞牌,从上到下每张的数字构成了一个长度为k的排列,请问在保证1.不能使得牌在移动过程中重叠2.不能让牌反复出现在左上和右下角。这两个条件下,能否将所有的卡牌通过移动来使得最终摞在右下角的卡牌是一个自上而下的1,2,3,,,k的顺序

思路:结论题,不难看出只要目前场上只要有一个空我就可以通过一系列的移动使得某张牌到我想要的位置上,所以只要目前要去右下角的牌放上去之后还能有一个空就可以了。

#include <bits/stdc++.h>

using namespace std;

const int N = 1e6+100;
int n,m,k;
int a[N];
int tr[N];
int ask(int x) {
    int res = 0;
    for(x; x ; x -= (x & -x)) res += tr[x];
    return res;
}

void add(int x, int v) {
    for(x; x <= k ; x += (x & -x)) tr[x] += v;
}

void solve()
{
    cin >> n >> m >> k;
    for(int i = 1; i <= k ; i ++ ) cin >> a[i], tr[i] = 0;
    bool flag = true;
    for(int i = 1; i <= k ; i ++ ) {
        if(ask(a[i]) >= n * m - 3) flag = false;
        add(a[i], 1);
    }
    if(flag) cout << "YA" << endl;
    else cout << "TIDAK" << endl;
}

signed main()
{
    int t;
    for(cin>>t;t;t--)
    {
        solve();
    }
    return 0;
}

C. Almost All Multiples(构造)

题意:给定n,x,请你构造一个排列,使得a[n]=1并且a[1]=x,而且要求每个位置上的数都是这个位置的倍数(即a[i]%i==0)的情况下使得排列的字典序最小。

思路:思路太多了反而给自己写挂了,反思一下应该想清楚后再写

对于给定的这个x;
1.如果n%x!=0,,显然无法构造,必然有个位置不满足a[i]%i== 0
2. 考虑如何构造,对于必然的两个点1和n,我们先构造好他,然后把n安放在x处,随后不断地向后试探是否有位置可以和n交换,交换后再不断试探,如此往复即可。

#include <bits/stdc++.h>

using namespace std;
#define endl '\n'
const int N = 2e5+100;
int a[N];
int main()
{
    cin.tie(0);cout.tie(0);ios::sync_with_stdio(0);
    int t;
    for(cin>>t;t;t--)
    {
        int n,x;
        cin>>n>>x;
        for(int i=1;i<=n;i++)
            a[i]=0;
        if(n%x)
        {
            cout<<-1<<endl;
            continue;
        }
        for(int i=1;i<=n;i++)
        {
            a[i]=i;
        }
        if(n==x)
        {
            swap(a[1],a[n]);
            for(int i=1;i<=n;i++)
                cout<<a[i]<<" ";
            cout<<endl;
            continue;
        }
        a[1]=x;
        a[n]=1;
        a[x]=n;
        int now=x;
        for(int i=2;i<n;i++)
        {
            if(n%i==0&&i%now==0)
            {
                swap(a[now],a[i]);
                now=i;
            }
        }
        for(int i=1;i<=n;i++)
        {
            cout<<a[i]<<" ";
        }
        cout<<endl;
    }
    return 0;
}

真的气,为什么vp每次都有牌,济南就犯了傻逼错误,我求求老天了,让我们杭州正式赛发挥好一次,呜呜呜。
A. Krypton(多重背包)

题意:给定了n个物品,这n个物品你可以无限卖,第一次卖的时候每个物品会有不同的赠品,每个物品和赠品都有其价值,请问给定m块钱怎样买能获得最大价值。

思路:zsy读到这题好像在想别的方法,和我说一下一眼多重背包就过了。

顺带一提,所谓基础的四个背包(01,多重,无限,混合)其实都可以直接用多重背包来做,没那么麻烦的。

#include <bits/stdc++.h>

using namespace std;
#define endl '\n'

const int N = 1e5+100;
struct node
{
    int w,v,num;
};
node a[N];
int dp[N];
int main()
{
    cin.tie(0);cout.tie(0);ios::sync_with_stdio(0);
    int n;
    cin>>n;
    a[1].num=1,a[1].v=18,a[1].w=1;
    a[2].num=1,a[2].v=78,a[2].w=6;
    a[3].num=1,a[3].v=280+28,a[3].w=28;
    a[4].num=1,a[4].v=880+58,a[4].w=88;
    a[5].num=1,a[5].v=1980+128,a[5].w=198;
    a[6].num=1,a[6].v=3280+198,a[6].w=328;
    a[7].num=1,a[7].v=6480+388,a[7].w=648;
    a[8].num=10000,a[8].v=10,a[8].w=1;
    a[9].num=10000,a[9].v=60,a[9].w=6;
    a[10].num=10000,a[10].v=280,a[10].w=28;
    a[11].num=10000,a[11].v=880,a[11].w=88;
    a[12].num=10000,a[12].v=1980,a[12].w=198;
    a[13].num=10000,a[13].v=3280,a[13].w=328;
    a[14].num=10000,a[14].v=6480,a[14].w=648;
    for(int i=1;i<=14;i++)
    {
        int num=min(a[i].num,n/a[i].w);
        for(int k=1;num>0;k<<=1)
        {
            if(k>num)
                k=num;
            num-=k;
            for(int j=n;j>=a[i].w*k;j--)
            {
                dp[j]=max(dp[j],dp[j-a[i].w*k]+a[i].v*k);
            }
        }
    }
    cout<<dp[n];
    return 0;
}

D. Meaningless Sequence(数位DP的思想,位运算,打表)
题意:请对于a的数列,有如下通项公式。给定n和c请你求解第二个公式

请添加图片描述在这里插入图片描述
思路:俗话说得好,看不出规律就打表。
打表发现a的每一项可以理解为c的多少次幂,而这个多少次幂又恰好发现是对应n的二进制表示下1的数量之和。那么这题就变成了:统计从0到n各个数二进制位都出现了多少次,用到了一点数位DP的思想

#include <bits/stdc++.h>

using namespace std;
#define endl '\n'
#define int long long
const int N=3e3+5;
const int mod = 1e9+7;
int x,a[N],c[N][N];
char s[N];
int fastpow(int n,int a)
{
    int res=1;
    while(n)
    {
        if(n&1)
        {
            res=res*a%mod;
        }
        a=a*a%mod;
        n>>=1;
    }
    return res%mod;
}
signed main()
{
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    c[0][0]=c[1][1]=1;
    for(int i=1;i<=3000;i++)
    {
        c[0][i]=c[i][i]=1;
        for(int j=0;j<i;j++)
        {
            c[i][j]=(c[i-1][j]+c[i-1][j-1])%mod;
        }
    }
    cin>>(s+1)>>x;
    int n=strlen(s+1),sum=0;
    for(int i=1;i<=n;i++)
    {
        if(s[i]=='0') continue;
        int len=n-i;
        for(int j=0;j<=len;j++)
            a[j+sum]=(a[j+sum]+c[len][j])%mod;
        sum++;
    }
    a[sum]++;
    int ans=0;
    for(int i=0;i<=3000;i++)
    {
        ans=(ans+a[i]*fastpow(i,x)%mod)%mod;
        //cout<<a[i]<<" "<<i<<endl;
    }
    cout<<ans;
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/49625.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

是不是Jenkins大神,看这几个技巧就够

01 Performance插件兼容性问题 自由风格项目中&#xff0c;有使用 Performance 插件收集构建产物&#xff0c;但是截至到目前最新版本&#xff08;Jenkins v2.298&#xff0c;Performance&#xff1a;v3.19&#xff09;&#xff0c;此插件和Jenkins都存在有兼容性问题&#xf…

运筹说 第75期 | 数学家欧拉也玩跨界

莱昂哈德欧拉&#xff08;Leonhard Euler&#xff09;的一生&#xff0c;是为数学发展而奋斗的一生&#xff0c;他不但为数学界作出贡献&#xff0c;更把整个数学推至物理的领域。欧拉杰出的智慧&#xff0c;顽强的毅力&#xff0c;孜孜不倦的奋斗精神和高尚的科学道德&#xf…

用uniapp开发打包多端应用完整指南

一、uni-app项目介绍 用uni-app开发多端项目&#xff0c;一套代码可同时打包出各端小程序、h5和app&#xff0c;uni-app支持通过 HBuilderX可视化界面 和 vue-cli命令行 两种方式创建项目&#xff0c;下面示例项目采用 HBuilderX可视化界面 的方式创建&#xff0c;cli项目可参…

opencv c++ 图像梯度、边缘、锐化

图像梯度的目的&#xff1a; 获取图像上沿着某一方向或多个方向上&#xff0c;像素值的突变图像。 即&#xff1a; 对满足之间相互独立的函数&#xff0c; 求&#xff0c; 1、预备知识 1.1、常见的梯度计算算子 1.2、梯度计算方法 L2法&#xff1a; L1法&#xff1a; 1.3…

Packet Tracer - 比较 2960 和 3560

目标 第 1 部分&#xff1a;比较第 2 层和第 3 层交换机 第 2 部分&#xff1a;比较第 3 层交换机和路由器 拓扑图 背景信息 在本练习中&#xff0c;您将使用各种命令检查三种不同的交换拓扑&#xff0c;并且比较 2960 和 3560 交换机之间的异同。 您还将比较 1941 路由器和…

章鱼应用链|UniqueOne 构建一体化的 NFT 和元宇宙的体验

全长1325字&#xff0c;预计阅读 6 分钟 作者&#xff1a;MiX 章鱼网络生态候选应用链 UniqueOne 已经通过投票&#xff0c;近期将启动主网。 UniqueOne 正在构建「NFT市场-元宇宙-DeFi」结构的多层价值生态&#xff0c;UoNo NFT Marketplace 将无缝连接元宇宙 UniqueOne.Wo…

七个研究生必备高效科研网站

文章目录一、Papers With Code二、Connected papers三、Semantic Scholar四、Researcher五、Academic Phrasebank六、EndNote七、DeepL翻译一、Papers With Code Reddit用户rstoj做了一个网站&#xff0c;将ArXiv上的最新机器学习论文与GitHub上的代码&#xff08;TensorFlow/…

RK3399 Android10 移除应用权限(包含USB)申请弹框

Android板外接了USB设备&#xff0c;每次开机后第一次启动我们的APP&#xff0c;都会弹出申请USB的弹框&#xff0c;客户使用起来很不方便&#xff0c;翻了一些文章和代码后通过修改UsbPermissionActivity.java实现。 我们看到此Activity是一个AlertActivity&#xff0c;也就是…

Zookeeper 实现分布式锁 -- 基于Curator

Zookeeper的四种节点类型 1、持久化节点 &#xff1a;所谓持久节点&#xff0c;是指在节点创建后&#xff0c;就一直存在&#xff0c;直到有删除操作来主动清除这个节点——不会因为创建该节点的客户端会话失效而消失。 2、持久化顺序节点&#xff1a;这类节点的基本特性和上…

postgres源码解析38 表创建执行全流程梳理--3

本文结合实例讲解表创建执行流程 [CREATE TABLE wp_shy(id int primary key, name carchar(20))],相关知识回顾见&#xff1a; postgres源码解析38 表创建执行全流程梳理–1 postgres源码解析38 表创建执行全流程梳理–2 执行流程图 transformCreateStmt函数是表创建真正的入口…

第十四届蓝桥杯模拟赛(第二场)题解·2022年·C/C++

前言 本场比赛是校内赛&#xff0c;总体感觉是DP规划比赛和简单数据结构比赛&#xff0c;但是要细心一点就可以了。 因为不知道答案&#xff0c;所以本题解只有一点参考意义&#xff0c;欢迎评论区和小熊同学讨论。 **不保证答案一定就是对的&#xff01;&#xff01;&#x…

退役了,总结的ACM近年区域赛的所有题型

之前写了个退役文章记录想记录下&#xff0c;但是没有内容&#xff0c;还是给删了&#xff0c;所以前面的是退役小记&#xff0c;后面是我个人写近2年所有区域赛场次记录的题型 目录 退役小记&#xff08;没兴趣可以不看&#xff09; 这里简单记下我的acm生涯 省赛和三场区…

Miniconda:在pycharm的terminal中无法使用Conda命令

在pycharm的terminal中无法使用Conda命令 问题&#xff1a; 在本地下载好conda系列后&#xff0c;在pycharm的terminal中无法使用conda命令 问题分析&#xff1a; 说的很清楚了&#xff0c;是因为当前支持的shells没有初始化conda 所以我们只需要把Shell 路径改成激活cond…

腾讯云架构师整理总结的MySQL性能优化和高可用架构实践文档

前言 有人调侃我们说&#xff1a; 程序员不如送外卖。送外卖是搬运食物&#xff0c;自己是搬运代码&#xff0c;都不产出新的东西……透支体力&#xff0c;又消耗健康&#xff0c;可替代性极强&#xff0c;30岁之后就要面临被优化的危险……想跳槽&#xff0c;但是更高的平台…

wordpress改成https网址方法

我们建议搭建wordpress使用宝塔更为方便&#xff0c;另外也可以选择WDCP或者phpstudy也不错。本次教程适用于宝塔。 老样子买一台云服务器&#xff0c;建议找一些主流云服务器提供商&#xff0c;然后买一台Linux系统的然后安装好宝塔控制面板&#xff0c;创建一个站点&#xf…

【T+】畅捷通T+服务管理中,异步任务服务(TPlusPopAsyncTaskService1700)无法启动

【问题描述】 畅捷通T产品&#xff0c; 服务管理中的【异步任务服务&#xff08;TPlusPopAsyncTaskService1700&#xff09;】一直处于停止状态&#xff0c;且点击启动没有任何反应。 【解决方法】 【排查过程】 首先&#xff1a;检查数据库配置&#xff0c;以及网站端口配置…

可以写进简历的软件测试电商项目,不进来get一下?

前言 说实话&#xff0c;在找项目的过程中&#xff0c;我下载过&#xff08;甚至付费下载过&#xff09;N多个项目、联系过很多项目的作者&#xff0c;但是绝大部分项目&#xff0c;在我看来&#xff0c;并不适合你拿来练习&#xff0c;它们或多或少都存在着“问题”&#xff…

Linux C中对json格式数组数据的生成与解析

在网络通信中&#xff0c;数据经常被做成json格式的来进行传输。那么我们怎么在linux系统中去做json格式的数据呢&#xff1f;怎么将接收到的json格式的数据解析出来呢&#xff1f; 1、linux json库的安装 &#xff08;1&#xff09;下载json-c源码包 &#xff08;2&#xff09…

Redis 内存淘汰和过期删除策略

提起使用Redis的优点&#xff0c;大家可以列举出许多&#xff0c;比如&#xff1a;数据存储在内存&#xff0c;读写速度快&#xff0c;性能优异。比如数据持久化&#xff0c;便于数据备份及恢复等等。 分布式服务系统平台发展至今&#xff0c;Redis活跃在平台的各个领域&#…

如何写单元测试

单元测试理论知识 什么是单元测试&#xff1f; 单元测试&#xff08;unit testing&#xff09;&#xff0c;是指对软件中的最小可测试单元进行检查和验证。通常而言&#xff0c;一个单元可能是单个程序、类、对象、方法等。 为什么需要单元测试 为什么要做单元测试&#xf…