算法通关村第十三关—数学与数学基础问题(青铜)

      数学与数学基础问题

一、统计专题

1.1 符号统计

 LeetCode1822给定一个数组,求所有元素的乘积的符号,如果最终答案是负的返回-1,如果最终答案是正的返回1,如果答案是0返回0。
 题目比较简单,正数对结果完全没影响,只需判断有多少个负数和是否有0即可

class Solution {public int arraySign(int[] nums) {int judge = 1;for(int num: nums){if(num == 0) return 0;if(num < 0) judge *= -1;}return judge == 1 ? 1 : -1;}
}

1.2 阶乘0的个数

 Leetcode 172 给定一个整数n,返回 n!结果中尾随零的数量。
 这道题需要统计尾数有多少个0,那其实可以想成有多少对5和2,而5的数量是一定是少于2的,所以统计出5的个数即可得出结果

class Solution {public int trailingZeroes(int n) {int sum = 0;//求出所有5的倍数for(int i = 5; i <= n; i += 5){//这些数可以拆出多少个5for(int k = i; k % 5 == 0; k /= 5) sum++;}return sum;}
}

 当然,这道题还可以进行优化,例如:当某个数x是5的倍数时,当5^1 <= x < 5^2 时,它只含有一个5,像5,10,15,20;而当5^2 <= x< 5^3 时它包含两个5。所以,我们可以利用上述例子来计算0的个数。sum = n/5+n/(5^2)+…

lass Solution {public int trailingZeroes(int n) {int sum = 0;for(int i = 5; n / i > 0; i *= 5){sum += n / i;}return sum;}
}

二、溢出问题

2.1 整数反转

 LeetCode7 给你一个32位的有符号整数x,返回将x中的数字部分反转后的结果。如果反转后整数超过32位的有符号整数的范围[-231,231一1],就返回0。假设环境不允许存储64位整数(有符号或无符号)
image.png
 这道题要解决两个关键问题:1.如何进行整数反转;2.如何判断溢出
 对于整数反转,只需要创建另外一个变量rev来反转即可,不需要复杂的数据结构

例:123
123 % 10 = 3, 123 / 10 = 12 
rev = 0 * 10 + 3 = 312 % 10 = 2, 12 / 10 = 1
rev = 3 * 10 + 2 = 321 % 10 = 1, 1 / 10 = 0
rev = 32 * 10 + 1 = 321

 对于溢出问题,当int溢出时,会无法得到你正常运算结果的数,这里有两种解决方法。一种是讲义中对溢出的前一位就进行判断,另外一种我是用long类型变量来保存反转结果,这样可以在反转完一次性判断是否溢出。两种写法代码如下:

//第一种 讲义
class Solution {public int reverse(int x) {int rev = 0;while(x != 0){int max = Integer.MAX_VALUE;int min = Integer.MIN_VALUE;if(rev > max / 10 || (rev == max / 10 && x % 10 > max % 10)) return 0;if(rev < min / 10 || (rev == min / 10 && x % 10 < min % 10)) return 0;rev = rev * 10 + x % 10;x /= 10;}return rev;}
}
//第二种 自己发现的,时间复杂度也是击败100%
class Solution {public int reverse(int x) {long rev = 0;while(x != 0){rev = rev * 10 + x % 10;x /= 10;}if(rev > Integer.MAX_VALUE || rev < Integer.MIN_VALUE) return 0;return (int)rev;}
}

2.2 字符串转整数

Leetcode 8 :在字符串一关中

2.3 回文数

