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

力扣面试经典150题day3第五题(lc69),第六题(lc189)

文章目录

  • 一、lc169
    • 1.排序做法
    • 2.灵神做法 打擂台
  • 二、lc189
    • 1.引入额外数组
    • 2.原地翻转


一、lc169

1.排序做法

因为众数的定义为出现次数大于(n/2),所以数组长度一半位置的元素一定为众数,可以不用进行遍历计数,统计出众数(不用排序也计数统计出众数,但需要利用map保存是哪个元素的数目,排序后不需要,所有相同的元素排在一起了,只需遍历完一个元素的数目后,与n/2进行比较即可)

class Solution {public int majorityElement(int[] nums) {Arrays.sort(nums);return nums[nums.length / 2];}
}

2.灵神做法 打擂台

nums[0]先做为擂主,初始血量为1,遍历后面元素,遇到同门(相同元素),血量加1,遇到对手(不同元素),血量减1,当血量为0时,换当前位置元素为擂主,遍历完后擂主的为众数。严格证明可以看代码下面的链接

class Solution {public int majorityElement(int[] nums) {int ans = 0;int hp = 0;for (int x : nums) {if (hp == 0) { // x 是初始擂主,生命值为 1ans = x;hp = 1;} else { // 比武,同门加血,否则扣血hp += x == ans ? 1 : -1;}}return ans;}
}作者:灵茶山艾府
链接:https://leetcode.cn/problems/majority-element/solutions/3744717/on-mo-er-tou-piao-fa-yan-jin-zheng-ming-ww1zv/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

二、lc189

1.引入额外数组

引入额外数组,备份nums数组,再把nums2中(i+k)%n的位置的元素移回nums数组中i的位置把数组看成环形的,右移k,相当于下标+k,由于数组长度为n,i+k大于n时越界了,需要对i+k取模,放在nums数组前面

class Solution {public void rotate(int[] nums, int k) {int n = nums.length;int[] nums2 = new int[n];int tmp;int nex;for(int i = 0;i<n;i++){nums2[i]=nums[i];}for(int i=0;i<n;i++){nex=(i+k)%n;nums[nex]=nums2[i];}}
}

2.原地翻转

class Solution {public void rotate(int[] nums, int k) {int n = nums.length;k %= n; // 轮转 k 次等于轮转 k % n 次reverse(nums, 0, n - 1);reverse(nums, 0, k - 1);reverse(nums, k, n - 1);}private void reverse(int[] nums, int i, int j) {while (i < j) {int temp = nums[i];nums[i++] = nums[j];nums[j--] = temp;}}
}作者:灵茶山艾府
链接:https://leetcode.cn/problems/rotate-array/solutions/2784427/tu-jie-yuan-di-zuo-fa-yi-tu-miao-dong-py-ryfv/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

http://www.dtcms.com/a/471112.html

相关文章:

  • 做网站去哪好盘锦威旺做网站建设
  • 字符串相关的方法有哪些?
  • 标签预制体上的组件
  • cms免费企业网站湖南网站模板建站
  • 【流氓软件】流氓软件及处理方法
  • 网站开发职业怎么经营网店生意才会好
  • 自动化脚本矩阵运营
  • 《Effective Java》第一条:用静态工厂方法代替构造器
  • 怎么做可以访问网站连接加密互联网营销模式
  • Diff-Shadow阴影去除
  • 怎么去接网站来做天津手机网站建设制作
  • 引擎搜索入口aso优化重要吗
  • 做外贸 需要做网站吗知名网站定制报价
  • 四川刚刚发布的最新新闻seo标题优化
  • 一文读懂 Flink Exactly-Once 保证机制深度解析
  • wordpress批量发布内容好的seo平台
  • Unity框架YouYouFramework学习第1篇:游戏入口
  • 专业的建设网站服务公司.网站建设课程设计
  • lnmp利用wordpress网站内链优化策略
  • 宁波做网站的哪个好logo设计多少钱
  • 昂瑞微:科创板逐浪者,射频“芯”征程的领航旗舰
  • Cyanine5.5-PEG-OH,在近红外区发射可用于活体成像
  • 网站注册建设外网代理服务器网站
  • Python文件访问
  • 静态网站设计找国外公司做网站
  • 建网站安全大型科技网站建设
  • Mysql初阶第六讲:Mysql内置函数
  • 怒江州建设局网站企业备案网站花溪村镇建设银行网站
  • 网站搭建合同模板2024很有可能再次封城吗
  • Terminal-Bench:AI 代理终端任务基准测试框架正式发布