2020百度之星初赛一 Matrix

2024-04-16 00:38
文章标签 2020 百度 matrix 初赛 之星

本文主要是介绍2020百度之星初赛一 Matrix,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Problem Description
有一个二维平面,给定 length[1],length[2],length[3],length[4],画出 4 个正方形区域。

第 i 个区域为 (x,y) | |x|<=length[i],|y|<=length[i]。

对于一个整点 (x,y) 其权值为 (|x|+|y|)∗cnt,其中 cnt 为覆盖该点的区域个数。(点在区域边界上或者在区域内,都称为被区域覆盖)。

现在需要在至少被一个区域覆盖的整点点集中,选出 k 个两两不同的点,使得总权值和最小。

输出最小的权值总和。

Input
第一行一个整数 T(T≤100) 表示 T 组测试数据。

每组数据有 5 个数字,分别表示 length[1],length[2],length[3],length[4],k。满足 1≤length[1]<length[2]<length[3]<length[4]≤109,0≤k≤1010。

数据保证一定能选出 k 个点。

Output
对每组数据输出一行,表示答案。

Sample Input
4
1 2 3 4 1
1 2 3 4 2
1 2 3 4 6
1 5 7 9 12

Sample Output
0
4
20
64

样例解释
对于第一组样例,取 (0,0);
对于第二组样例,取 (0,0)、(0,1);
对于第三组样例,取 (0,0)、(0,1)、(1,0)、(-1,0)、(0,-1)、(1,0)、(4,0);

参考题解:https://www.cnblogs.com/jianjinxiani/p/13361465.html

思路:
正解里写的是二分最后点的最大权值,表示看得不是很懂。
然后参考了上面题解里的写法。

也就是,枚举当前的权值,然后对于4个区域分别判断对于权值 w w w的点,这个区域有多少个点。

因为枚举权值均摊下来,每次可以消去 4 ∗ l e n [ 1 ] + l e n [ 2 ] + l e n [ 3 ] + l e n [ 4 ] 4 4*\frac{len[1]+len[2]+len[3]+len[4]}{4} 44len[1]+len[2]+len[3]+len[4]个点。所以 k \sqrt{k} k 的时间复杂度可以解决这个问题。

#include <cstdio>
#include <cstring>
#include <algorithm>using namespace std;typedef long long ll;
int a[10];ll get(ll x,int len) {if(x > len * 2 || len == 0) return 0;if(x == 0) return 1;if(x <= len) return x * 4;return (2 * len - x + 1) * 4;
}int main() {int T;scanf("%d",&T);while(T--) {ll k;scanf("%d%d%d%d%lld",&a[4],&a[3],&a[2],&a[1],&k);ll ans = 0;ll w = 0;while(k) {for(int i = 1;i <= 4;i++) {if(w % i == 0) {ll num = get(w / i,a[i]) - get(w / i,a[i + 1]);ans += min(k,num) * w;k -= min(k,num);}}w++;}printf("%lld\n",ans);}return 0;
}

这篇关于2020百度之星初赛一 Matrix的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/907359

相关文章

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

[论文笔记]LLM.int8(): 8-bit Matrix Multiplication for Transformers at Scale

引言 今天带来第一篇量化论文LLM.int8(): 8-bit Matrix Multiplication for Transformers at Scale笔记。 为了简单,下文中以翻译的口吻记录,比如替换"作者"为"我们"。 大语言模型已被广泛采用,但推理时需要大量的GPU内存。我们开发了一种Int8矩阵乘法的过程,用于Transformer中的前馈和注意力投影层,这可以将推理所需

Imageview在百度地图中实现点击事件

1.首先第一步,需要声明的全局有关类的引用 private BMapManager mBMapMan; private MapView mMapView; private MapController mMapController; private RadioGroup radiogroup; private RadioButton normalview; private RadioBu

百度之星 2015 复赛 1001 (数长方形)

数长方形    Accepts: 595    Submissions: 1225  Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description 小度熊喜欢玩木棒。一天他在玩木棒的时候,发现一些木棒会形成长方形

百度之星 2015 初赛(1) 1002 找连续数

找连续数      Accepts: 401      Submissions: 1911  Time Limit: 2000/1000 MS (Java/Others)      Memory Limit: 32768/32768 K (Java/Others) Problem Description 小度熊拿到了一个无序的数组,对于这个数组,小度熊想知道是

百度之星初赛1002(二分搜索)

序列变换    Accepts: 816    Submissions: 3578  Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description 给定序列 A={A1,A2,...,An} , 要求改变序列A中

百度之星初赛1006(计算几何:能包含凸包的最小矩形面积)

矩形面积    Accepts: 717    Submissions: 1619  Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description 小度熊有一个桌面,小度熊剪了很多矩形放在桌面上,小度熊想知道能把这些

73. Set Matrix Zeros

题目: 解答: 提供了两种解题思路: 第一种,使用两个数组,分别标记每一行、每一列是否有0的存在,然后再去更新二维数组。 第二种,使用两个变量brow,bcol分别标记第0行,第0列是否存在0,然后使用每一行、每一列的第一个单元存储是否该行、该列存在0. 代码: class Solution {public:// 方法一void setZeroes(vector<vector<i

【python 百度指数抓取】python 模拟登陆百度指数,图像识别百度指数

一、算法思想 目的奔着去抓取百度指数的搜索指数,搜索指数的爬虫不像是其他爬虫,难度系数很高,分析之后发现是图片,坑爹的狠,想了下,由于之前做过身份证号码识别,验证码识别之类,豁然开朗,不就是图像识别麽,图像识别我不怕你,于是就有了思路,果然有异曲同工之妙,最后成功被我攻破了,大致思路如下: 1、首先得模拟登陆百度账号(用selenium+PhantomJS模拟登陆百度,获取cookie) 2