码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode·304竞赛·6132·使数组中所有元素都等于零·模拟·哈希


    链接:https://leetcode.cn/problems/make-array-zero-by-subtracting-equal-amounts/solution/by-xun-ge-v-a5s6/
    来源:力扣(LeetCode)
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 

    题目

     

    示例

     

    思路

    解题思路

    • 暴力求解

    题目需要我们寻找 最少 操作数,那么直接按题目给定要求进行模拟操作:

    • 对元素进行升序处理,每次寻找第一个非0元素 x
    • 选出一个正整数 x ,x 需要小于或等于 nums 中 最小 的 非零 元素。
    • nums 中的每个正整数都减去 x。
    • 减去会再升序处理

    • 简易哈希表

    再次读题目,可以发现,其实题目就等价于求数组中非0元素的个数,我们定义一个简易哈希表记录数组中不同元素的个数,最后相加即可

    代码

    暴力求解

    1. int cmp(const void * a, const void * b)//升序
    2. {
    3. return *(int *)a - *(int *)b;
    4. }
    5. int minimumOperations(int* nums, int numsSize){
    6. qsort(nums, numsSize,sizeof(int), cmp);//升序
    7. int conut = 0;
    8. for(int i = 0; i < numsSize; i++)//枚举整个数组
    9. {
    10. if(nums[i] == 0)//寻找第一个非0元素
    11. {
    12. continue;
    13. }
    14. conut++;
    15. int m = nums[i];
    16. for(int j = i; j < numsSize; j++)//nums 中的每个正整数都减去 x
    17. {
    18. nums[j] = nums[j] - m;
    19. }
    20. qsort(nums, numsSize,sizeof(int), cmp);//再升序
    21. }
    22. return conut;
    23. }
    24. 作者:xun-ge-v
    25. 链接:https://leetcode.cn/problems/make-array-zero-by-subtracting-equal-amounts/solution/by-xun-ge-v-a5s6/
    26. 来源:力扣(LeetCode)
    27. 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

    简易哈希表

    1. int minimumOperations(int* nums, int numsSize){
    2. int ans[101];
    3. memset(ans, 0, sizeof(int) * 101);//初始化
    4. for(int i = 0; i < numsSize; i++)//记录不同元素的个数
    5. {
    6. ans[nums[i]] = 1;
    7. }
    8. int conut = 0;
    9. for(int i = 1; i < 101; i++)//累加
    10. {
    11. conut += ans[i];
    12. }
    13. return conut;
    14. }
    15. 作者:xun-ge-v
    16. 链接:https://leetcode.cn/problems/make-array-zero-by-subtracting-equal-amounts/solution/by-xun-ge-v-a5s6/
    17. 来源:力扣(LeetCode)
    18. 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

    时间空间复杂度

     

  • 相关阅读:
    C语言语法笔记
    通师高专科技创新社训练赛(20221130)
    Tc99m-TEx-Cy7 荧光素偶联修饰99m同位素的外泌体
    DSPE-PEG-TAT,磷脂-聚乙二醇-靶向穿膜肽,脂质体修饰细胞穿膜肽TAT
    axios和vuex
    Spring之@Column的注解详解
    关于灭弧式智慧用电在养老机构的应用案例分析-安科瑞 蒋静
    R语言ggplot2可视化:使用ggpubr包的ggboxplot函数可视化分组箱图、使用set_palette函数同时改变可视化图像的线条色和填充色
    strcpy函数详解:字符串复制的利器
    短视频如何批量添加水印
  • 原文地址:https://blog.csdn.net/m0_64560763/article/details/126084452
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号