【每日刷题】Day52

【每日刷题】Day52

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

1. 2965. 找出缺失和重复的数字 - 力扣(LeetCode)

2. 350. 两个数组的交集 II - 力扣(LeetCode)

3. 2807. 在链表中插入最大公约数 - 力扣(LeetCode)

1. 2965. 找出缺失和重复的数字 - 力扣(LeetCode)

//思路:哈希表。维护一个长度为 (gridSize*(*gridColSize))的哈希表,将数组中的值作为键,键值+=1,键值等于2的键就是重复的数字,为0就是缺失的数字。

int* findMissingAndRepeatedValues(int** grid, int gridSize, int* gridColSize, int* returnSize)

{

    int* ans = (int*)malloc(sizeof(int)*2);

    int hash[10000] = {0};

    for(int i = 0;i<gridSize;i++)

    {

        for(int j = 0;j<(*gridColSize);j++)

        {

            hash[grid[i][j]]+=1;

        }

    }

    for(int i = 0;i<=gridSize*(*gridColSize);i++)

    {

        if(hash[i]==2)

        {

            ans[0] = i;

        }

        if(hash[i]==0)

        {

            ans[1] = i;

        }

    }

    *returnSize = 2;

    return ans;

}

2. 350. 两个数组的交集 II - 力扣(LeetCode)

//思路:哈希表。维护两个哈希表,分别存储nums1中元素出现的次数以及nums2中元素出现的次数。

int* intersect(int* nums1, int nums1Size, int* nums2, int nums2Size, int* returnSize)

{

    int* ans = (int*)malloc(sizeof(int)*1000);

    int count = 0;

    int hash1[1001] = {0};

    int hash2[1002] = {0};

    int i = 0;

    int j = 0;

    while(i<nums1Size||j<nums2Size)

    {

        if(i<nums1Size)

        {

            hash1[nums1[i]]+=1;

            i++;

        }

        if(j<nums2Size)

        {

            hash2[nums2[j]]+=1;

            j++;

        }

    }

    for(int i = 0;i<1001;i++)

    {

        if(hash1[i]!=0&&hash2[i]!=0&&(hash1[i]<=hash2[i]||hash1[i]>=hash2[i]))

        {

            int tmp = fmin(hash1[i],hash2[i]);

            while(tmp)

            {

                ans[count++] = i;

                tmp--;

            }

        }

    }

    *returnSize = count;

    return ans;

}

3. 2807. 在链表中插入最大公约数 - 力扣(LeetCode)

//辗转相除法求最大公约数。

//辗转相除法:x = 100 ,y = 18

① int tmp = x%y (10)

② x = y (18)

③ y = tmp (10)

//重复上述过程,直到x%y==0,此时y就是最大公约数

typedef struct ListNode LN;

struct ListNode* insertGreatestCommonDivisors(struct ListNode* head)

{

    LN* phead = head;

    LN* pnext = phead->next;

    while(pnext)

    {

        int x = phead->val;//100

        int y = pnext->val;//18

        while(x%y)

        {

            int tmp = x%y;//8

            x = y;//x = 10

            y = tmp;//y = 8

        }

        LN* newnode = (LN*)malloc(sizeof(LN));

        newnode->val = y;

        newnode->next = pnext;

        phead->next = newnode;

        phead = pnext;

        pnext = phead->next;

    }

    return head;

}

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

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

相关文章

kaggle竞赛系列基于图像对水稻分类代码案例

目录 依赖环境 代码 导入依赖包 定义数据集路径&#xff1a; 创建训练集、验证集和测试集的文件夹&#xff1a; 代码的作用&#xff1a; 设置新的数据集路径与类别名称 代码的作用&#xff1a; 定义数据预处理和增强变换&#xff1a; 代码的作用&#xff1a; 定义数…

【源码】多语言H5聊天室/thinkphp多国语言即时通讯/H5聊天室源码/在线聊天/全开源

多语言聊天室系统&#xff0c;可当即时通讯用&#xff0c;系统默认无需注册即可进入群聊天&#xff0c;全开源 【海外聊天室】多语言H5聊天室/thinkphp多国语言即时通讯/H5聊天室源码/在线聊天/全开源 - 吾爱资源网

每日5题Day13 - LeetCode 61 - 65

每一步向前都是向自己的梦想更近一步&#xff0c;坚持不懈&#xff0c;勇往直前&#xff01; 第一题&#xff1a;61. 旋转链表 - 力扣&#xff08;LeetCode&#xff09; /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;…

STM32学习和实践笔记(32):电容触摸按键实验

1.电容触摸按键原理介绍 触摸按键与传统的机械按键相比&#xff0c;不仅美观而且耐用、寿命长&#xff0c;它颠覆了传统意义上的机械按键控制&#xff0c;只要轻轻触摸&#xff0c;就可以实现按键开关的控制、量化调节甚至方向控制。触摸按键已广泛应用于手机、DVD、洗衣机等消…

宿舍管理系统带文档java项目基于springboot+vue的宿舍管理系统

文章目录 宿舍管理系统一、项目演示二、项目介绍三、八千字项目文档四、部分功能截图五、部分代码展示六、底部获取项目源码和8000字论文参考&#xff08;9.9&#xffe5;带走&#xff09; 宿舍管理系统 一、项目演示 宿舍管理系统 二、项目介绍 基于springbootvue的前后端分…

MVC、MVP 和 MVVM 架构总结

