C. Count Triangles

题目链接 :

https://codeforces.com/contest/1355/problem/C

题目大意 :

给你 A , B , C , D

问有多少种方法构造出三角形(X , Y , Z)使得 A ≤ X ≤ B ≤ Y ≤ C ≤ Z ≤ D

解题思路 :

假设我们有了 (X + Y) 的长度时(记 X + Y = i )

根据三角形两边之和大于第三边的性质 Z 的取值范围我们也能确定了

再根据题意 B <= Y <= C , 我们又能得到 X 的取值范围(即构成 X + Y = i 的方案数)

于是答案 ans +=  (Z的取值范围 * X的取值范围)

而我们已知 A ≤ X ≤ B ≤ Y ≤ C ≤ Z ≤ D 且 (X , Y , Z) 可构成三角形,那么 X + Y 的可取范围也就已知

所以我们可以通过枚举 X + Y 的长度来操作

AC_Code :

#include<bits/stdc++.h>
#define int long long
using namespace std;
signed main()
{
ios::sync_with_stdio(false);
int a , b , c , d , ans = ;
cin >> a >> b >> c >> d;
for(int i = c + ; i <= c + d ; i ++)
{
int l = max(a , i - c);
int r = min(b , i - b);
if(r < l) continue;
ans += (r - l + ) * (min(d + , i) - c);
}
cout << ans << '\n';
return ;
}

D. Game With Array

题目链接 :

https://codeforces.com/contest/1355/problem/D

题目大意 :

问你能否构造一个长度为 N 且和为 S 的序列

使得对于该序列你无法找到一个子序列使得子序列的和等于 K 或 S - K (0 <= K <= S)

解题思路 :

猜结论

我们构造一个前 N - 1项为 1,第 N 项为 S - N + 1 的序列

对于前 N - 1项构成的序列的和我们设为 K,那么第 N 项构成的序列和就为 S - K

这样就很好的使用上了题目给的信息,所以盲猜该构造方法是可行的

那么对于该序列,[ 1 , N - 1 ] 和 [ S - (N - 1) , S ] 的值我们都是可以通过选取子序列得到

而 [ N , S - N ] 的值无法得到,所以只要判断 N 是否小于等于 S - N 即可

AC_Code :

#include<bits/stdc++.h>
using namespace std;
signed main()
{
ios::sync_with_stdio(false);
int n , s;
cin >> n >> s ;
int ans = s - n;
if(ans >= n)
{
cout << "YES" << '\n';
for(int i = ; i <= n - ; i ++) cout << "1 ";
cout << ans + << '\n' << n << '\n';
}
else cout << "NO\n";
return ;
}

E. Restorer Distance

题目链接 :

https://codeforces.com/contest/1355/problem/E

题目大意 :

给你一个长度为 N 的序列 H 和三种操作

①、任选一个 Hi 使得 Hi = Hi + 1,代价为 A

②、任选一个 Hi 使得 Hi = Hi  - 1,代价为 R

③、任选一个 Hi、Hj 使得 Hi = Hi + 1 , Hj = Hj - 1 ,代价为 M

现要使整个序列的数的值都相同,问需要花费的最小代价为多少

解题思路 :

操作③ = 操作① + 操作②,如果 A + R <= M,那么对于操作③我们只要用操作① + ②代替即可

因为最后整个序列的值都相同(我们记最后的值为 X),那么暴力的做法就是枚举 X 然后选择最小代价

显然暴力的做法复杂度是不行的

但是通过枚举我们会发现 , 在 X 的可行域内 F(X) 呈一种单峰函数(F(X)指最后序列值全为 X 的最小代价)

得到了这些信息后这道题就是道三分的裸题了

AC_Code :

#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N = 3e5 + ;
int h[N] , n , a , r , m , ans = 1e18;
int check(int mid)
{
int res = , sum1 = , sum2 = ;
if(a + r <= m)
{
for(int i = ; i <= n ; i ++)
if(h[i] >= mid) res += (h[i] - mid) * r;
else res += (mid - h[i]) * a;
return res;
}
for(int i = ; i <= n ; i ++)
if(h[i] >= mid) sum1 += h[i] - mid;
else sum2 += mid - h[i];
res += min(sum1 , sum2) * m;
if(sum1 > sum2) res += (sum1 - sum2) * r;
else res += (sum2 - sum1) * a;
return res;
}
signed main()
{
ios::sync_with_stdio(false);
cin >> n >> a >> r >> m;
for(int i = ; i <= n ; i ++) cin >> h[i];
int L = , R = 1e9;
while(R - L > )
{
int midl = L + (R - L) / , midr = R - (R - L) / ;
if(check(midl) < check(midr)) R = midr;
else L = midl;
}
for(int i = L ; i <= R ; i ++) ans = min(ans , check(i));
cout << ans << '\n' ;
return ;
}

