Educational Codeforces Round 106 (Rated for Div. 2) C. Minimum Grid Path 奇偶 + 思维

传送门

文章目录

  • 题意:
  • 思路:

题意:

给一个二维平面,起点在(0,0)(0,0)(0,0),终点在(n,n)(n,n)(n,n),每次只能往上和往右走,距离随意,总步数不超过nnn,每一步有一个代价cic_ici,定义从(0,0)(0,0)(0,0)(n,n)(n,n)(n,n)总花费是∑ci∗disti\sum c_i*dist_icidistidistidist_idisti是第iii步走的长度。

思路:

我们假设一共走了kkk步,那么说明我们拐了k−1k-1k1个弯,设每次走的步为dist1,dist2,dist3,...,distkdist_1,dist_2,dist_3,...,dist_kdist1,dist2,dist3,...,distk,我们可以发现dist1+dist3+...=ndist_1+dist_3+...=ndist1+dist3+...=ndist2+dist4+...=ndist_2+dist_4+...=ndist2+dist4+...=n,所以我们可以奇偶分开做就好啦。
分别统计一下奇数和偶数到当前位的cic_ici最小值,让后让最小值走的步最多,其他的disti=1dist_i=1disti=1即可。

//#pragma GCC optimize(2)
#include<cstdio>
#include<iostream>
#include<string>
#include<cstring>
#include<map>
#include<cmath>
#include<cctype>
#include<vector>
#include<set>
#include<queue>
#include<algorithm>
#include<sstream>
#include<ctime>
#include<cstdlib>
#define X first
#define Y second
#define L (u<<1)
#define R (u<<1|1)
#define pb push_back
#define mk make_pair
#define Mid (tr[u].l+tr[u].r>>1)
#define Len(u) (tr[u].r-tr[u].l+1)
#define random(a,b) ((a)+rand()%((b)-(a)+1))
#define db puts("---")
using namespace std;//void rd_cre() { freopen("d://dp//data.txt","w",stdout); srand(time(NULL)); }
//void rd_ac() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//AC.txt","w",stdout); }
//void rd_wa() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//WA.txt","w",stdout); }typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int,int> PII;const int N=1000010,mod=1e9+7,INF=0x3f3f3f3f;
const double eps=1e-6;int n;
int c[N];int main()
{
//	ios::sync_with_stdio(false);
//	cin.tie(0);int _; scanf("%d",&_);while(_--){scanf("%d",&n);for(int i=1;i<=n;i++) scanf("%d",&c[i]);LL pre1,pre2,ans1,ans2;pre1=pre2=0;ans1=ans2=1e18;LL ans=1e18;LL mi1,mi2; mi1=mi2=1e18;for(int i=1,c1=0,c2=0;i<=n;i++){if(i%2==1){mi1=min(mi1,1ll*c[i]);c1++;pre1+=c[i];if(i>=2) ans=min(ans,1ll*(n-c1)*mi1+pre1+ans2);ans1=1ll*(n-c1)*mi1+pre1;}else{mi2=min(mi2,1ll*c[i]);c2++;pre2+=c[i];if(i>=2) ans=min(ans,1ll*(n-c2)*mi2+pre2+ans1);ans2=1ll*(n-c2)*mi2+pre2;}}printf("%lld\n",ans);}return 0;
}
/**/

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

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

相关文章

从CLR GC到CoreCLR GC看.NET Core对云原生的支持

内存分配概要前段时间在园子里看到有人提到了GC学习的重要性&#xff0c;很赞同他的观点。充分了解GC可以帮助我们更好的认识.NET的设计以及为何在云原生开发中.NET Core会占有更大的优势&#xff0c;这也是一个程序员成长到更高层次所需要经历的过程。在认识GC的过程中&#x…

Orac and LCM #641(div2) c题--求质因数次小指数

Orac and LCM cf地址 For the multiset of positive integers s{s1,s2,…,sk}, define the Greatest Common Divisor (GCD) and Least Common Multiple (LCM) of s as follow: gcd(s) is the maximum positive integer x, such that all integers in s are divisible on x. …

Codeforces Round #606 (Div. 2, based on Technocup 2020 Elimination Round 4) dfs + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给一张图&#xff0c;求必须经过aaa点和bbb点的路径条数。 思路&#xff1a; 通过观察我们发现&#xff0c;这个路径无非就是x−>a−>b−>yx->a->b->yx−>a−>b−>y或者x−>…

一张图带你了解 Insider Dev Tour 2019中国技术大会

点击阅读原文&#xff0c;前往微软Insider Dev Tour 全球官网

Codeforces Round #632 (Div. 2)巧用小技巧

Codeforces Round #632 (Div. 2)点这 Eugene likes working with arrays. And today he needs your help in solving one challenging task. An array c is a subarray of an array b if c can be obtained from b by deletion of several (possibly, zero or all) elements f…

Codeforces Round #606 (Div. 2, based on Technocup 2020 Elimination Round 4) 构造

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给nnn个数&#xff0c;让你构造一个尽可能大的矩阵&#xff0c;其中每个点所在的行和列都不含相等元素。 思路&#xff1a; 假设构造的答案矩阵大小为ababab且a<ba<ba<b&#xff0c;那么我们可以…

.NET项目迁移到.NET Core操作指南

这篇文章&#xff0c;汇集了大量优秀作者写的关于".NET迁移到.NET Core"资料文章以及微软官方教程文档。是我在迁移公司框架项目到.NET Core和.NET Standard时遇到的问题&#xff0c;并将相关资料整理成这篇文章。记录如何一步一步把项目迁移到.NET Core。在此感谢这…