 LeetCode9 给你一个整数x,如果x是一个回文整数,返回true;否则,返回false
 根据题目要求,我们可以对整数x进行反转后与原数进行比较,若相等则为回文数,但这样要考虑溢出问题。所以,可以考虑反转一半的数,然后前后两部分进行比较。(注意考虑整数位数的奇偶)
代码如下:

public boolean isPalindrome(int x){
//特殊情况:
//如上所述,当x<0时,x不是回文数。
//同样地,如果数字的最后一位是0,为了使该数字为回文,
//则其第一位数字也应该是0
//只有0满足这一属性
if(x < 0 || (x % 10 = 0 && × != 0)) return false;
int revertedNumber 0;
while (x > revertedNumber){
revertedNumber = revertedNumber 10 + x % 10;
x /= 10;
}
//当数字长度为奇数时,我们可以通过revertedNumber/10去除处于中位的数字。
//例如,当输入为12321时,在while循环的末尾我们可以得到x=12,revertedNumber=123
//由于处于中位的数字不影响回文(它总是与自己相等),所以我们可以简单地将其去除。
return x == revertedNumber || x == revertedNumber / 10;
}

巧妙地化字符串,利用reverse()方法求解

class Solution {public boolean isPalindrome(int x) {String reversedStr = (new StringBuilder(x + "")).reverse().toString();return (x + "").equals(reversedStr);}
}

三、进制专题

3.1 七进制数

 LeetCode504.给定一个整数num,将其转化为7进制,并以字符串形式输出。其中-107<=num<=107。
 给定一个整数将其转换成7进制的主要过程是循环取余和整除,最后将所有的余数反过来即可。例如,将十进制数101转成七进制:

示例:101
101÷7=143
14÷7=20
2÷7=02
结果:203

注意如果是负数,要先把负号取出来再计算。

class Solution {public String convertToBase7(int num) {StringBuffer str = new StringBuffer();if(num == 0) return "0";int judge = 1;if(num < 0){judge = -1;num = -1 * num;}while(num != 0){str.append("" + num % 7);num /= 7;}if(judge == -1) str.append("-");return str.reverse().toString();}
}

3.2 进制转换