Codeforces Round #643 (Div. 2)(C ~ E)的更多相关文章

  1. Codeforces Round #643 (Div. 2) 题解 (ABCDE)

    目录 A. Sequence with Digits B. Young Explorers C. Count Triangles D. Game With Array E. Restorer Dist ...

  2. Codeforces Round #643 (Div.2)

    前言:这套cf我感觉出的很不错,AB就不说了,唯一有点欠缺的就是C和D的位置应该换一下,C出的挺不错,反正我当时没有想出来(赛后补题的时候其实也不难..听朋友说还可以FFT优化,然而我是个图论手并不会 ...

  3. Codeforces Round #643 (Div. 2) B. Young Explorers (思维,贪心)

    题意:给你一组人\(a\),现在要将这些人进行分组,对于\(i\),只有某一组的人数\(\ge a_{i}\)时,\(i\)才可以加入这个组,问最多能够有多少组,(不必将所有人都选用). 题解:我们将 ...

  4. Codeforces Round #643 (Div. 2) E. Restorer Distance (贪心,三分)

    题意:给你\(n\)个数,每次可以使某个数++,--,或使某个数--另一个++,分别消耗\(a,r,m\).求使所有数相同最少的消耗. 题解:因为答案不是单调的,所以不能二分,但不难发现,答案只有一个 ...

  5. Codeforces Round #643 (Div. 2) C. Count Triangles (数学公式)

    题意:给你四个正整数\(A,B,C,D\),且\(A\le B\le C \le D\),有\(A\le x\le B\le y\le C \le z\le D\),求最多有多少组\((x,y,z)\ ...

  6. Codeforces Round #643 (Div. 2) D. Game With Array (思维,构造)

    题意:给你两个正整数\(N\)和\(S\),构造一个长度为\(N\)并且所有元素和为\(S\)的正整数数组,问是否能找到一个\(K (0\le K \le S)\)使得这个数组的任意_子数组_的和都不 ...

  7. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  8. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  9. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

随机推荐

  1. MySQL不香吗,为什么还要有noSQL?

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是分布式专题的第14篇文章,我们一起来看看NoSQL数据库. 其实我很早就想写写分布式数据库相关的文章,既是我现在正在学习的,也是我很感 ...

  2. 微信小程序基本知识

    逻辑实现 1 使用动态数据展示列表(可以考虑使用wx:for属性配合动态数组渲染全部列表项,以减少WXML页面的代码量) eg:  <view class='listGroup' wx:for= ...

  3. 原生Js贪吃蛇游戏实战开发笔记

    前言 本课程是通过JavaScript结合WebAPI DOM实现的一版网页游戏---贪吃蛇的开发全过程,采用面向以象的思想设计开发.通过这个小游戏的开发, 不仅可以掌握JS的语法的应用,还可以学会D ...

  4. Apple Watch Series 6或将增加焦虑监测和睡眠追踪功能

    一条新的泄露消息称,Apple Watch Series 6 将增加心理健康功能,延长电池续航时间,并对现有传感器进行扩展,这样设备可以测量血液含氧量.苹果即将更新的 Apple Watch 新款推测 ...

  5. mac OS 搭建PHP项目开发环境

    系统 macOS Mojave 版本10.14.6 mac OS 自带Apache和PHP 非常便利 sudo apachectl -v //查看apache版本 php -v //查看php版本 启 ...

  6. pfSense®2.4.4发布后,原pfSense 黄金会员的服务将免费使用!

    2018年7月16日,Doug McIntire 从即将发布的pfSense®2.4.4开始,之前在"pfSense Gold"下提供的所有服务都将继续,但所有pfSense用户都 ...

  7. MySQL数据库的套接字文件和pid文件

    MySQL数据库的套接字文件和pid文件 socket文件:当用Unix域套接字方式进行连接时需要的文件. pid文件:MySQL实例的进程ID文件. MySQL表结构文件:用来存放MySQL表结构定 ...

  8. Mybatis详解系列(五)--Mybatis Generator和全注解风格的MyBatis3DynamicSql

    简介 Mybatis Generator (MBG) 是 Mybatis 官方提供的代码生成器,通过它可以在项目中自动生成简单的 CRUD 方法,甚至"无所不能"的高级条件查询(M ...

  9. IDEA 打可执行jar包(maven项目)

    1. Ctrl+Shift+Alt+S  打开 Project Structure  2.选择要执行的文件,  依次选择 项目, 方法所在文件(必须有main方法), 保存 3.如果之前路径下曾经打过 ...

  10. Python监控文件夹 && 发送邮件

    直接上代码: # python3 # -*- coding: utf-8 -*- # 2017/06/16 by luohan from email.mime.text import MIMEText ...