【每日刷题】Day11

【每日刷题】Day11

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

目录

1. 860. 柠檬水找零 - 力扣(LeetCode)

2. 976. 三角形的最大周长 - 力扣(LeetCode)

3. 1232. 缀点成线 - 力扣(LeetCode)

1. 860. 柠檬水找零 - 力扣(LeetCode)

//思路:这题实际上只需要判断5元钱的剩余数。

bool lemonadeChange(int* bills, int billsSize)

{

    int i = 0;

    int five = 0;//用于记录收到5元的数量

    int ten = 0;//用于记录收到10元的数量

    for(i = 0;i<billsSize;i++)

    {

        if(bills[i]==5)

        {

            five++;//收到5元,five++

        }

        else if(bills[i]==10)

        {

            ten++;//收到10元需要找回顾客5元,多一张10元

            five--;

        }

        else

        {

            if(ten>0)

            {

                ten--;//收到20元时,需要判断收到的10元个数,如果不为0,则可以用10元与5元结合找回给顾客

                five--;

            }

            else

            {

                five-=3;//否则只能找3张5元给顾客

            }

        }

        if(five<0)

        {

            return false;//如果最后5元数量小于0了,说明有顾客无法正确找零

        }

    }

    return true;

}

2. 976. 三角形的最大周长 - 力扣(LeetCode)

//思路:将数组先排为降序,然后从头开始三个三个遍历,因为是降序,所以需要让i+2和i+1的和大于i才能成为三角形。并且,因为是降序,所以第一个找到的能成为三角形的数据组一定是最大的

int largestPerimeter(int* nums, int numsSize)

{

    int i = 0;

    int j = 0;

    for(i = 0;i<numsSize-1;i++)

    {

        for(j = 0;j<numsSize-i-1;j++)

        {

            if(nums[j]<nums[j+1])

            {

                int tmp = nums[j];

                nums[j] = nums[j+1];//使用冒泡排序(这里可以有更好的排序算法)将数组排为降序

                nums[j+1] = tmp;

            }

        }

    }

    for(i = 0;i<numsSize-2;i++)

    {

        if(nums[i+2]+nums[i+1]>nums[i])

        {

            return nums[i]+nums[i+1]+nums[i+2];//只要找到一个能成为三角形的数据组直接返回,一定是最大的

        }

    }

    return 0;

}

3. 1232. 缀点成线 - 力扣(LeetCode)

//思路:两点确定一条直线。将第一个点移回原点,后面的点根据第一个点的位移情况相应地位移;再根据原点和第二个点创建一条直线,将后面点地x、y带入方程中,通过判断方程是否有解来判断该点是否在直线上。需要注意地是,这里我们需要考虑直线平行于x、y轴的情况。

bool checkStraightLine(int** coordinates, int coordinatesSize, int* coordinatesColSize)

{

    int i = 0;

    int flag = 1;//用于判断方程是否有解

    int flag1 = 1;//用于判断直线是否平行于y轴

    int flag2 = 1;//用于判断直线是否平行于x轴

    int equ = 0;//方程

    int firstx = coordinates[0][0];//记录第一个点的x坐标,因为后面会改变第一个点的x、y坐标,因此这里需要记录初始值

    int firsty = coordinates[0][1];//记录第一个点的y坐标

    for(i = 0;i<coordinatesSize;i++)//将第一个点移动到原点,并相应移动后面的点

    {

        coordinates[i][0]-= firstx;

        coordinates[i][1]-= firsty;

    }

    for(i = 0;i<coordinatesSize-1;i++)//判断直线是否平行于y轴

    {

        if(coordinates[i][0]!=coordinates[i+1][0])

        {

            flag1 = 0;

        }

    }

    for(i = 0;i<coordinatesSize-1;i++)//判断直线是否平行于x轴

    {

        if(coordinates[i][1]!=coordinates[i+1][1])

        {

            flag2 = 0;

        }

    }

    if(flag1)//如果flag1不为0,则说明直线平行于y轴,直接返回true

    {

        return true;

    }

    if(flag2)//如果flag2不为0,则说明直线平行于x轴,直接返回true

    {

        return true;

    }

    for(i = 2;i<coordinatesSize;i++)//直线不平行于x轴也不平行于y轴,则通过方程判断每个点是否都在给定直线上

    {

        equ = ((coordinates[1][1]*coordinates[i][0])-(coordinates[1][0]*coordinates[i][1]));

        if(equ!=0)

        {

            flag = 0;

            break;

        }

    }

    if(flag)//如果flag不为0,则说明每个点都在直线上,返回true

    {

        return true;

    }

    return false;

}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

