C#刷遍Leetcode面试题系列连载(6):No.372 - 超级次方

点击蓝字“dotNET匠人”关注我哟

加个“星标”,每日 7:15,好文必达!

前文传送门:

C# 刷遍 Leetcode 面试题系列连载(1) - 入门与工具简介

C#刷遍Leetcode面试题系列连载(2): No.38 - 报数

C#刷遍Leetcode面试题系列连载(3): No.728 - 自除数

C#刷遍Leetcode面试题系列连载(4): No.633 - 平方数之和

C#刷遍Leetcode面试题系列连载(5):No.593 - 有效的正方形

上一篇 LeetCode 面试题中,我们分析了一道难度为 Medium 的数学题 - 有效的正方形,提供了3种方法。今天我们继续来分析一道难度为 Medium 的面试题吧。


今天要给大家分析的面试题是 LeetCode 上第 372 号问题,

LeetCode - 372. 超级次方

https://leetcode.com/problems/super-pow/

题目描述


你的任务是计算  对 1337 取模,a 是一个正整数,b 是一个非常大的正整数且会以数组形式给出。

示例 1:

a = 2
b = [3]结果: 8

示例 2:

a = 2
b = [1,0]结果: 1024

示例 3:

a = 2147483647
b = [2,0,0]
结果: 1198

致谢:

特别感谢 @Stomach_ache 添加这道题并创建所有测试用例。

  • 题目难度:Medium

  • 提交次数:6.3K

  • 通过次数:2.3K

  • 通过率:35.95%

  • 相关标签

    • 数学

      https://leetcode-cn.com/tag/math

  • 相似题目

    Pow(x, n)

    https://leetcode-cn.com/problems/powx-n



相关知识与思路:

理解题意:

本题要求计算  % 1337,输入中a是以十进制形式给出,而b是以数组的形式给出的,数组中依次存有十进制下的每位数字。

解法1: 直接用字符串处理

public class Solution
{public int SuperPow(int a, int[] b){int res = 0;StringBuilder sb = new StringBuilder();foreach (var item in b)sb.Append(item);int.TryParse(sb.ToString(), out int p);var val = (int) Math.Pow(a, p);res = val - (val / 1337)*1337;return res;}
}

会发现,对数b较大时(示例3)会越界。因此需利用模运算的性质来优化~

模运算的常用性质如下:

分配率

(a + b) mod n = [(a mod n) +(b mod n) ] mod n。

 mod n = [(a mod n) (b mod n) ] mod n

d mod() =(d mod a) + a [(d \ a) mod b] +  [(d \ a \ b) mod c],其中\是欧几里德除法的商的算子。

c mod(a + b) =(c mod a) + [ (a + b) ] mod b - [ (a + b) ] mod a。

除法 :A/B 

mod n = [(a mod n) ( mod n) ] mod n,当b和n互质时,右边被定义。反之亦然。

相乘后的逆(Inverse multiplication)

[( mod n) ( mod n) ] mod n = a mod n。

特殊性质:x %  == x & ()

另外,与之相关的一个概念是同余(Congruence relation)。

此题需用到分配率中的:  mod n = [(a mod n) (b mod n) ] mod n

解法2 已AC代码:

public class Solution
{const int Mod0 = 1337;public int SuperPow(int a, int[] b){if (b.Length == 0)return 1;var res = 1;for (int i = b.Length - 1; i >= 0; i--){res = powMod(a, b[i]) * res % Mod0;a = powMod(a, 10);}return res;}private int powMod(int a, int m){a %= Mod0;int result = 1;for (int i = 0; i < m; i++)result = result * a % Mod0;return result;}
}

Rank:

执行用时: 116 ms, 在所有 csharp 提交中击败了100.00%的用户.

按理说,如果将a%m改为a-(a/m)*m,代码运行速度会变快些,直接进行模运算确实会慢一些。

解法3 已AC代码:

public class Solution
{const int Mod0 = 1337;public int SuperPow(int a, int[] b){if (b.Length == 0)return 1;var res = 1;for (int i = b.Length - 1; i >= 0; i--){var powModResult = powMod(a, b[i]) * res;res = powModResult - (powModResult / Mod0) * Mod0;a = powMod(a, 10);}return res;}private int powMod(int a, int m){a = a - (a / Mod0) * Mod0;int result = 1;for (int i = 0; i < m; i++)result = result * a - (result * a / Mod0) * Mod0;return result;}
}

Rank:执行用时: 112 ms, 在所有 csharp 提交中击败了100.00%的用户

示例代码: 

https://github.com/yanglr/Leetcode-CSharp/tree/master/leetcode372 .


欢迎提出更佳的解决思路~