 给定一个十进制数M,以及需要转换的进制数N,将十进制数M转化为N进制数。M是32位整数,2<=N<=16。
 这个题目的思路不复杂,但是想写正确却很不容易,本题有好几个需要处理的问题:
1.超过进制最大范围之后如何准确映射到其他进制,特别是ABCDEF这种情况。简单的方式是大量采用if判断,但是这样写代码太多了
2.需要对结果进行一次转置。
3.需要判断负号。
 下面这个是讲义总结出的最精简,最容易理解的实现方案。注意采取三个措施来方便处理:
1.定义大小为16的数组F,保存的是2到16的各个进制的值对应的标记,这样赋值时只计算下标,不必考虑不同进制的转换关系了。(绝妙)
2.使用StringBuffer的reverse()完成数组转置等功能,如果不记得这个方法,工作量直接飙升。
3.通过一个flag来判断正数还是负数,最后才处理。

//要考虑到余数>9的情况,2<=N<=16.
public static final String[] F = {"0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F"};
//将十进制数M转化为N进制数
public String convert(int M,int N){Boolean flag = false;if(M < 0){flag = true;M *= -1;}StringBuffer sb = new StringBuffer();int temp;while(M != 0){temp = M % N;//技巧一:通过数组F[]解决了大量繁琐的不同进制之间映射的问题sb.append(F[temp]);M = M / N;}//技巧二:使用StringBuffer的reverse()方法,让原本麻烦的转置瞬间美好sb.reverse();//技巧三:最后处理正负,不要从一开始就揉在一起。return (flag ? "-" : "") + sb.toString();
}

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

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

相关文章

CVE-2021-4145:类型混淆导致释放任意 file 结构体

前言 影响版本&#xff1a; v5.13.4 之前 测试版本&#xff1a;v5.13.3 &#xff08;感谢 bsauce 大佬提供的测试环境&#xff09; 漏洞发生在 fsconfig 处理时调用的cgroup1_parse_param 函数中&#xff0c;patch&#xff1a; diff --git a/kernel/cgroup/cgroup-v1.c b/k…

软路由R4S+iStoreOS如何实现公网远程桌面本地电脑

&#x1f308;个人主页&#xff1a;聆风吟 &#x1f525;系列专栏&#xff1a;数据结构、Cpolar杂谈 &#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 文章目录 一. 简介1.1 软路由的定义1.2 使用软路由的好处1.3 常用组网 二. 配置远程桌面公网地址三. 家中使用…

mysql原理--B+树索引的使用

1.索引的代价 在介绍如何更好的使用索引之前先要了解一下使用这玩意儿的代价&#xff0c;它在空间和时间上都会拖后腿&#xff1a; (1). 空间上的代价 这个是显而易见的&#xff0c;每建立一个索引都要为它建立一棵 B 树&#xff0c;每一棵 B 树的每一个节点都是一个数据页&…

抖去推--短视频剪辑、矩阵无人直播saas营销工具一站式开发

抖去推是一款短视频剪辑和矩阵无人直播SAAS营销工具一站式开发平台。它提供了以下功能和特点&#xff1a; 1. 短视频剪辑&#xff1a;抖去推提供了一系列的剪辑工具&#xff0c;包括自动剪辑、特效制作、配音配乐等&#xff0c;可以帮助用户轻松制作出高质量的短视频。 2. 矩阵…

日志审计在网络安全中的重要性

日志审计是一种通过分析、识别和验证各种日志信息&#xff0c;以帮助企业了解其网络和系统的安全状态和活动的过程。这些日志信息可能来自各种来源&#xff0c;包括服务器、网络设备、应用程序、操作系统等。 日志审计的主要功能包括&#xff1a; 1.识别潜在的安全威胁&#…

创建第一个Vue2项目-----HelloWorld

创建第一个Vue项目 第一步先去安装Vue&#xff0c;一共有两种安装方式&#xff0c;这里使用 点击这里下载&#xff1a;Vue.js 添加到自己的项目中 在使用的页面引入<script src"../js/vue.js"></script> 2. 准备好一个容器 <div id"root&qu…

阿里云大数据工程师ACP认证,今天终于搞定了,87分

为啥我得去考个阿里云大数据工程ACP证书&#xff1f; 首先得声明&#xff0c;这不是因为我对阿里有多痴迷&#xff0c;也不是因为我想把我的简历装饰得花里胡哨。实际上&#xff0c;这更像是一场自我挑战的游戏。我就是一根筋&#xff0c;当时公司要求考阿里云大数据工程师认证…

Redis部署-集群

目录 集群 数据分片算法 哈希求余 一致性哈希算法 哈希槽分区算法 redis集群搭建 1.创建目录和配置. 2.将上述redis节点.构建成集群 3.使用客户端连接集群 集群模式下的故障转移流程 1.故障判定 2.故障迁移 集群扩容 集群 广义上的集群,只要是多个机器,构成了分布…

[IDEA] 写代码时没有类型推断的解决方法

本示例使用scala, 其他语言同理 使用 .var 时会自动生成变量 使用快捷键 CtrlAtlv 一样 val abc "abc"但是这个变量没有显式表现类型 期望 val abc: String "abc" 解决方法

【带头学C++】----- 九、类和对象 ---- 9.13 运算符重载——(9.13.1-9.13.4)

❤️❤️❤️❤️❤️❤️❤️❤️❤️❤️❤️创做不易&#xff0c;麻烦点个关注❤️❤️❤️❤️❤️❤️❤️❤️❤️❤️❤️❤️ ❤️❤️❤️❤️❤️❤️❤️❤️❤️文末有惊喜&#xff01;献舞一支&#xff01;❤️❤️❤️❤️❤️❤️❤️❤️❤️❤️ 目录 9.13…

Linux安装MySQL数据库系统

1、MySQL的编译安装。 1.1、准备工作 &#xff08;1&#xff09;为了避免发生端口冲突、程序冲突等现象&#xff0c;建议先查询MySQL软件的安装情况&#xff0c;确认没有使用以RPM方式安装的mysql-server、mysql软件包&#xff0c;否则建议将其卸载。 [rootlocalhost ~]# rp…

微信社群机器人开发

简要描述&#xff1a; 删除朋友圈 请求URL&#xff1a; http://域名地址/deleteSns 请求方式&#xff1a; POST 请求头Headers&#xff1a; Content-Type&#xff1a;application/jsonAuthorization&#xff1a;login接口返回 参数&#xff1a; 参数名必选类型说明wId…

蚂蚁集团20篇论文入选AI顶会NeurlPS,7成论文聚焦生成式AI

人工智能新浪潮如火如荼&#xff0c;中国互联网企业奋力逐浪并行。 当地时间12月10日&#xff0c;为期六天的全球AI顶级会议NeurlPS在美国路易斯安那州新奥尔良市举办。NeurlPS披露的数据显示&#xff0c;本届会议共有12343篇有效论文投稿&#xff0c;接收率仅为26.1%。蚂蚁集…

FastAPI之响应模型

前言 响应模型我认为最主要的作用就是在自动化文档的显示时&#xff0c;可以直接给查看文档的小伙伴显示返回的数据格式。对于后端开发的伙伴来说&#xff0c;其编码的实际意义不大&#xff0c;但是为了可以不用再额外的提供文档&#xff0c;我们只需要添加一个 response_mod…

单片双向马达驱动芯片D6208的芯片描述

D6208 是一块单片双向马达驱动电路&#xff0c;它使用TTL电平的逻辑信号就能控制卡式录音机和其它电子设备中的双向马达。该电路由一个逻辑部分和一个功率输出部分组成。逻辑部分控制马达正、反转向及制动&#xff0c;功率输出部分根据逻辑控制能提供100mA&#xff08;典型值&a…

[PyTorch][chapter 6][李宏毅深度学习][Logistic Regression]

前言&#xff1a; logistic回归又称logistic回归分析&#xff0c;是一种广义的线性回归分析模型&#xff0c;常用于数据挖掘&#xff0c;疾病自动诊断&#xff0c;经济预测等领域。 逻辑回归根据给定的自变量数据集来估计事件的发生概率&#xff0c;由于结果是一个概率&#xf…

【docker 】 安装docker(centOS7)

官网 docker官网 github源码 官网 在CentOS上安装Docker引擎 官网 在Debian上安装Docker引擎 官网 在 Fedora上安装Docker引擎 官网 在ubuntu上安装Docker引擎 官网 在RHEL (s390x)上安装Docker引擎 官网 在SLES上安装Docker引擎 最完善的资料都在官网。 卸载旧版本 …

异地现场工控设备,如何实现远程配置、调试?

南京某企业专注于工业物联领域&#xff0c;在相关项目中往往会在各个点位部署基于Linux系统的中控主机&#xff0c;实现各类物联设备信息的采集、汇总。但是&#xff0c;由于各点位分散多地&#xff0c;且数量达到了上百个&#xff0c;虽然中控主机具备4G物联网接入能力&#x…

Vue3-07-样式绑定-style绑定的写法总结

style 绑定的方式 1.html中直接一个属性一个属性的写&#xff1b; 2.直接绑定一个对象&#xff1b; 3.绑定一个包含多个样式对象的数组。style绑定样式的注意点 推荐使用 驼峰命名 规则来编写样式的名称&#xff0c;如 &#xff1a; fontSize:12px; 如果使用 中线分割的规则时…

医美行业-上游厂商的营销规模分析与测算

一、医美行业整体发展趋势&#xff1a;轻医美逐步占领市场&#xff0c;占比逐年增加&#xff0c;规模增速远超手术类医美 从2019年开始医美行业扩张速度放缓&#xff0c;2020年受疫情影响中国美容用户的医美行为有所减少&#xff0c;增速放缓至9.9%&#xff0c;随着疫情的好转及…