第七讲 贪心
文章目录
- 股票买卖 II
- 货仓选址(贪心:排序+中位数)
- 糖果传递(❗·贪心:中位数)
- 雷达设备(贪心+排序)
- 付账问题(平均值+排序❓)
- 乘积最大(排序/双指针)
- 后缀表达式(👍绝对值/分类讨论/贪心)
股票买卖 II
思路:只要对于今天来说明天的价格比今天高,我们就买,明天卖了肯定会获利。
public class Main{static Scanner sc = new Scanner(System.in);static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static int N = (int) (1e5 + 10);static int[] a = new int[N];static long ans = 0;public static void main(String[] args) throws Exception{int n = sc.nextInt();for(int i = 1; i <= n; i++) {a[i] = sc.nextInt();}for(int i = 2; i <= n; i++) {if(a[i] > a[i - 1]) {ans += (a[i] - a[i - 1]);}}System.out.println(ans);}
}
货仓选址(贪心:排序+中位数)
选中位数对两边来说都比较优
public class Main{static Scanner sc = new Scanner(System.in);static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static int N = (int) (1e5 + 10);static int[] a = new int[N];static long ans = 0;public static void main(String[] args) throws Exception{int n = sc.nextInt();for(int i = 1; i <= n; i++) {a[i] = sc.nextInt();}Arrays.sort(a,1, 1 + n);int mid = (n + 1)/2;for(int i = 1; i <= n; i++) {ans = ans + Math.abs(a[i] - a[mid]);}System.out.println(ans);}
}
糖果传递(❗·贪心:中位数)
本人还不是太明白
雷达设备(贪心+排序)
这道题也不太会,太菜了,😢
看的别人的题解,很妙题解
首先我们需要将小岛的坐标转换为区间,x只有在[x1,x2]才可以被搜到。
转换为以后就变成了区间覆盖问题 ,但是我们需要对区间从小到达(右端点)从小到大排序,我们只需要哦使用最近的雷达去判断是否可以,如果不可以就需要在加一个。
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;public class Main{static Scanner sc = new Scanner(System.in);static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static int N = (int) (1e4 + 10);static node[] a = new node[N];static int ans = 0;static int n = 0,d = 0;static boolean[] vis = new boolean[N];public static void main(String[] args) throws Exception{n = sc.nextInt();d = sc.nextInt();for(int i = 1; i <= n; i++) {int x,y;x = sc.nextInt();y = sc.nextInt();y = Math.abs(y);if(y > d) {System.out.println(-1);return;}a[i] = new node();a[i].l = x - Math.sqrt(d*d-y*y);a[i].r = x + Math.sqrt(d*d-y*y);}Arrays.sort(a,1,1 + n,new cmp());
// for(int i = 1; i <= n; i++) {
// System.out.println(a[i].r);
// }for(int i = 1;i <= n; i++) {if(!vis[i]) {ans++;vis[i] = true;for(int j = i + 1; j <= n; j++) {if(a[j].l <= a[i].r) {vis[j] = true;}}}}System.out.println(ans);}
}
class node{double l,r;
}
class cmp implements Comparator<node>{public int compare(node o1, node o2) {if(o1.r < o2.r) {return -1;}else {return 1;}}}
付账问题(平均值+排序❓)
思路:显然是所有人付的钱越接近平均数标准差越小,我们让所有人的数据尽可能接近标准差,首先算出平均值,然后将其进行排序,低于平均值的人把所有钱都拿出来,其余的由其他人平摊(需要注意精度问题,竟然还要用long double)
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>using namespace std;const int N = 500010;int n;
int a[N];int main()
{long double s;cin >> n >> s;for (int i = 0; i < n; i ++ ) scanf("%d", &a[i]);sort(a, a + n);long double res = 0, avg = s / n;for (int i = 0; i < n; i ++ ){double cur = s / (n - i);//当前需要交多少钱if (a[i] < cur) cur = a[i];//如果当前的钱不够,那么就全部交res += (cur - avg) * (cur - avg); //把平方加到答案里面s -= cur;//剩下需要交的钱就减少了cur}printf("%.4Lf\n", sqrt(res / n));return 0;
}
乘积最大(排序/双指针)
思路:对于k是奇数且k<n的情况,我们需要特殊处理一下,转换为普遍情况,我们取一个最大的数,此时k就转换为偶数,我们可以使用双指针算法,首先对所有数进行排序,很显然负数绝对值大的在左边,偶数绝对值大的在右边,如果必须选一个正的一个负的话,显然是选的负数绝对值较小的与正数数值较小的,加个负号,显然是比较小的。
public class Main{static Scanner sc = new Scanner(System.in);static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static int N = 100010;static int ans = 0;static int n = 0,k = 0;static int[]a = new int[N];static int mod = 1000000009;public static void main(String[] args) throws Exception{n = sc.nextInt();k = sc.nextInt();for(int i = 1; i <= n; i++) {a[i] = sc.nextInt();}Arrays.sort(a,1,1 +n);long res = 1;//初始化乘积int l = 1, r = n;int sign = 1;//标记符号位if(k % 2 == 1) {res = a[r--];//选取最大的一个数if(res < 0) {sign = -1;}k--;}while(k > 0) {long x = (long)a[l] * a[l+1];long y = (long)a[r] * a[r-1];if(x * sign > y * sign) {res = ((res % mod) * (x % mod));//不太懂为啥l += 2;}else {res = ((y % mod) * (res % mod));r -= 2;}k-=2;}System.out.println(res%mod);}// static int md(int x) {
// if(x > 0) {
// return x%mod;
// }else {
//
// }
// }}
public class Main{static Scanner sc = new Scanner(System.in);static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static int N = 100010;static int ans = 0;static int n = 0,k = 0;static int[]a = new int[N];static int mod = 1000000009;public static void main(String[] args) throws Exception{n = sc.nextInt();k = sc.nextInt();for(int i = 1; i <= n; i++) {a[i] = sc.nextInt();}Arrays.sort(a,1,1 +n);long res = 1;//初始化乘积int l = 1, r = n;int sign = 1;//标记符号位if(k % 2 == 1) {res = a[r--];//选取最大的一个数if(res < 0) {sign = -1;}k--;}while(k > 0) {long x = (long)a[l] * a[l+1];long y = (long)a[r] * a[r-1];if(x * sign > y * sign) {res = (md(x) * md(res));//不太懂为啥l += 2;}else {res = (md(y) * md(res));r -= 2;}k-=2;}System.out.println(md(res));}static long md(long x) {if(x > 0) {return x % mod;}else {return 0-((0-x)%(long)1000000009);}}}
是否判断正负都是可以的,不太懂
后缀表达式(👍绝对值/分类讨论/贪心)
中缀表达式:运算符在两个操作数的位置
后缀表达式:运算符在两个操作数的后面
前缀表达式:运算符在两个操作数的前面
其实感觉和后缀表达式没有太大的关系,即使不懂也可以做
显然我们需要谈论:
(1)最简单的一种就是全是➕号,此时我们不需要进行什么操作,显然答案就是所有数的和。
(2)有一个➖号,此时我们可以通过不同的加减号的位置,可以是➕号也发挥减号的作用,-(+…+…)=>(-…-…),此时等价于好多➖号
(3)存在多个➖号,此时减号既可以当➕号,也可以当➖,因为-(-x) = +x,此时我们需要讨论所给数的正负,
对于全为加号的我们不在讨论,
如果存在减号,
1)如果全是正数,那么至少会有一个数会被减掉
2)如果全是负数,我们需要找一个最大的负数,其他的全变正数,比如-2,-3,-4,-5和3个减号,我们可以变为-2-(-5)-(-4)-(-3)此时显然是最大的。
3)有正有负,所有正数匹配正号,所有负数匹配负号,最终就是所有数的绝对值之和,比如1,2,(-3)转换为,2个➖号:1-(-3-2)=6,2-(-3-1)=6
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.util.Arrays;
import java.util.Scanner;public class Main{static Scanner sc = new Scanner(System.in);static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static int N = 1000100;static long ans = 0;static int n = 0,m = 0;static int[]a = new int[N];public static void main(String[] args) throws Exception{n = sc.nextInt();m = sc.nextInt();int k = n + m + 1;for(int i = 1; i <= k; i++) {a[i] = sc.nextInt();ans = ans + (long)a[i];}if(m == 0) {System.out.println(ans);}else {Arrays.sort(a,1,1+k);ans = 0;ans = a[k] - a[1];
// System.out.println(ans);for(int i = 2; i < k; i++) {ans = ans + (long)Math.abs(a[i]);}System.out.println(ans);}}}
相关文章:
![](https://img-blog.csdnimg.cn/c08bf7a248e346a58b2dc8fe540f9c57.png)
第七讲 贪心
文章目录股票买卖 II货仓选址(贪心:排序中位数)糖果传递(❗贪心:中位数)雷达设备(贪心排序)付账问题(平均值排序❓)乘积最大(排序/双指针)后缀表达…...
![](https://www.ngui.cc/images/no-images.jpg)
数字藏品的未来及发展趋势
随着互联网的普及以及数字文化的日益发展,数字藏品作为一种全新的收藏方式正在逐步兴起。数字藏品可以是数字版权、数字艺术品、数字音乐以及数字视频等形式,这些藏品通过数字化技术保存下来,并在互联网上进行传播和交易。数字藏品的发展趋势…...
![](https://img-blog.csdnimg.cn/17b35b5ed6e64720b913e1f588be6f78.jpeg)
值得记忆的STL常用算法,分分钟摆脱容器调用的困境,以vector为例,其余容器写法类似
STL常用算法 概述: 算法主要是由头文件<algorithm> <functional> <numeric>组成 <algorithm>是所有STL头文件中最大的一个,范围涉及到比较、交换、查找、遍历操作、复制、修改等等 <nuneric>体积很小,只包括…...
java如何手动导jar包
今天用IDEA,需要导入一个Jar包,因为以前都是用eclipse的,所以对这个idea还不怎么上手,连打个Jar包都是谷歌了一下。 但是发现网上谷歌到的做法一般都是去File –> Project Structure中去设置,有没有如同eclipse一样…...
![](https://www.ngui.cc/images/no-images.jpg)
怎么防止SQL注入?
首先SQL注入是一种常见的安全漏洞,黑客可以通过注入恶意代码来攻击数据库和应用程序。以下是一些防止SQL注入的基本措施: 数据库操作层面 使用参数化查询:参数化查询可以防止SQL注入,因为参数化查询会对用户输入的数据进行过滤和…...
![](https://img-blog.csdnimg.cn/d56ca138eacd4b729e9d341d1ad9937c.jpeg)
【千题案例】TypeScript获取两点之间的距离 | 中点 | 补点 | 向量 | 角度
我们在编写一些瞄准、绘制、擦除等功能函数时,经常会遇到计算两点之间的一些参数,那本篇文章就来讲一下两点之间的一系列参数计算。 目录 1️⃣ 两点之间的距离 ①实现原理 ②代码实现及结果 2️⃣两点之间的中点 ①实现原理 ②代码实现及结果 3…...
![](https://img-blog.csdnimg.cn/ea6c74bbf4a04dc78883e0264f7582fd.png)
堆叠注入--攻防世界CTF赛题学习
在一次联系CTF赛题中才了解到堆叠注入,在这里简单介绍一下。 堆叠注入的原理什么的一搜一大堆,我就不引用百度了,直接进入正题。 这个是攻防世界的一道CTF赛题。 采用寻常思路来寻找sql注入漏洞。 payload:1 and 11-- 利用payload: and 12…...
![](https://img-blog.csdnimg.cn/img_convert/d09b30dda49838b5e09488a48d320c60.png)
STM32 ADC+定时器+DMA+FFT
本次实现的功能为单片机DAC输出一个正弦波,然后ADC定时采样用DMA输出,最后对DAC输出的波形进行FFT。单片机STM32F103ZET6内部时钟一、配置ADCADC端口为PA1,采用DMA输出,定时器3触发定时器时钟64M,分频后为102.4KHzADC采…...
![](https://www.ngui.cc/images/no-images.jpg)
用Node.js实现一个HTTP服务器程序(文件服务器)
http Node.js开发的目的就是为了用JavaScript编写Web服务器程序。因为JavaScript实际上已经统治了浏览器端的脚本,其优势就是有世界上数量最多的前端开发人员。如果已经掌握了JavaScript前端开发,再学习一下如何将JavaScript应用在后端开发,就是名副其实的全栈了。 HTTP协…...
![](https://img-blog.csdnimg.cn/227820fabcfc48f98a3f9192febec938.gif)
Python实现人脸识别检测, 对美女主播照片进行评分排名
前言 嗨喽,大家好呀~这里是爱看美女的茜茜呐 素材、视频、代码、插件安装教程我都准备好了,直接在文末名片自取就可点击此处跳转 开发环境: Python 3.8 Pycharm 2021.2 模块使用: requests >>> pip install requests tqdm >…...
![](https://img-blog.csdnimg.cn/5261bf2a11124b798cf2e02aeb0bb25e.png)
【数据结构与算法】什么是双向链表?并用代码手动实现一个双向链表
文章目录一、什么是双向链表二、双向链表的简单实现一、什么是双向链表 我们来看一下这个例子: 在一个教室里,所有的课桌排成一列,如图 相信在你们的读书生涯中,老师肯定有要求你们记住自己的前后桌是谁。所以该例子中&#x…...
![](https://img-blog.csdnimg.cn/3a8e83662fea495baa36475c12c3922c.png)
23种设计模式
参考链接: 【狂神说Java】通俗易懂的23种设计模式教学(停更)_哔哩哔哩_bilibili 23种设计模式【狂神说】_狂神说设计模式_miss_you1213的博客-CSDN博客 1. 单例模式 参考链接: 【狂神说Java】单例模式-23种设计模式系列_哔哩哔哩…...
![](https://www.ngui.cc/images/no-images.jpg)
20美刀一个月的ChatGPT架构师,性价比逆天了
文章目录20美刀一个月的ChatGPT架构师,性价比逆天了1.角色设定2.基本描述3.解决方案4.物理网络蓝图5.系统集成接口5.1 系统集成接口设计5.1.1 前端服务器与后端服务器接口:5.1.2 后端服务器与去背景处理服务接口:5.2 系统集成接口展示6.部署环…...
![](https://www.ngui.cc/images/no-images.jpg)
海门区教育科学规划课题2020年度成果鉴定书
海门区教育科学规划课题2020年度成果鉴定书 课题编号:HMGZ2020007 课题名称 中学历史核心素养校本化实施的培育研究 主持人 徐彬 工作单位 南通市海门证大中学 核心组成员 (包括主持人) 姓名 研究任务完成情况 (获得的主要成果、…...
![](https://www.ngui.cc/images/no-images.jpg)
大数据专业应该怎么学习
大数据学习不能停留在理论的层面上,大数据方向切入应是全方位的,基础语言的学习只是很小的一个方面,编程落实到最后到编程思想。学习前一定要对大数据有一个整体的认识。 大数据是数据量多吗?其实并不是,通过Hadoop其…...
![](https://img-blog.csdnimg.cn/img_convert/2bb8cbc9344106d137781f8b514ef478.jpeg)
学习黑客十余年,如何成为一名高级的安全工程师?
1. 前言 说实话,一直到现在,我都认为绝大多数看我这篇文章的读者最后终究会放弃,原因很简单,自学终究是一种适合于极少数人的学习方法,而且非常非常慢,在这个过程中的变数过大,稍有不慎&#…...
![](https://img-blog.csdnimg.cn/a7d74ccc26644779aefa1e9785b71b86.png)
【算法】手把手学会二分查找
目录 简介 基本步骤 第一种二分 第二种二分 例题 搜索插入位置 数的范围 总结 简介 🥥二分查找,又叫折半查找,通过找到数据二段性每次都能将原来的数据筛选掉一半,通过这个算法我们能够将一个一个查找的 O(n) 的时间复杂…...
![](https://www.ngui.cc/images/no-images.jpg)
SVO、vinsmono、 OKVIS系统比较
几个经典视觉slam系统的比较 SVO 高翔链接:https://www.zhihu.com/question/39904950/answer/138644975处理的各个线程: tracking部分-frame to frame 、frame to map 金字塔的处理。这一步估计是从金字塔的顶层开始,把上一层的结果作为下一层估计的初…...
![](https://www.ngui.cc/images/no-images.jpg)
前端开发规范
一、开发工具 开发工具统一使用 VSCode代码格式化插件使用 Prettier代码格式校验使用 ESLintVSCode 需安装的插件有:ESLint、Prettier、Vetur 二、命名规范 项目命名使用小写字母,以连字符分隔 正确:fe-project 错误:FE PROJECT…...
![](https://img-blog.csdnimg.cn/img_convert/7795cb1f35442887b891cf7b3665a2de.png)
不用科学上网,免费的GPT-4 IDE工具Cursor保姆级使用教程
大家好,我是可乐。 过去的一周,真是疯狂的一周。 GPT-4 震撼发布,拥有了多模态能力,不仅能和GPT3一样进行文字对话,还能读懂图片; 然后斯坦福大学发布 Alpaca 7 B,性能匹敌 GPT-3.5ÿ…...
![](https://www.ngui.cc/images/no-images.jpg)
【艾特淘】抖音小店物流体验分提升的6个维度,新手做店必看
抖音小店体验分,考核的内容包括商品、物流以及服务。大部分人会把重心放在商品评价和服务上,忽略了物流体验。但其实,抖音小店物流体验占比有20%,比服务分的占比还高一点。如果你的订单物流出了问题,很有可能会导致用户…...
![](https://img-blog.csdnimg.cn/9c152e18a85b46f78bb7ca2919c1a56f.png)
数据结构——二叉树与堆
作者:几冬雪来 时间: 内容:二叉树与堆内容讲解 目录 前言: 1.完全二叉树的存储: 2.堆的实现: 1.创建文件: 2.定义结构体: 3.初始化结构体: 4.扩容空间与扩容…...
![](https://img-blog.csdnimg.cn/4076c3bedf0e4d40aff5ac08352a9850.png)
Three.js——learn02
Three.js——learn02Three.js——learn02通过轨道控制器查看物体OrbitControls核心代码index2.htmlindex.cssindex2.jsresult添加辅助器1.坐标轴辅助器AxesHelper核心代码完整代码2.箭头辅助器ArrowHelper核心代码完整代码3.相机视锥体辅助器CameraHelper核心代码完整代码Three…...
![](https://img-blog.csdnimg.cn/img_convert/e992045027882e8f94d70ab26ed681cc.png)
零基础小白如何入门网络安全?
我经常会看到这一类的问题: 学习XXX知识没效果; 学习XXX技能没方向; 学习XXX没办法入门; 给大家一个忠告,如果你完全没有基础的话,前期最好不要盲目去找资料学习,因为大部分人把资料收集好之…...
![](https://img-blog.csdnimg.cn/b0dd2b2f8dca48ccb12d594f0d6e3060.png)
【前缀和】
前缀和前缀和子矩阵的和结语前缀和 输入一个长度为 n的整数序列。 接下来再输入 m 个询问,每个询问输入一对 l,r 对于每个询问,输出原序列中从第 l 个数到第 r个数的和。 输入格式第一行包含两个整数 n和 m 第二行包含 n个整数,表示整数…...
ChatGPT可以做WebRTC音视频质量性能优化,惊艳到我了
摘要 随着GPT-4的发布,AI的风越吹越旺。GPT-4可以回答问题,可以写作,甚至可以基于一张草图生成html代码搭建一个网站。即构社区的一位开发者倪同学就基于目前在研究的WebRTC QOS技术点对GPT-3.5跟GPT-4进行一场实验,ChatGPT会取代…...
![](https://img-blog.csdnimg.cn/ca51a72e133949efb54779c6a0735f4c.jpeg#pic_center)
MySQL数据库实现主从同步
安装MySQL数据库8.0.32 前言 今天来学习数据库主从同步的原理及过程,数据库主要是用来存储WEB数据,在企业当中是极为重要的,下面一起来看下。 1.1 数据库做主从的目的 MySQL主从复制在中小企业,大型企业中广泛使用,…...
![](https://img-blog.csdnimg.cn/d88742a601d54b8e845664bd8138fd5e.png)
go语言gin框架学习
让框架去做http解包封包等,让我们的精力用在应用层开发 MVC模式 M: model,操作数据库gorm view 视图 处理模板页面 contoller 控制器 路由 逻辑函数 解决gin相关代码飘红的问题 记得启用gomodule go env -w GO111MODULEon然后到相应目录下执行 go mod i…...
![](https://img-blog.csdnimg.cn/d47377d470cf4ef68ac620a95dd3ea84.png)
Java奠基】Java经典案例讲解
目录 卖飞机票 找质数 开发验证码 数组元素的复制 评委打分 数字加密 数字解密 抢红包 模拟双色球 二维数组 卖飞机票 需求:机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。按照如下规则计算机票价格: 旺季&…...
![](https://img-blog.csdnimg.cn/4aaf81b863b24cad972cba464d8f7b2f.png)
新闻文本分类任务:使用Transformer实现
❤️觉得内容不错的话,欢迎点赞收藏加关注😊😊😊,后续会继续输入更多优质内容❤️👉有问题欢迎大家加关注私戳或者评论(包括但不限于NLP算法相关,linux学习相关,读研读博…...
![](/images/no-images.jpg)
平湖新埭哪里有做网站的/外链发布平台
电脑史话(40)——窗含千秋雪凡使用过IBM PC机的人都知道,在DOS操作系统的控制下,无论让电脑干什么,都必须记住各种操作命令,在键盘上不停敲打,输入一大串文字字符,带来诸多不便。 1985年11月,微…...
![](/images/no-images.jpg)
做相册网站logo/网推怎么做
转载于:https://www.cnblogs.com/6DAN_HUST/archive/2013/06/02/3114323.html...
![](/images/no-images.jpg)
网站首页关键字方案/百度seo引流怎么做
一.创建一张HTML页面 初学者创建一张html页面建议借助工具,例如Dreamweaver可视化编辑器。 二.<Script>标签解析 <script>xxx</script>这组标签,是用于在html页面中插入js的主要方法。它主要有以下几个属性&…...
![](http://hi.csdn.net/attachment/201112/1/0_1322708778u3rs.gif)
贵阳免费网站建设/企业营销策划
转载地址:http://www.cnblogs.com/rollenholt/archive/2011/08/28/2156357.html java中的多线程 在java中要想实现多线程,有两种手段,一种是继续Thread类,另外一种是实现Runable接口。 对于直接继承Thread的类来说,代…...
![](https://img-blog.csdnimg.cn/df65e8ce226f495db33dca07113cb306.png)
镇江海绵城市建设官方网站/站长工具查询seo
主要是编写shell代码部分问题: 注:for i相当于for i in $* (取全部位置参数)下文存在不在赘述 4.对教材例题4.9 (P108)进行编辑,然后执行。 #!/bin/bash echo $0 $1 $2 $3 $4 $5 $6 $7 $8 $9 shift echo $0 $1 $2 $3 $4 $5 $6 $7 $8 $9 shift 4 echo …...
![](/images/no-images.jpg)
html5 metro风格网站模板/哪有培训seo
1、跳到最后一行 :$或者shiftg或者vi test.txt 2、跳到第一行 :1或者gg或者vi 1 test.txt 3、查找指定字符 :/testtimer 向下查找第一次出现testtimer的地方,往下查找直接按回车。 :?testtimer 向上查找第一次出现testtimer的地方。 …...