[2020-11-24 contest]糖果机器(二维偏序),手套(状压dp),甲虫(区间dp),选举(线段树 最大子段和)

文章目录

  • T1:糖果机器
    • solution
    • code
  • T2:手套
    • solution
    • code
  • T3:甲虫
    • solution
    • code
  • T4:选举
    • solution
    • code

T1:糖果机器

solution

考虑从第iii个糖果出发能到达第jjj个,则有Tj−Ti≥∣Sj−Si∣T_j-T_i≥|S_j-S_i|TjTiSjSi
{Tj−Ti≥Sj−SiTj−Ti≥Si−Sj=>{Ti+Si≥Tj+SjTi−Si≥Tj−Sj\left\{ \begin{aligned} T_j-T_i≥S_j-S_i \\ T_j-T_i≥S_i-S_j\\ \end{aligned} \right.=>\left\{ \begin{aligned} T_i+S_i\ge T_j+S_j\\ T_i-S_i\ge T_j-S_j\\ \end{aligned} \right.{TjTiSjSiTjTiSiSj=>{Ti+SiTj+SjTiSiTjSj
发现这其实是函数同构体
在这里插入图片描述

A=Ti+Si,B=Ti−SiA=T_i+S_i,B=T_i-S_iA=Ti+Si,B=TiSi,则👆可转化为👇
{Ai≥AjBi≥Bj\left\{ \begin{aligned} A_i\ge A_j\\ B_i\ge B_j\\ \end{aligned} \right.{AiAjBiBj
又发现此题就是一个二维偏序问题
其实就是noip普及组1999导弹拦截
在这里插入图片描述

二维偏序问题,一般是一维时间轴有序,然后二维套树状数组,总体上复杂度是logloglog级别

code

#include <set>
#include <cstdio>
#include <algorithm>
using namespace std;
#define maxn 100005
struct node {int s, t, id;friend bool operator < ( const node &x, const node &y ) {return x.s + x.t < y.s + y.t;}
}p[maxn];
set < node > st;
int n, tot;bool cmp( node x, node y ) {return ( x.t - x.s == y.t - y.s ) ? ( x.t + x.s < y.t + y.s ) : ( x.t - x.s < y.t - y.s );
}int main() {scanf( "%d", &n );for( int i = 1;i <= n;i ++ )scanf( "%d %d", &p[i].s, &p[i].t );sort( p + 1, p + n + 1, cmp );for( int i = 1;i <= n;i ++ ) {set < node > :: iterator it = st.upper_bound( p[i] );if( it == st.begin() ) p[i].id = ++ tot;else it --, p[i].id = it->id, st.erase( it );st.insert( p[i] );}printf( "%d\n", tot );for( int i = 1;i <= n;i ++ )printf( "%d %d %d\n", p[i].s, p[i].t, p[i].id );return 0;
}

T2:手套

solution

在这里插入图片描述

code

#include <cstdio>
#include <algorithm>
using namespace std;
#define maxn 20
struct node {int x, y;
}p[1 << maxn];
int n;
int a[maxn], b[maxn];bool cmp( node s, node t ) {return ( s.x == t.x ) ? ( s.y > t.y ) : ( s.x < t.x );
}void update( long long &ansx, long long &ansy, long long x, long long y ) {if( ( x + y < ansx + ansy ) || ( x + y == ansx + ansy && x < ansx ) )ansx = x, ansy = y;
}int main() {scanf( "%d", &n );for( int i = 0;i < n;i ++ )scanf( "%d", &a[i] );for( int i = 0;i < n;i ++ )scanf( "%d", &b[i] );int m = 1 << n;for( int i = 0;i < m;i ++ )for( int j = 0;j < n;j ++ )if( i >> j & 1 ) p[i].x += a[j];for( int i = 0;i < m;i ++ )for( int j = 0;j < n;j ++ )if( i >> j & 1 ) p[m - 1 - i].y += b[j];long long flagx = p[m - 1].x, flagy = p[0].y, ansx = flagx, ansy = flagy;sort( p, p + m, cmp );for( int i = m - 1, y = 0;~ i;i -- ) {if( p[i].x != flagx && y != flagy )update( ansx, ansy, p[i].x + 1, y + 1 );y = max( p[i].y, y );}printf( "%lld\n%lld\n", ansx, ansy );return 0;
}

T3:甲虫

solution

区间dp还是一眼就看得出来,只不过不知道怎么处理时间问题,考场上错误代码都能骗40
在这里插入图片描述
正着不行,就反着考虑

code

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define maxn 305
#define ll long long
#define inf 0x3f3f3f3f
int n, m, k;
int x[maxn];
ll dp[2][maxn][maxn];
int vis[2][maxn][maxn];long long dfs( int t, int l, int r ) {if( r - l == k ) return 0;if( vis[t][l][r] == k ) return dp[t][l][r];vis[t][l][r] = k;int p = ( t ? r : l );ll &ans = dp[t][l][r];ans = inf;if( l != 1 ) ans = min( ans, dfs( 0, l - 1, r ) + ( x[p] - x[l - 1] ) * ( k - ( r - l ) ) );if( r != n ) ans = min( ans, dfs( 1, l, r + 1 ) + ( x[r + 1] - x[p] ) * ( k - ( r - l ) ) );return ans;
}int main() {scanf( "%d %d", &n, &m );for( int i = 1;i <= n;i ++ )scanf( "%d", &x[i] );x[++ n] = 0;sort( x + 1, x + n + 1 );int pos;for( int i = 1;i <= n;i ++ )if( ! x[i] ) { pos = i; break; }ll ans = 0;for( k = 0;k < n;k ++ )ans = max( ans, 1ll * m * k - dfs( 0, pos, pos ) );printf( "%lld", ans );return 0;
}

T4:选举

solution

在这里插入图片描述

在这里插入图片描述

code

#include <cstdio>
#include <iostream>
using namespace std;
#define maxn 500005
struct node {int minn, maxx, ans;node() {}node( int Min, int Max, int Ans ) {minn = Min, maxx = Max, ans = Ans;}friend node operator + ( const node &x, const node &y ) {return node( min( x.minn, y.minn ), max( x.maxx, y.maxx ), max( y.maxx - x.minn, max( x.ans, y.ans ) ) );}
}t[maxn << 2];
int n, Q;
char s[maxn];
int pre[maxn];void build( int num, int l, int r ) {if( l == r ) {t[num] = node( pre[l], pre[l], 0 );return;}int mid = ( l + r ) >> 1;build( num << 1, l, mid ), build( num << 1 | 1, mid + 1, r );t[num] = t[num << 1] + t[num << 1 | 1];
}node query( int num, int l, int r, int L, int R ) {if( L <= l && r <= R ) return t[num];int mid = ( l + r ) >> 1;if( R <= mid ) return query( num << 1, l, mid, L, R );else if( mid < L ) return query( num << 1 | 1, mid + 1, r, L, R );else return query( num << 1, l, mid, L, R ) + query( num << 1 | 1, mid + 1, r, L, R );
}int main() {scanf( "%d %s %d", &n, s + 1, &Q );for( int i = 1;i <= n;i ++ )pre[i] = pre[i - 1] + ( s[i] == 'T' ? -1 : 1 );build( 1, 0, n );	while( Q -- ) {int l, r;scanf( "%d %d", &l, &r );node ans = query( 1, 0, n, l - 1, r );printf( "%d\n", ans.ans - ( pre[r] - pre[l - 1] ) );}return 0;
}

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

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

相关文章

ASP.NET Core 数据加解密的一些坑

点击蓝字关注我ASP.NET Core 给我们提供了自带的Data Protection机制&#xff0c;用于敏感数据加解密&#xff0c;带来方便的同时也有一些限制可能引发问题&#xff0c;这几天我就被狠狠爆了一把我的场景我的博客系统有个发送邮件通知的功能&#xff0c;因此需要配置一个邮箱账…

[2020-11-28 contest]素数(数学),精灵(区间dp),农夫约的假期(结论),观察(树链剖分lca+set)

文章目录素数solutioncode精灵solutioncode农夫约的假期solutioncode观察solutionsolutioncode素数 solution 通过观察可得一个结论 对于两个相邻的质数p1,p2(p1<p2)p_1,p_2\ (p_1<p_2)p1​,p2​ (p1​<p2​) 对于x∈[p1,p2)x∈[p_1,p_2)x∈[p1​,p2​)&#xff0c;都…

B. Box Fitting

B. Box Fitting 题意&#xff1a; 现在有n个长方形&#xff0c;宽均为1&#xff0c;现在有一个底为m的容器&#xff0c;问将长方形放入其中&#xff0c;所用容器的最小宽度是多少 &#xff08;长方形必须长朝下放置详细如图&#xff09; 题解&#xff1a; 比赛时脑子抽了。…

人工智能第六课:如何做研究

这是我学习 Data Science Research Methods 这门课程的笔记。这门课程的讲师是一名教授和数据科学家&#xff0c;可能因为他既有理论背景&#xff0c;又有实践经验&#xff0c;所以整个课程听下来还比较舒服&#xff0c;学到了一些不错的理论知识。这门课比较系统地介绍了什么…

[2020-11-30 contest]数列(矩阵加速),秘密通道(dijkstra最短路)小X游世界树(换根dp),划分(数学)

文章目录数列solutioncode秘密通道solutioncode小X游世界树solutioncode划分solutioncode数列 a[1]a[2]a[3]1 a[x]a[x-3]a[x-1] (x>3) 求 a 数列的第 n 项对 1000000007&#xff08;10^97&#xff09;取余的值。 输入格式 第一行一个整数 T&#xff0c;表示询问个数。 以下…

Docker最全教程——数据库容器化之持久保存数据(十二)

上一节我们讲述了SQL Server容器化实践&#xff08;注意&#xff0c;SQL Server现在也支持跨平台&#xff09;&#xff0c;本节将讲述如何持久保存数据&#xff0c;并且接下来将逐步讲解其他数据库&#xff08;MySql、Redis、Mongodb等等&#xff09;的容器化实践&#xff0c;中…

【李超树】李超线段树维护凸包(凸壳) (例题:blue mary开公司+线段游戏+ZZH的旅行)

文章目录前言李超树引入(斜率优化)什么是李超树&#xff1f;李超树活着能干点什么&#xff1f;算法思想(使用手册&#xff1f;)插入查询模板判断是否覆盖(优不优)插入查询例题板题&#xff1a;BlueMary开公司分析code线段游戏分析code拓展——(动态开点李超树维护凸包)ZZH的旅行…

老牌开源Office操作组件NPOI现已支持.NET Core

昨天在微信群里听到老牌Excel开发利器NPOI的作者瞿总说4.6.1版本的NPOI已经支持.NET Standard 2.0了&#xff0c;这也就意味着你可以在.NET Core中使用NPOI了。作者&#xff1a;依乐祝原文地址 &#xff1a;https://www.cnblogs.com/yilezhu/p/10269281.html写在前面曾经的.NET…

.NET西安社区 [拥抱开源,又见 .NET] 第二次活动简报

「拥抱开源, 又见 .NET」随着 .NET Core的发布和开源&#xff0c;.NET又重新回到人们的视野。 .NET Core的下个3.0即将release&#xff0c;加入非常多的新功能&#xff0c;越来越拥抱变化&#xff0c;DevOps和Microservice的最佳实践已经在 .NET Core落地&#xff0c;比如 Ocel…

[dsu on tree]树上启发式合并总结(算法思想及模板附例题练习)

文章目录前言树上启发式合并引入算法思想时间复杂度模板练习例题&#xff1a;CF600E Lomsat gelralsolutioncodeCF208E Blood CousinssolutioncodeCF570D Tree RequestssolutioncodeCF1009F Dominant Indicessolutioncode前言 最近不是在⛏李超树嘛&#xff0c;然后就去玩了下…

领域驱动设计,让程序员心中有码(七)

领域驱动设计- 让程序员心中有码&#xff08;七&#xff09;-设计原则和设计模式&#xff0c;互联网开发者们共同的追求前言多年来&#xff0c;笔者一直从事传统软件企业的软件开发和项目管理工作。笔者发现在众多的传统软件企业中&#xff0c;评判优秀开发者的标准往往是技能的…

cf1504. Travelling Salesman Problem

cf1504. Travelling Salesman Problem 题意&#xff1a; n个城市&#xff0c;编号1~n&#xff0c;每个城市有美丽值a[i]&#xff0c;现在要从城市1出发&#xff0c;其他所有城市走一遍&#xff0c;最后回到城市1&#xff0c;城市i到j的花费为max(ci,aj-ai)&#xff0c;ci为第…

[NOIP-S 2020]游记(附考前注意事项)

呜呼起飞T1&#xff1a;排水系统T2&#xff1a;字符串匹配T3&#xff1a;移球游戏T4&#xff1a;微信步数总述考前注意事项T1&#xff1a;排水系统 嗯—— 怎么说呢&#xff1f;&#xff1f; 比赛开始后迅速通读三遍题 顶着第一题肯定是打卡题的心态 哪怕是恶心模拟也得上&…

程序猿修仙之路--数据结构之你是否真的懂数组?

数据结构但凡IT江湖侠士&#xff0c;算法与数据结构为必修之课。早有前辈已经明确指出&#xff1a;程序算法数据结构 。要想在之后的江湖历练中通关&#xff0c;数据结构必不可少。数据结构与算法相辅相成&#xff0c;亦是阴阳互补之法。开篇说道数组&#xff0c;几乎每个IT江…

Rolling The Polygon Gym - 102222B

Rolling The Polygon Gym - 102222B 题意&#xff1a; 给你一个多边形&#xff0c;给你内部一个点Q&#xff0c;多边形在平面上滚动一周&#xff08;当有一个边第二次触地滚动停止&#xff09;&#xff0c;问Q的轨迹长度 题解&#xff1a; 计算几何题目 自己一直不是很擅长…

Asp.Net Core 轻松学-经常使用异步的你,可能需要看看这个文章

前言事情的起因是由于一段简单的数据库连接代码引起&#xff0c;这段代码从语法上看&#xff0c;是没有任何问题&#xff1b;但是就是莫名其妙的报错了&#xff0c;这段代码极其简单&#xff0c;就是打开数据库连接&#xff0c;读取一条记录&#xff0c;然后立即更新到数据库中…

try.dot.net 的正确使用姿势

来源&#xff1a;https://www.cnblogs.com/7tiny/p/10277600.html【简介】微软官方前不久发布了 try.dot.net 这个有趣的网址&#xff0c;开始只是图个新鲜看了一下&#xff0c;后面通过自身实践过后&#xff0c;发现这着实算是个“有趣”的站点&#xff01;首先我们大概地列举…

A - TOYS POJ - 2318

A - TOYS POJ - 2318 题意&#xff1a; 一个盒子中有n个隔板&#xff0c;分出n1个空间&#xff08;从左往右空间的编号分别是0…n&#xff09;&#xff0c;&#xff08;隔板之间不会相交&#xff0c;且按照从左往右的顺序给出&#xff09;&#xff0c;现在给你m个坐标的物品&…

[BJOI2017]魔法咒语(AC自动机+DP+矩阵快速幂)

文章目录titlesolutioncodetitle solution 针对数据编程才是坠吊的&#xff01;&#xff01;&#xff01; 观察数据&#xff0c;发现分隔数据的LLL跨度过大&#xff0c;没有衔接——推测很有可能是分数据做法 ①&#xff1a;考虑L≤100L\le100L≤100的情况 可以暴力DPDPDP转移…

[国家集训队]middle(二分+主席树[中位数思维题])

文章目录点击查看solutioncode点击查看 solution 简单口胡一下就跑 考虑二分答案ansansans 区间[x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d][x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d][x1,x2],x1∈[a,b]&#xff0c;x2∈[c,d] 大于等于ansansans的设为111&#xff0c;小于ansans…