最近正在看百度前副总裁的《俞军产品方法论》,提升一下自己的产品思维。这本书2019年12月才由中信出版社出版,良心好书,推荐给大家~

End

作者简介:Bravo Yeung计算机硕士,知乎干货答主(2.3万关注者,获73K 赞同, 34K 感谢, 210K 收藏)。曾在国内 Top3互联网视频直播公司短暂工作过,后加入一家外企做软件开发至今。

欢迎在留言区留下你的观点,一起讨论提高。如果今天的文章让你有新的启发,学习能力的提升上有新的认识,欢迎转发分享给更多人。

欢迎各位读者加入 .NET技术交流群,在公众号后台回复“加群”或者“学习”即可。

  • 大家好,我就是区块链本人。今天,我要给你们介绍我的家族…

  • 只因写了一段爬虫,公司200多人被一锅全端!

  • 真实的上海IT圈:张江男vs漕河泾男

  • C#刷遍Leetcode面试题系列连载(1) - 入门与工具简介

  • .NET斗鱼直播弹幕客户端(上)

  • 写给.NET开发者看的Python3上手指南系列(1):Python3与C# 基础语法对比

  • 硬货 - 技术人也能轻松玩转公众号?正确姿势竟然是...

转发至朋友圈,是对我最大的支持。

朕已阅 

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

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

相关文章

堆 最大堆 最小堆

堆是特殊的队列 从堆中取出元素是依照元素的优先级大小&#xff0c;而不是元素进入队列的先后顺序 堆最常用的结构是二叉树表示&#xff0c;不特指的话&#xff0c;它是一棵完全二叉树 因为高度为h的完全二叉树有结点2(h-1) 到2h-1个&#xff0c;且结点排布及其规律&#xff…

使用 Postman 测试你的 API

使用 Postman 测试你的 APIIntro最近想对 API 做一些自动化测试&#xff0c;看了几个工具&#xff0c;最后选择了 postman&#xff0c;感觉 postman 的设计更好一些&#xff0c;我们可以在请求发送之前和请求获取到响应之后都可以自定义脚本&#xff0c;很灵活。而且 postman 的…

散列查找 散列表(哈希表)

哈希表的平均查找长度是&#xff08;&#xff09;的函数。 A.哈希表的长度 B.哈希表的装填因子 C.哈希函数 D.表中元素的多少 装填因子 关键字个数 / 表长 符号表&#xff1a;是 “名字&#xff08;Name&#xff09;–属性&#xff08;Attribute&#xff09;”对的集合 符号表…

使用 postman 给 API 写测试

使用 postman 给 API 写测试Intro上次我们简单介绍了 使用 postman 测试 API&#xff0c;这次主要来写一些测试用例以检查请求的响应是否符合我们的预期以及如何使用脚本测试使用 postman 内置的随机变量postman 内置的有一些产生随机值的变量&#xff0c;在发送请求时随机生成…

图 无向图 有向图

若无向图G &#xff08;V&#xff0c;E&#xff09;中含7个顶点&#xff0c;要保证图G在任何情况下都是连通的&#xff0c;则需要的边数最少是&#xff1a; A.6 B.15 C.16 D.21 (n-1)*(n-2)/21 6 * 5/2116 设无向图的顶点个数为N&#xff0c;则该图最多有多少条边&#xff1f;…

Excel催化剂回顾2019年产出(文章合集),展望2020年

一年结束&#xff0c;大家都对自己一年辛勤耕耘作一个总结&#xff0c;Excel催化剂也不落俗&#xff0c;也来一篇文章合集式的梳理&#xff0c;方便大家对Excel催化剂的产出有一个宏观全局的认识。不断创新中前行Excel催化剂从2018年开波以来&#xff0c;累计到如今已有114个大…

朗文3000词汇表带音标_英语零基础音标语法都不会词汇量3000 学雅思到6/6.5分 需要多久 该如何做?...

谢邀~题主好&#xff01;看来题主的零基础非常纯正。你现在测试的单词量是3000&#xff0c;只能大概展示出你的一些基础&#xff0c;但其实真正的还是要看你会使用&#xff0c;真正理解用法、语境的词汇有多少&#xff0c;而不是为了看起来有多少的那个数字。那么首先题主最好的…

选择排序 插入排序 交换排序

动图演示&#xff1a; https://www.runoob.com/w3cnote/bubble-sort.html 选择排序 简单选择排序 在未排序的序列中&#xff0c;选出最小的元素和序列的首位元素交换&#xff0c;接下来在剩下的未排序序列中&#xff0c;再选出最小元素与序列的第二位元素交换&#xff0c;以此…

ASP.NETCore编程实现基本认证