MVC、MVP 和 MVVM 是常见的软件架构模式&#xff0c;主要用于组织应用程序的结构&#xff0c;特别是在用户界面和业务逻辑之间进行分离。以下是对它们的详细解释&#xff0c;包括它们的差异、优缺点。 MVC&#xff08;Model-View-Controller&#xff09; 结构 Model&#xf…

C++的继承(十一):私有继承和受保护的继承

但凡用过C的人都知道&#xff1a;私有继承的成员在派生类里均为私有&#xff0c;受保护的继承公有和受保护的成员在派生类里为受保护。另外C不对私有继承和受保护的继承的派生类指针自动转化为基础类。 #include <stdio.h> struct X {int a;X():a(9) {}int sqare() {ret…

5.nginx平滑升级

nginx平滑升级 一、nginx平滑升级1、下载新版本的安装包2、以之前的安装参数来编译新版本软件3、将新版本的nginx拷贝到安装目录4、启动新版本进程5、平缓关闭旧工作进程6、清理旧版本的nginx 一、nginx平滑升级 USR2 启动新版本进程 WINCH 平缓关闭旧工作进程 1、下载新版本…

分层注入的设计模式-上下层文件相互包含解决办法

现象&#xff1a;上下层文件相互包含 写代码时&#xff0c;会不会遇到&#xff0c;业务层内容要在底层硬件程序里写&#xff0c; 例如&#xff1a;一个外部按键&#xff0c;按键中断要触发一个应用层业务。 业务就要写道IO中断里&#xff0c;这个代码就要用到上层一些函数和变…

在长窗口时代,RAG技术是否仍然必要?

自从谷歌推出 Gemini 1.5 Pro&#xff0c;行业内部对于 RAG 的讨论就不绝于耳。 Gemini 1.5 Pro 的性能确实令人瞩目。根据谷歌公布的技术文档&#xff0c;该系统能够稳定处理长达 100 token 的内容&#xff0c;相当于一小时的视频、十一小时的音频、超过三万行的代码或七十万…

【VTKExamples::Utilities】第十七期 ZBuffer

很高兴在雪易的CSDN遇见你 VTK技术爱好者 QQ:870202403 公众号:VTK忠粉 前言 本文分享VTK样例ZBuffer,并解析接口vtkWindowToImageFilter,希望对各位小伙伴有所帮助! 感谢各位小伙伴的点赞+关注,小易会继续努力分享,一起进步! 你的点赞就是我的动力(^U^)ノ…

24 _ 分层和合成机制:为什么CSS动画比JavaScript高效?

在上一篇文章中我们分析了CSS和JavaScript是如何影响到DOM树生成的&#xff0c;今天我们继续沿着渲染流水线向下分析&#xff0c;来聊聊DOM树之后所发生的事情。 在前面《05 | 渲染流程&#xff08;上&#xff09;&#xff1a;HTML、CSS和JavaScript文件&#xff0c;是如何变成…

linux下can-utils的使用以及can接口的配置(以ubuntu20.04为例)

linux下can-utils的使用以及can接口的配置&#xff08;以ubuntu20.04为例&#xff09; can-utils是什么 can-utils 是一套用于Linux操作系统的开源工具&#xff0c;专门用来处理与CAN&#xff08;Controller Area Network&#xff09;总线相关的任务。CAN总线广泛应用于汽车和…

C语言文件操作:打开关闭,读写

程序文件 源程序文件&#xff08;后缀为.c&#xff09; 目标文件&#xff08;Windows环境后缀为.obj&#xff09; 可执行文件&#xff08;Windows环境后缀为.exe&#xff09; fputc FILE* pf fopen("test.txt","w");if (pf NULL){printf("%s\n"…

深入理解Qt计算器应用的构建过程

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、数字按钮的信号与槽函数连接 二、运算符按钮的信号与槽函数连接 三、特殊按钮的信号与…

红外超声波雷达测距(water)

文章目录 一 RS-232二 RS485三 Modbus四 stm32多路超声波测距4.1 设计方案4.2 代码 参考资料总结 实验要求 一. 采用stm32F103和HC-SR04超声波模块&#xff0c; 使用标准库或HAL库 定时器中断&#xff0c;完成1或2路的超声波障碍物测距功能。 1&#xff09;测试数据包含噪声&am…

Bezier Python 用法:深入探索与实用指南

Bezier Python 用法&#xff1a;深入探索与实用指南 在数字图形学和计算机编程中&#xff0c;贝塞尔曲线&#xff08;Bezier Curves&#xff09;是一种重要的参数曲线&#xff0c;被广泛应用于二维图形应用程序中&#xff0c;如字体轮廓、矢量图形和动画等。Python作为一种功能…

EukRep:区分真核和原核序列

https://github.com/patrickwest/EukRep 安装 conda create -y -n eukrep-env -c bioconda scikit-learn0.19.2 eukrep mamba install -c conda-forge numpy1.19.5 使用 EukRep -i <Sequences in Fasta format> -o <Eukaryote sequence output fasta file>

【Linux】线程ID

大致草稿—————————— 思维导图 学习目标 一、线程ID的理解 1.1 引出对tid的理解 我们先来创建一个线程复习一下线程的函数&#xff1a; pthread_t tid; // 创建一个线程 pthread_create(&tid, nullptr, threadrun, (void*)"thread-1"); // 打印出…

二分查找学习:优雅的二分查找——“Leetcode 35. 搜索插入位置”

例题 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target 5 输出: 2 示例 2…