算法简介

Posted yanweifeng

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法简介相关的知识,希望对你有一定的参考价值。

算法简介

标签(空格分隔): python

介绍

1 程序 = 数据结构 + 算法
2 算法(algorithms)是针对特定的问题,经过精心设计的用来一步步解决该问题从而得到答案的过程。
3 算法是解决问题的步骤的思想的描述,而我们使用计算机语言来实现算法是算法的实现的过程仅仅是为了让计算机能执行(算法的实现过程)。
4 算法具有五个基本特性:输入、输出、有穷性、确定性和可行性。
5 有穷性:直白一些说就是算法的实现代码不能是死循环的
6 可行性:是指再现有的条件下算法的每一个步骤都应该是可以实现的而不是只是空想或者你设计了一个20年之后可以实现的算法,这个在当下都是没有意义的。
7 设计算法基本的原则有五个: 正确性、健壮性、高效性、环保性和可读性!
8 自我理解:算法就是数学中解决问题的方法,只不过它是在计算机中解决的

面试题

如果 a+b+c=1000,且 a^2+b^2=c^2(a,b,c 为自然数),如何求出所有a、b、c可能的组合?

第一次尝试

技术分享图片

运行结果 160秒

技术分享图片

第二次尝试

技术分享图片

运行结果
看运行时间

技术分享图片

以上是关于算法简介的主要内容,如果未能解决你的问题,请参考以下文章

Android 逆向类加载器 ClassLoader ( 类加载器源码简介 | BaseDexClassLoader | DexClassLoader | PathClassLoader )(代码片段

以下代码片段的算法复杂度

有人可以解释啥是 SVN 平分算法吗?理论上和通过代码片段[重复]

片段(Java) | 机试题+算法思路+考点+代码解析 2023

Android 逆向Linux 文件权限 ( Linux 权限简介 | 系统权限 | 用户权限 | 匿名用户权限 | 读 | 写 | 执行 | 更改组 | 更改用户 | 粘滞 )(代码片段

SpringCloud系列十一:SpringCloudStream(SpringCloudStream 简介创建消息生产者创建消息消费者自定义消息通道分组与持久化设置 RoutingKey)(代码片段