当前位置: 首页 > news >正文

用java做直播网站谷歌搜索入口

用java做直播网站,谷歌搜索入口,宁波专业做网站,合肥房产网新楼盘目录 分发饼⼲(easy) 题目解析 讲解算法原理 编写代码 最优除法(medium) 题目解析 讲解算法原理 编写代码 分发饼⼲(easy) 题目解析 1.题目链接:. - 力扣(LeetCode&#xf…

目录

分发饼⼲(easy)

题目解析

讲解算法原理

编写代码

最优除法(medium)

题目解析

讲解算法原理

编写代码


分发饼⼲(easy)

题目解析

1.题目链接:. - 力扣(LeetCode)

2.题目描述

假设你是⼀位很棒的家⻓,想要给你的孩⼦们⼀些⼩饼⼲。但是,每个孩⼦最多只能给⼀块饼⼲。对每个孩⼦ i ,都有⼀个胃⼝值 g[i] (,)这是能让孩⼦们满⾜胃⼝的饼⼲的最⼩尺⼨;并且每块
饼⼲ j ,都有⼀个尺⼨ s[j] ()。如果 s[j] >= g[i] ,我们可以将这个饼⼲ j 分配给孩⼦
i ,这个孩⼦会得到满⾜。你的⽬标是尽可能满⾜越多数量的孩⼦,并输出这个最⼤数值。
⽰例1:
输⼊:g=[1,2,3],s=[1,1]
输出:1
解释:
你有三个孩⼦和两块⼩饼⼲,3个孩⼦的胃⼝值分别是:1,2,3。虽然你有两块⼩饼⼲,由于他们的尺⼨都是1,你只能让胃⼝值是1的孩⼦满⾜。所以你应该输出1。
⽰例2:
输⼊:g=[1,2],s=[1,2,3]
输出:2
解释:
你有两个孩⼦和三块⼩饼⼲,2个孩⼦的胃⼝值分别是1,2。你拥有的饼⼲数量和尺⼨都⾜以让所有孩⼦满⾜。
所以你应该输出2.

提⽰:
◦ 1 <= g.length <= 3 * 10(4)
◦ 0 <= s.length <= 3 * 10(4)
◦ 1 <= g[i], s[j] <= 2(31) - 1

讲解算法原理

解法(贪⼼):
既然是很棒的家⻓,为什么不多买⼀些饼⼲呢

贪⼼策略:
先将两个数组排序。
针对胃⼝较⼩的孩⼦,从⼩到⼤挑选饼⼲:
i. 如果当前饼⼲能满⾜,直接喂(最⼩的饼⼲都能满⾜,不要浪费⼤饼⼲);ii. 如果当前饼⼲不能满⾜,放弃这个饼⼲,去检测下⼀个饼⼲(这个饼⼲连最⼩胃⼝的孩⼦都
⽆法满⾜,更别提那些胃⼝⼤的孩⼦了)。

编写代码

c++算法代码:

class Solution
{
public:int findContentChildren(vector<int>& g, vector<int>& s) {// 先排序sort(g.begin(), g.end());sort(s.begin(), s.end());// 利⽤双指针找答案int ret = 0, n = s.size();for(int i = 0, j = 0; i < g.size() && j < n; i++, j++){while(j < n && s[j] < g[i]) j++; // 找饼⼲if(j < n) ret++;}return ret;}
};

java算法代码:

class Solution
{public int findContentChildren(int[] g, int[] s) {// 排序Arrays.sort(g);Arrays.sort(s);// 利⽤双指针找答案int ret = 0, m = g.length, n = s.length;for(int i = 0, j = 0; i < m && j < n; i++, j++){while(j < n && s[j] < g[i]) j++; // 找饼⼲if(j < n) ret++;}return ret;}
}

最优除法(medium)

题目解析

1.题目链接:. - 力扣(LeetCode)

2.题目描述

给定⼀正整数数组 nums , nums 中的相邻整数将进⾏浮点除法。例如,[2,3,4]->2/3/4。• 例如, nums = [2,3,4] ,我们将求表达式的值 "2/3/4" 。
但是,你可以在任意位置添加任意数⽬的括号,来改变算数的优先级。你需要找出怎么添加括号,以便计算后的表达式的值为最⼤值。
以字符串格式返回具有最⼤值的对应表达式。
注意:你的表达式不应该包含多余的括号。

⽰例1:
输⼊:[1000,100,10,2]
输出:"1000/(100/10/2)"
解释:1000/(100/10/2)=1000/((100/10)/2)=200
但是,以下加粗的括号"1000/((100/10)/2)"是冗余的,
因为他们并不影响操作的优先级,所以你需要返回"1000/(100/10/2)"。
其他⽤例:
1000/(100/10)/2=50
1000/(100/(10/2))=50
1000/100/10/2=0.5
1000/100/(10/2)=2

⽰例2:
输⼊:nums=[2,3,4]
输出:"2/(3/4)"
解释:(2/(3/4))=8/3=2.667
可以看出,在尝试了所有的可能性之后,我们⽆法得到⼀个结果⼤于2.667的表达式。
说明:
◦ 1 <= nums.length <= 10
◦ 2 <= nums[i] <= 1000
◦ 对于给定的输⼊只有⼀种最优除法。

讲解算法原理

解法(贪⼼):
贪⼼策略:

在最终的结果中,前两个数的位置是⽆法改变的。
因为每⼀个数的都是⼤于等于 2 的,为了让结果更⼤,我们应该尽可能的把剩下的数全都放在「分⼦」上。

编写代码

c++算法代码:

class Solution
{
public:string optimalDivision(vector<int>& nums) {int n = nums.size();// 先处理两个边界情况if(n == 1){return to_string(nums[0]);}if(n == 2){return to_string(nums[0]) + "/" + to_string(nums[1]);}string ret = to_string(nums[0]) + "/(" + to_string(nums[1]);for(int i = 2; i < n; i++){ret += "/" + to_string(nums[i]);}ret += ")";return ret;}
};

java算法代码:

class Solution
{public String optimalDivision(int[] nums) {int n = nums.length;StringBuffer ret = new StringBuffer();// 先处理两个边界情况if(n == 1){return ret.append(nums[0]).toString();}if(n == 2){return ret.append(nums[0]).append("/").append(nums[1]).toString();}ret.append(nums[0]).append("/(").append(nums[1]);for(int i = 2; i < n; i++){ret.append("/").append(nums[i]);}ret.append(")");return ret.toString();}
}

http://www.dinnco.com/news/34601.html

相关文章:

  • 做网站敲代码的图片电商自学网
  • 德州极速网站建设百家号火星时代教育培训机构官网
  • 独家实用的网址大全天猫淘宝网站结构优化的内容和方法
  • 单县网站建设站长工具官网查询
  • 网站变灰 兼容北京百度推广投诉电话
  • wordpress主题演示插件湖北seo关键词排名优化软件
  • 国外域名需要实名吗网站seo优化建议
  • 新人怎么自己做网站优化大师人工服务电话
  • 免费制作软件的网站今日重大事件
  • 网站建设与制作dw8教程app地推接单平台
  • wordpress 个性网站40个免费网站推广平台
  • 大良营销网站建设市场市场推广工作内容
  • 计算机系毕业论文想要做好一个网站 怎么做免费收录软文网站
  • 晚上做羞羞的事情视频网站网络公司取什么名字好
  • 大学生毕业设计课题做网站互联网广告推广是做什么的
  • 企业做网站须要注意些什么百度品牌专区怎么收费
  • 付网站首期合同款怎么做分录网络运营培训课程
  • 做外贸相关的网站今日军事新闻头条打仗
  • 做地方网站能赚钱吗数据分析师培训需要多少钱
  • 音乐网站开发文档湖北疫情最新情况
  • 怎样做聊天网站seo是什么公司
  • 系统集成销售和网站建设销售网址
  • 个人网站不备案做经营性质网站百度关键词价格排行榜
  • 网站怎么做英文版的seo是什么职业
  • 网站域名被劫持怎么修复google首页
  • ppt设计工具怎么调出来seo智能优化系统
  • 云南网站营销新站如何让百度快速收录
  • 珠海网站建设及优化网络营销课程培训机构
  • 如何做区块链网站网站网络推广优化
  • 深圳品牌营销网站建设竞猜世界杯