Educational Codeforces Round 88 D. Yet Another Yet Another Task(巧枚举)

cf地址 **题目大意&#xff1a;**一个序列&#xff0c;你可以选择一个子段&#xff0c;要求去掉子段最大值后的和最大&#xff0c;求出这个最大值 **思路&#xff1a;**a[i]的范围比较小&#xff0c;可以通过枚举最大值&#xff0c;再找到最大值可以辐射的区间。经典套路了。…

Codeforces Round #607 (Div. 2) E. Jeremy Bearimy dfs + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你2∗k2*k2∗k个点的一棵树。定义GGG为任选kkk组不同的点&#xff0c;每组点的距离和的最小值。定义BBB为任选kkk组不同的点&#xff0c;每组点的距离和的最大值。让你求出GGG和BBB。 思路&#xff1a; …

EF Core 3 的 40 个中断性变更

为了修复 Entify Framework Core 中许多已发现的缺陷&#xff0c;微软在 EF Core 3 中引入了 40 个中断性变更。我们可以在微软文档中查看完整的中断性变更列表&#xff0c;本文仅列举几个主要的点。客户端查询为了突破 EF Core SQL 生成器的限制&#xff0c;默认只在客户端执行…

Codeforces Round #646 (Div. 2) E(贪心,bfs)

Codeforces Round #646 (Div. 2) E 题目大意&#xff1a; 给一棵树&#xff0c;每个节点有三个权值 A,B,C, (B,C为0或1)&#xff0c;每次你可以花费 A[u] *k的代价让A子树中的任意 k 个节点交换彼此的 B &#xff0c;问让所有节点的 BC 至少花费多少代价。 思路&#xff1a; …

Educational Codeforces Round 77 (Rated for Div. 2) D. A Game with Traps 贪心 +二分

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你nnn个人&#xff0c;每个人都有个能力值aia_iai​。让后在1−m1-m1−m的路上有kkk个陷阱&#xff0c;每个陷阱的范围是[li,ri][l_i,r_i][li​,ri​]&#xff0c;伤害是did_idi​&#xff0c;能力值低于d…

联手微软,Docker公司将推出Docker Desktop for WSL 2

微软最新推出的 WSL 2 在架构方面发生了重大的变化&#xff1a;它提供了一个在轻量级 VM 中运行的真正 Linux 内核。使用真正的 Linux 内核意味着可以在 Windows 上运行 ELF64 Linux 二进制文件。对 Docker 来说绝对是利好消息&#xff0c;因为这意味着 Linux 版本的 Docker 可…

SP1026 FAVDICE - Favorite Dice 期望dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 一个n面的骰子&#xff0c;求期望掷几次能使得每一面都被掷到。 思路&#xff1a; 考虑期望dpdpdp。定义f[i]f[i]f[i]表示有iii面了&#xff0c;还需要多少次能到nnn面。当前是iii面&#xff0c;所以选到新…

Educational Codeforces Round 88 (Rated for Div. 2) E(数学)

Educational Codeforces Round 88 (Rated for Div. 2)E 题目大意: 给你n&#xff0c;k(1<k<n<5e5)&#xff0c;从1到n中选k个数组成一个严格递增序列&#xff0c;如果对任何正整数&#xff0c;依次模上这k个数&#xff0c;无论这k个数如何排列得到的答案都相同&#…

HAProxy 2.0发布,长期支持版本

HAProxy 2.0 发布了。HAProxy 是一个使用 C 语言编写的自由及开源软件&#xff0c;其提供高可用性、负载均衡以及基于 TCP 和 HTTP 应用的代理&#xff0c;支持虚拟主机&#xff0c;它是免费、快速并且可靠的 Web 负载均衡解决方案。包括 GitHub、Bitbucket、Stack Overflow、R…

Codeforces Round #651 (Div. 2) D

D. Odd-Even Subsequence 题目大意&#xff1a;在a数组中 保留k个数字&#xff0c;如何代价最小的多少。 代价的算法 具体看题意&#xff1a;就是k数组中 min{max{奇数下标}&#xff0c;max{偶数下标}} 解题思路&#xff1a;贪心加二分&#xff0c;二分全部的答案&#xff08…

CF1042E Vasya and Magic Matrix 期望dp + 推公式

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 将矩阵中的数放到数组里排序&#xff0c;就是一个比较明显的期望dpdpdp了。 定义f[i]f[i]f[i]表示从第iii个出发的期望得分&#xff0c;所以转移方程也比较好写了&#xff1a;f[i]∑(f[j](…

C#并发编程之异步编程(一)

写在前面C#5.0中&#xff0c;对异步编程进行了一次革命性的重构&#xff0c;引入了async和await这两个关键字&#xff0c;使得开发人员在不需要深刻了解异步编程的底层原理&#xff0c;就可以写出十分优美而又代码量极少的代码。如果使用得当&#xff0c;你可以写出具有并行化并…

简单思维dp-- Gym - 102392B

Gym - 102392B点 题意&#xff1a;Steve想要在游戏中升到 两级&#xff0c;给你s1和s2 分别为1级需要的经验和二级需要的经验&#xff0c;然后给你n给任务&#xff0c;任务在1级前和在1级后的经验不同&#xff0c;完成的时间也不同&#xff0c;在刚刚升1级时&#xff0c;所溢出…