通信安全之数据加密

数据安全的需求如今越来越重要&#xff0c;本篇简单举例给日常的TCP/UDP通信加密&#xff0c;至少能让想干坏事的崽犯罪的成本更高一些&#xff08;如果会一些BPF的&#xff0c;可能难不住这些崽&#xff09;&#xff0c;能让我们的数据更安全一点。 经典TCP socket编程 下面…

In Memoriam Fabrizio Flacco

一、背景 最近在看人机协作相关的论文&#xff0c;其中有一篇是Arash Ajoudani于2018发表在Autonomous Robots题为Progress and prospects of the human–robot collaboration的综述。当看到最后Acknowledgements部分&#xff0c;有一句话是The authors would like to thank a…

小样本计数网络FamNet(Learning To Count Everything)

小样本计数网络FamNet(Learning To Count Everything) 大多数计数方法都仅仅针对一类特定的物体&#xff0c;如人群计数、汽车计数、动物计数等。一些方法可以进行多类物体的计数&#xff0c;但是training set中的类别和test set中的类别必须是相同的。 为了增加计数方法的可拓…

基于tcmalloc的高并发内存池

内存池 池化技术&#xff1a; 池是在计算机技术中经常使用的一种设计模式&#xff0c;其内涵在于&#xff1a;将程序中需要经常使用的核心资源 先申请出来&#xff0c;放到一个池内&#xff0c;由程序自己管理&#xff0c;这样可以提高资源的使用效率&#xff0c;也可以保证本程…

【新版HI3559AV100开发注意事项(四)】

新版HI3559AV100开发注意事项&#xff08;四&#xff09; 三十、HI3559A参数中对输入分辨率限制的原因是&#xff1f; 答&#xff1a;分辨率限制有两个来源&#xff1a; 一个是时钟频率最高为600M&#xff0c;开启一拍两像素之后相当于1200M。你这个数据量太大了&#xff0c;6…

【IR-SDE】Image Restoration SDE项目演示运行app.py

背景&#xff1a; code:GitHub - Algolzw/image-restoration-sde: Image Restoration with Mean-Reverting Stochastic Differential Equations, ICML 2023. Winning solution of the NTIRE 2023 Image Shadow Removal Challenge. paper: Official PyTorch Implementations o…

Terraform 语法配置

配置语法 Terraform 的配置文件都是以 .tf 为后缀Terraform 支持两种模式 HCL、JSON Provider 插件 providers 地址&#xff1a;Terraform Registry Terraform 通过 provider 管理基础设施&#xff0c;使用 provider 与云供应商 API 进行交互&#xff0c;每个 Provider 都包含…

2024年DeFi的四大主导趋势:Restaking、Layer3、AI和DePin

DeFi&#xff08;去中心化金融&#xff09;行业在2024年将继续呈现快速增长的势头&#xff0c;驱动这一增长的主要因素将是四大主导趋势&#xff1a;Restaking、Layer3、AI和DePin。这些趋势将推动DeFi生态系统的发展&#xff0c;为用户提供更多的机会和创新。 趋势1&#xff…

JavaScript函数式编程

函数式编程 课程介绍 为什么要学习函数编程以及什么是函数式编程函数式编程的特性(纯函数、柯里化、函数组合等)函数式编程的应用场景函数式编程库Lodash 为什么要学习函数式编程 函数式编程是非常古老的一个概念&#xff0c;早于第一台计算机的诞生&#xff0c; 函数式编程…

有图片转成PDF文件格式的方法吗?分享图片转成PDF文件的方法

