四个算法啊

算法总结(kruskal,prime,Floyd,Dijkstra)思想汇总

当涉及到这些经典算法时,每个算法都有其独特的思想:

Kruskal算法:
思想: 贪心算法。从边的权重最小的开始,逐步选择权重递增的边,但保持不形成环路,直到所有顶点都连接在一起。
关键点: 边的排序和并查集的使用。
Prim算法:
思想: 同样是贪心算法。从一个初始顶点开始,逐步选择连接到当前生成树的最短边,直到所有顶点都在生成树中。
关键点: 顶点的选择和边的更新。
Floyd算法:
思想: 动态规划。通过逐个考虑所有中间顶点,更新最短路径的信息,直到找到所有顶点间的最短路径。
关键点: 三重循环,更新最短路径矩阵。
Dijkstra算法:
思想: 贪心算法。从起始顶点开始,维护一个到各顶点的最短距离集合,逐步更新并选择最短路径。
关键点: 优先队列或最小堆的使用,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
这里分别分析四个算法的签名和验证过程的异同: 1. RSA-PKCS签名算法 签名过程: (1) 选择一个合适的RSA密钥对; (2) 计算消息的哈希值; (3) 使用私钥对哈希值进行加密,生成签名。 验证过程: (1) 获取公钥; (2) 计算消息的哈希值; (3) 使用公钥对签名进行解密,得到哈希值; (4) 对比计算的哈希值和解密得到的哈希值是否相同。 2. ELGAMAL签名算法 签名过程: (1) 选择一个合适的ELGAMAL密钥对; (2) 计算消息的哈希值; (3) 生成一个随机数; (4) 计算第一个部分:g^k mod p,其中g和p是公共参数,k是步骤3中生成的随机数; (5) 计算第二个部分:(m - x*r) * k^(-1) mod (p-1),其中m是消息的哈希值,r是步骤4中计算的值,x是私钥,k^(-1)是k在模p-1下的逆元; (6) 最终签名为(r, s)。 验证过程: (1) 获取公钥; (2) 计算消息的哈希值; (3) 计算第一个部分:y^r * r^s mod p,其中y是公钥,r和s是签名中的两个部分; (4) 计算第二个部分:g^m mod p; (5) 对比计算的两个部分是否相同。 3. DSA签名算法 签名过程: (1) 选择一个合适的DSA密钥对; (2) 计算消息的哈希值; (3) 生成一个随机数; (4) 计算第一个部分:g^k mod p,其中g、p和q是公共参数,k是步骤3中生成的随机数; (5) 计算第二个部分:(k^(-1) * (m + x*r)) mod q,其中m是消息的哈希值,r是步骤4中计算的值,x是私钥,k^(-1)是k在模q下的逆元; (6) 最终签名为(r, s)。 验证过程: (1) 获取公钥; (2) 计算消息的哈希值; (3) 计算第一个部分:(g^u1 * y^u2 mod p) mod q,其中y是公钥,r和s是签名中的两个部分,u1 = (h(m) * s^(-1)) mod q,u2 = (r * s^(-1)) mod q,h(m)是消息的哈希值; (4) 对比计算的第一个部分是否等于r。 4. ECC签名算法 签名过程: (1) 选择一个合适的ECC密钥对; (2) 计算消息的哈希值; (3) 生成一个随机数; (4) 计算第一个部分:k * G,其中G是椭圆曲线上的固定点,k是步骤3中生成的随机数; (5) 计算第二个部分:((h(m) + x1*r) * k^(-1)) mod n,其中n是椭圆曲线上点的个数,h(m)是消息的哈希值,r是步骤4中计算的值,x1是私钥,k^(-1)是k在模n下的逆元; (6) 最终签名为(r, s)。 验证过程: (1) 获取公钥; (2) 计算消息的哈希值; (3) 计算第一个部分:s*G - h(m)*P,其中P是公钥,G是椭圆曲线上的固定点,s和r是签名中的两个部分; (4) 对比计算的第一个部分和r是否相同。 总体来说,四种算法的签名和验证过程都包含了哈希计算、随机数生成、数学运算等基本步骤。其中,RSA-PKCS算法和ELGAMAL算法都需要用到加密算法对哈希值进行处理,而DSA算法和ECC算法则是直接使用哈希值。同时,四种算法的签名和验证过程都要用到密钥对,签名过程涉及到私钥的使用,验证过程则涉及到公钥的使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值