C语言之linux内核实现最大公约数算法

在线体验各类最新模型,更有模型 免费Token 额度领取!
立即体验
简介:

最大公约数算法,又称欧几里算法,至今已有几千年的历史了。在我们开始学习C语言的时候最常用的算法就是辗转相除法,其实在linux内核中,内核也是使用这样的方法实现两数最大公约数的计算。

     两个整数的最大公约数是能够同时整除它们的最大的正整数。辗转相除法基于如下原理:两个整数的最大公约数等于其中较小的数和两数的相除余数的最大公约数。

      例如,252和105的最大公约数是21(252 = 21 × 12;105 = 21 × 5);

      算法原理:

设两数为a、b(b<a),用gcd(a,b)表示a,b的最大公约数,r=a (mod b) 为a除以b以后的余数,k为a除以b的商,即a÷b=k .......r。辗转相除法即是要证明gcd(a,b)=gcd(b,r)。
第一步:令c=gcd(a,b),则设a=mc,b=nc
第二步:根据前提可知r =a-kb=mc-knc=(m-kn)c
第三步:根据第二步结果可知c也是r的因数
第四步:可以断定m-kn与n互质【否则,可设m-kn=xd,n=yd (d>1),则m=kn+xd=kyd+xd=(ky+x)d,则a=mc=(ky+x)dc,b=nc=ycd,故a与b最大 公约数成为cd,而非c,与前面结论矛盾】
从而可知gcd(b,r)=c,继而gcd(a,b)=gcd(b,r)。
http://home.ebrun.com/u-1120007.html
http://home.ebrun.com/u-1120008.html
http://home.ebrun.com/u-1120009.html
http://home.ebrun.com/u-1120011.html
http://home.ebrun.com/u-1120015.html
http://home.ebrun.com/u-1120013.html
http://home.ebrun.com/u-1120021.html
http://home.ebrun.com/u-1120019.html
http://home.ebrun.com/u-1120016.html
http://home.ebrun.com/u-1120024.html
http://home.ebrun.com/u-1120012.html
http://home.ebrun.com/u-1120023.html
http://home.ebrun.com/u-1120025.html
http://home.ebrun.com/u-1120022.html
http://home.ebrun.com/u-1120018.html
http://home.ebrun.com/u-1120020.html
http://home.ebrun.com/u-1120014.html
http://home.ebrun.com/u-1120010.html
http://home.ebrun.com/u-1120017.html
http://home.ebrun.com/u-1120031.html
http://home.ebrun.com/u-1120032.html
http://home.ebrun.com/u-1120033.html
http://home.ebrun.com/u-1120034.html
http://home.ebrun.com/u-1120035.html
http://home.ebrun.com/u-1120036.html
http://home.ebrun.com/u-1120038.html
http://home.ebrun.com/u-1120037.html
http://home.ebrun.com/u-1120039.html
http://home.ebrun.com/u-1120041.html
http://home.ebrun.com/u-1120043.html
http://home.ebrun.com/u-1120053.html
http://home.ebrun.com/u-1120051.html
http://home.ebrun.com/u-1120047.html
http://home.ebrun.com/u-1120044.html
http://home.ebrun.com/u-1120045.html
http://home.ebrun.com/u-1120042.html
http://home.ebrun.com/u-1120050.html
http://home.ebrun.com/u-1120054.html
http://home.ebrun.com/u-1120048.html
http://home.ebrun.com/u-1120052.html
http://home.ebrun.com/u-1120061.html
http://home.ebrun.com/u-1120056.html
http://home.ebrun.com/u-1120062.html
http://home.ebrun.com/u-1120040.html
http://home.ebrun.com/u-1120057.html
http://home.ebrun.com/u-1120055.html
http://home.ebrun.com/u-1120059.html
http://home.ebrun.com/u-1120064.html
http://home.ebrun.com/u-1120060.html



目录
相关文章
|
11月前
|
安全 网络协议 Linux
深入理解Linux内核模块:加载机制、参数传递与实战开发
本文深入解析了Linux内核模块的加载机制、参数传递方式及实战开发技巧。内容涵盖模块基础概念、加载与卸载流程、生命周期管理、参数配置方法,并通过“Hello World”模块和字符设备驱动实例,带领读者逐步掌握模块开发技能。同时,介绍了调试手段、常见问题排查、开发规范及高级特性,如内核线程、模块间通信与性能优化策略。适合希望深入理解Linux内核机制、提升系统编程能力的技术人员阅读与实践。
938 1
|
11月前
|
监控 Ubuntu Linux
什么Linux,Linux内核及Linux操作系统
上面只是简单的介绍了一下Linux操作系统的几个核心组件,其实Linux的整体架构要复杂的多。单纯从Linux内核的角度,它要管理CPU、内存、网卡、硬盘和输入输出等设备,因此内核本身分为进程调度,内存管理,虚拟文件系统,网络接口等4个核心子系统。
1066 0
|
11月前
|
Web App开发 缓存 Rust
|
11月前
|
Ubuntu 安全 Linux
Ubuntu 发行版更新 Linux 内核,修复 17 个安全漏洞
本地攻击者可以利用上述漏洞,攻击 Ubuntu 22.10、Ubuntu 22.04、Ubuntu 20.04 LTS 发行版,导致拒绝服务(系统崩溃)或执行任意代码。
|
10月前
|
Linux 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
1009 1
二、Linux文本处理与文件操作核心命令
|
10月前
|
Linux
linux命令—stat
`stat` 是 Linux 系统中用于查看文件或文件系统详细状态信息的命令。相比 `ls -l`,它提供更全面的信息,包括文件大小、权限、所有者、时间戳(最后访问、修改、状态变更时间)、inode 号、设备信息等。其常用选项包括 `-f` 查看文件系统状态、`-t` 以简洁格式输出、`-L` 跟踪符号链接,以及 `-c` 或 `--format` 自定义输出格式。通过这些选项,用户可以灵活获取所需信息,适用于系统调试、权限检查、磁盘管理等场景。
620 137
|
10月前
|
安全 Ubuntu Unix
一、初识 Linux 与基本命令
玩转Linux命令行,就像探索一座新城市。首先要熟悉它的“地图”,也就是/根目录下/etc(放配置)、/home(住家)这些核心区域。然后掌握几个“生存口令”:用ls看周围,cd去别处,mkdir建新房,cp/mv搬东西,再用cat或tail看文件内容。最后,别忘了随时按Tab键,它能帮你自动补全命令和路径,是提高效率的第一神器。
1581 58
|
9月前
|
存储 安全 Linux
Linux卡在emergency mode怎么办?xfs_repair 命令轻松解决
Linux虚拟机遇紧急模式?别慌!多因磁盘挂载失败。本文教你通过日志定位问题,用`xfs_repair`等工具修复文件系统,三步快速恢复。掌握查日志、修磁盘、验重启,轻松应对紧急模式,保障系统稳定运行。
1455 2
|
10月前
|
Unix Linux 程序员
Linux文本搜索工具grep命令使用指南
以上就是对Linux环境下强大工具 `grep` 的基础到进阶功能介绍。它不仅能够执行简单文字查询任务还能够处理复杂文字处理任务,并且支持强大而灵活地正则表达规范来增加查询精度与效率。无论您是程序员、数据分析师还是系统管理员,在日常工作中熟练运用该命令都将极大提升您处理和分析数据效率。
792 16