HTTP基本认证在HTTP中&#xff0c;HTTP基本认证&#xff08;Basic Authentication&#xff09;是一种允许浏览器或其他客户端程序使用&#xff08;用户名&#xff0c;口令&#xff09;请求资源的身份验证方式&#xff0c;不要求cookie,session identifier、login page等标记或载…

计算机原理(计算机系统漫游)

计算机五大组成部件&#xff1a;运算器&#xff08;ALU&#xff09;&#xff0c;控制器&#xff0c;存储器&#xff0c;输入部件&#xff0c;输出部件 1.控制器 2.运算器 逻辑运算&#xff08;判断事物的对与错&#xff09; 数学运算(11) 控制器运算器中央处理器&#xff08;CP…

使用ASP.NET Core 3.x 构建 RESTful API - 4.2 过滤和搜索

向Web API传递参数数据可以通过多种方式来传给API。 Binding Source Attributes 会告诉 Model 的绑定引擎从哪里找到绑定源。 共有以下六种 Binding Source Attributes&#xff1a; [FromBody] 请求的 Body [FromForm] 请求的 Body 中的 form数据 [FromHeader] 请求的 Header […

360浏览器linux版本_360安全浏览器崩溃解决方案

360安全浏览器崩溃解决方案方案一&#xff1a;打开360安全浏览器&#xff0c;按键盘上的F1调出浏览器医生界面&#xff0c;点击一键修复即可。如图所示&#xff1a;方案二&#xff1a;360浏览器打开了太多标签占用内存&#xff0c;并且随着浏览器开着的时间越长&#xff0c;占用…

.NET 开源软件开发BIM工具包xBIM

一、xBIM 简介BIM&#xff08;Building Information Modelling&#xff09;建筑信息模型&#xff0c;xBIM&#xff08;eXtensible Building Information Modelling&#xff09;可扩展的建筑信息模型。它是一个.NET 开源软件开发BIM工具包&#xff0c;支持BuildingSmart数据模型…

< meta name=“viewport“ content=“width=device-width, initial-scale=1.0“>的解释

< meta name“viewport” content“widthdevice-width, initial-scale1.0”> meta是html语言head区的一个辅助性标签&#xff0c;位于文档的头部&#xff0c;不包含任何内容 标签的属性定义了与文档相关的名称/值对 meta元素可提供相关页面的元信息&#xff0c;比如针对…

<meta name=“robots“ content=“index,follow“>的解释

为了让搜索引擎禁止抓取本页面 此标签必须放在< head >和< /head >之间 content中的值决定允许抓取的类型&#xff0c;必须同时包含两个值&#xff1a;是否允许索引&#xff08;index&#xff09;和是否跟踪链接&#xff08;follow&#xff0c;也可以理解为是否允…

2019(dotNet全栈开发)公众号回顾

2019年已经过去&#xff0c;人口红利已经逐渐消失&#xff0c;也许这是这10年互联网史上最糟糕的一年&#xff0c;也可能这是未来10年互联网史上最好的一年关于公众号&#xff0c;我其实很早就开始注册了&#xff0c;只是一直没怎么运营&#xff08;ps&#xff1a;不知道怎么推…

CSS padding margin border属性讲解

把所有网页上的对象都放在一个盒&#xff08;box&#xff09;中 &#xff0c;设计师可以通过创建定义来控制这个盒的属性&#xff0c;这些对象包括段落、列表、标题、图片以及层。 盒模型主要定义四个区域&#xff1a; 内容&#xff08;content&#xff09; 内边距&#xff08;…

laravel 模板继承_Laravel框架模板之公共模板、继承、包含实现方法分析

本文主要介绍了laravel框架模板之公共模板、继承、包含实现方法,结合实例形式分析了Laravel框架中公共模板的建立、模板包含、模板继承等相关操作技巧&#xff0c;需要的朋友可以参考下&#xff0c;具体如下&#xff1a;简介&#xff1a;利用laravel框架开发后台管理系统或web站…

css表格表单属性

表格标签 table表格 属性&#xff1a; border 边框属性 值 数字 width 宽度 值 数字 height 高度 值 数字 cellpadding单元格的内容到单元格边的距离 cellspacing单元格和单元格之间的间距 align规定表格水平如何摆放 值 left/center/right tr行 属性&#xff1a; height 高度…

2019 amazingdotnet 公众号回顾

2019 精彩文章汇总Intro新的一年了&#xff0c;把去年的精彩文章汇总一下&#xff0c;希望能对大家有所帮助博客园推荐文章asp.net core 3.0 更新简记asp.net core 从单机到集群动手造轮子&#xff1a;实现一个简单的 EventBusasp.net core 3.0 中使用 swaggerasp.net core 自定…