将图片转换为PDF文件是一个相对简单的过程&#xff0c;但也需要一定的步骤和注意事项。下面&#xff0c;我将详细介绍如何将图片转换为PDF文件&#xff0c;包括所需的工具、步骤以及可能遇到的问题和解决方案。 首先&#xff0c;我们需要一个能够将图片转换为PDF文件的工具。市…

SV-704XT 100W网络有源音柱 校园广播音柱

SV-704XT 100W网络有源音柱 一、描述 SV-704XT是深圳锐科达电子有限公司的一款壁挂式网络有源音柱&#xff0c;具有10/100M以太网接口&#xff0c;可将网络音源通过自带的功放和喇叭输出播放&#xff0c;其采用防水设计&#xff0c;功率100W。SV-704XT作为网络广播播放系统的终…

分布式强化学习

标题 易混淆概念联邦学习与强化学习1&#xff09;联邦学习应用于强化学习2&#xff09;强化学习应用于联邦学习 时空图卷积网络&#xff08;ST-GCN&#xff09;基本概念结合训练 易混淆概念 DistributionalRL是分布RL&#xff0c;不是分布式RL。分布RL是把Q值从一个期望构建成…

程序员搞副业你可以这样做

程序员搞副业你可以这样做 文章目录 程序员搞副业你可以这样做01/开发外包项目02/开源项目赢取打赏盈利模式之一&#xff1a;多种产品线盈利模式之二&#xff1a;技术服务型盈利模式之三&#xff1a;应用服务托管&#xff08;ASP&#xff09;盈利模式之四&#xff1a;软、硬件一…

边缘计算网关究竟是什么呢?它又有什么作用呢?-天拓四方

在数字化时代&#xff0c;信息的传输与处理变得愈发重要&#xff0c;而其中的关键节点之一便是边缘计算网关。这一先进的网络设备&#xff0c;不仅扩展了云端功能至本地边缘设备&#xff0c;还使得边缘设备能够自主、快速地响应本地事件&#xff0c;提供了低延时、低成本、隐私…

20240412,引用,函数高级

老子什么时候能找到一个很爱我还和我一样喜欢看日出日落的对象 一&#xff0c;引用 给变量起别名&#xff0c;数据类型 & 别名原名&#xff1b;引用一定要初始化&#xff0c;初始化之后不能更改 #include <iostream> using namespace std; int main() {int a 10;i…

PostgreSQL入门到实战-第二十一弹

PostgreSQL入门到实战 PostgreSQL中表连接操作(五)官网地址PostgreSQL概述PostgreSQL中RIGHT JOIN命令理论PostgreSQL中RIGHT JOIN命令实战更新计划 PostgreSQL中表连接操作(五) 使用PostgreSQL RIGHT JOIN连接两个表&#xff0c;并从右表返回行 官网地址 声明: 由于操作系统…

【前沿模型解析】潜在扩散模型 2-3 | 手撕感知图像压缩 基础块 自注意力块

1 注意力机制回顾 同ResNet一样&#xff0c;注意力机制应该也是神经网络最重要的一部分了。 想象一下你在观看一场电影&#xff0c;但你的朋友在给你发短信。虽然你正在专心观看电影&#xff0c;但当你听到手机响起时&#xff0c;你会停下来查看短信&#xff0c;然后这时候电…

CSS特效---纯CSS实现点击切换按钮

1、演示 2、一切尽在代码中 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewport" content"w…

第11版《中国网络安全行业全景图》发布,谁霸榜了软件供应链安全领域?

近日&#xff0c;知名网络安全行业媒体安全牛正式发布了第11版《中国网络安全行业全景图》&#xff08;以下简称”全景图“&#xff09;&#xff0c;共收录了国内网络安全企业454家&#xff0c;细分领域共收录2413项&#xff0c;旨在优先展现当前热门网络安全领域中具有较强市场…

mysql题目1

tj11: ​ select * from t_student where grade 大一 and major 软件工程 ​ tj12: SELECTt_student.name, count(t_choice.cid)FROMt_choiceINNER JOINt_courseON t_choice.cid t_course.idINNER JOINt_studentON t_choice.sid t_student.id GROUP BYt_choice.sid HAVIN…