【代码随想录】LC 455. 分发饼干

文章目录

  • 前言
  • 一、题目
    • 1、原题链接
    • 2、题目描述
  • 二、解题报告
    • 1、思路分析
    • 2、时间复杂度
    • 3、代码详解

前言

本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记,如有侵权,立即删除。

一、题目

1、原题链接

455. 分发饼干

2、题目描述

在这里插入图片描述

二、解题报告

1、思路分析

(1)根据贪心的思路,由于大饼干可以满足胃口大的孩子,也能满足胃口小的孩子,我们为了能够让更多的孩子得到满足,我们可以优先将大的饼干先满足胃口大的孩子,然后以此类推,将次小的饼干满足胃口次小的孩子…
(2)所以我们可以先将每个孩子的胃口值和每个饼干的尺寸进行排序。然后从胃口大的孩子开始枚举,同样用尺寸大的饼干开始枚举,判断该饼干能否满足该孩子,若能则记录的答案数加一,同时枚举下一个孩子和下一个饼干;若不能满足,枚举下一个孩子,还是上次枚举的饼干,看是否能满足,以此类推。(注:在枚举过程中,由于胃口数组和饼干数组可能长度不一致以及每次枚举时元素是否需要变化等问题,同时注意数组的边界问题

2、时间复杂度

时间复杂度O(nlogn)

3、代码详解

class Solution {
public:int findContentChildren(vector<int>& g, vector<int>& s) {int ans = 0;    //记录答案sort(g.begin(), g.end());sort(s.begin(), s.end());int j = s.size() - 1;    //饼干数组指针,初始指向最大尺寸饼干下标,也就是最后一个元素下标//从后往前枚举孩子for (int i = g.size() - 1; i >= 0; i--) {//注意条件,j>=0要首先判断,否则会出现数组下标越界,出现错误if (j >= 0 && g[i] <= s[j] ) {  //若s[j]饼干可以满足g[i]孩子则答案+1、饼干数组指针前移ans++;j--;}}return ans;}
};

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

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

相关文章

【文件上传WAF绕过】<?绕过、.htaccess木马、.php绕过

&#x1f36c; 博主介绍&#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 hacker-routing &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【应急响应】 【python】 【VulnHub靶场复现】【面试分析】 &#x1f389;点赞➕评论➕收藏…

go语言!! 来学习go吧,让我们一起go!go!go!

获取资源&#xff1a;关注公众号&#xff0c;回复&#xff1a;go 背景介绍 Go语言是谷歌推出的一种全新的编程语言&#xff0c;可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发Go&#xff0c;是因为过去10多年间软…

linux免密登录的实现

ssh免密登录使用方便&#xff0c;关键没有了口令验证反倒规避了暴力破解或者被探测的风险。配置得当&#xff0c;使用ssh免密登录更加安全。在生产环境中应用和数据库服务器之间互相设置后使用方便&#xff0c;并且在第三方人员配置使用时不用告知对方密码。 第一步、ssh登录发…

【傻瓜式教程】docker运行facechain

首选&#xff0c;为了防止后期docker满&#xff0c;Docker容器 - 启动报错&#xff1a;No space left on device&#xff0c;更换一下docker存储位置 1、停止Docker服务 首先停止Docker守护进程&#xff0c;可以使用以下命令&#xff1a; sudo systemctl stop docker 备份现有…

flask基于django大数据的证券股票分析系统python可视化大屏

证券分析系统采用B/S架构&#xff0c;数据库是MySQL。网站的搭建与开发采用了先进的Python进行编写&#xff0c;使用了Django框架。该系统从两个对象&#xff1a;由管理员和用户来对系统进行设计构建。主要功能包括&#xff1a;个人信息修改&#xff0c;对股票信息、股票买入、…

java学习04 循环高级

一 无限循环 1.for格式&#xff1a; for(;;){System.out.println("循环执行一直在打印内容"); } 解释&#xff1a; 初始化语句可以空着不写&#xff0c;表示循环之前不定义任何的控制变量。 条件判断语句可以空着不写&#xff0c;如果不写&#xff0c;默认表示t…

C++函数分文件编写之VScode版

VScode实现函数的分文件编写 1.下载插件创建项目2.分文件编写内容3.修改主函数文件名 我在分享内容时经常用的软件是VScode&#xff0c;相信有些内存敏感或需要VScode便利性的小伙伴也是更愿意使用VScode。那么接下来我们就盘一盘怎样使用VScode实现分文件编写。 1.下载插件创建…

【lesson6】高并发内存池Page Cache层申请内存的实现

文章目录 Page Cache层的结构申请内存的流程释放内存的流程Page Cache对象结构Page Cache所需要的成员变量Page Cache所需要的成员变量GetInstance()的实现NewSpan()的实现GetOneSpan()的实现NewSpan()的实现 Page Cache层实现的全部代码Common.hThreadCache.hThreadCache.cppC…

推荐收藏!算法工程师面试常考的手撕面试题!

今天给大家分享一些算法工程师技术面试中常手撕的代码。 不管是秋招还是社招&#xff0c;互联网大厂的技术面试中的手撕代码这一部分总是绕不过去的一关。 如果你对这些感兴趣&#xff0c;可以文末找我们交流 手撕 numpy写线性回归的随机梯度下降&#xff08;stochastic gra…

Dash :一个超漂亮的 python Web库!

你好&#xff0c;Dash 是一个非常方便的 Python 库&#xff0c;它可以非常非常帮助你构建基于 Web 的应用程序&#xff0c;而且最棒的是你无需使用 JavaScript&#xff01; 不仅如此&#xff0c;Dash 还是一个专门用于创建分析 Web 应用程序的用户界面库。 如果你是一个使用 …

帮管客CRM 文件上传漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

css3 属性 backface-visibility 的实践应用

backface-visibility 是一个用于控制元素在面对屏幕不同方向时的可见性的CSS3特性。它有两个可能的值&#xff1a; visible&#xff1a;当元素不面向屏幕&#xff08;即背面朝向用户&#xff09;时&#xff0c;元素的内容是可以被看到的。hidden&#xff1a;当元素不面向屏幕…