php加密解密函数用法,php达成金盏银台数的4个示

2019-07-21 04:18 来源:未知

示例1:


此间可以查到贰个有关小说.

自幂数,又称Armstrong数,民间通称姚女子花剑数。实则只有3位自幂数才是金盏银台数。4位5位6位等等各有其余叫法。

复制代码 代码如下:

附上xiunobbs里的代码,自个儿加了点注释,应接大咖商量指正

复制代码 代码如下:

<?php
for($q=1;$q<=9;$q ){
    for($w=0;$w<=9;$w ){
      for($e=0;$e<=9;$e ){
        if($q*$q*$q $w*$w*$w $e*$e*$e ==
         100*$q 10*$w $e){
           echo "$q $w $e "."<p>";
        }
      }
    }
}
?>

//将数值数组还原成字符串,$v为str2long重回的数组,$w为bool值(数组中是否包函原str长度)

<?php
//阿姆Strong数:三个k位数,它的各种位上的数字的k次幂之和分外它自己。(举个例子:1^3

示例2:

  1. function long2str($v, $w) {
  2.     $len = count($v);
  3.     $n = ($len - 1) << 2;
  4.     if ($w) {
  5.         $m = $v[$len - 1];
  6.         if (($m < $n - 3) || ($m > $n)) return false;
  7.         $n = $m;
  8.     }
  9.     $s = array();
  10.     for ($i = 0; $i < $len; $i ) {
  11.         $s[$i] = pack("V", $v[$i]);
  12.     }
  13.     if ($w) {
  14.         return substr(join('', $s), 0, $n);
  15.     }
  16.     else {
  17.         return join('', $s);
  18.     }
  19.  }
  • 5^3 3^3 = 153)
    class Armstrong {

复制代码 代码如下:

//将字符串调换来数值数组,$s要改造的字符串,$w为bool值(数组中是还是不是包函原str长度)

 static function index(){
  for ( $i = 100; $i < 100000; $i ) {
   echo self::is_armstrong($i) ? $i . '<br>' : '';
  }
 }
 static function is_armstrong($num){
  $s = 0;
  $k = strlen($num);
  $d = str_split($num);
  foreach ($d as $r) {
   $s = bcpow($r, $k);
  }
  return $num == $s;
 }

<?php
function cube( $n )
{
    return $n * $n * $n;
}

  1. function str2long($s, $w) {
  2.     $v = unpack("V*", $s. str_repeat("\0", (4 - strlen($s) % 4) & 3));
  3.     $v = array_values($v);
  4.     if ($w) {
  5.         $v[count($v)] = strlen($s);
  6.     }
  7.     return $v;
  8.  }

}
Armstrong::index();

function is_narcissistic ( $n )
{
    $hundreds = floor( $n / 100);    //分解出百位
    $tens = floor( $n / 10 ) % 10;    //分解出十人
    $ones = floor( $n % 10 );    //分解出个位
    return (bool)(cube($hundreds) cube($tens) cube($ones) == $n);
}

您只怕感兴趣的稿子:

  • PHP求小于一千的享有金盏银台数的代码

 
for ( $i = 100; $i < 1000; $i )
{
    if ( is_narcissistic($i) )
        echo $i."n";
}
?>

  1. function int32($n) {
  2.     while ($n >= 2147483648) $n -= 4294967296;
  3.     while ($n <= -2147483649) $n  = 4294967296; 
  4.     return (int)$n;
  5.  }

示例3:

//宗旨加密函数

www.weide1946.com,复制代码 代码如下:

  1. function xxtea_encrypt($str, $key) {
  2.     if ($str == "") {
  3.         return "";
  4.     }
  5.     $v = str2long($str, true);
  6.     $k = str2long($key, false);
  7.     if (count($k) < 4) {
  8.         for ($i = count($k); $i < 4; $i ) {
  9.             $k[$i] = 0;
  10.         }
  11.     }
  12.     $n = count($v) - 1;
  13.  
  14.     $z = $v[$n];
  15.     $y = $v[0];
  16.     $delta = 0x9E3779B9;
  17.     $q = floor(6   52 / ($n   1));
  18.     $sum = 0;
  19.     while (0 < $q--) {
  20.         $sum = int32($sum   $delta);
  21.         $e = $sum >> 2 & 3;
  22.         for ($p = 0; $p < $n; $p ) {
  23.             $y = $v[$p   1];
  24.             $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2)   (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y)   ($k[$p & 3 ^ $e] ^ $z));
  25.             $z = $v[$p] = int32($v[$p]   $mx);
  26.         }
  27.         $y = $v[0];
  28.         $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2)   (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y)   ($k[$p & 3 ^ $e] ^ $z));
  29.         $z = $v[$n] = int32($v[$n]   $mx);
  30.     }
  31.     return long2str($v, false);
  32.  }

<?php
//Armstrong数:五个k位数,它的各类位上的数字的k次幂之和优秀它本人。(比方:1^3

//宗旨解密函数

  • 5^3 3^3 = 153)
    class Armstrong {
     static function index(){
      for ( $i = 100; $i < 100000; $i ) {
       echo self::is_armstrong($i) ? $i . '<br>' : '';
      }
     }
     static function is_armstrong($num){
      $s = 0;
      $k = strlen($num);
      $d = str_split($num);
      foreach ($d as $r) {
       $s = bcpow($r, $k);
      }
      return $num == $s;
     }
    }
    Armstrong::index();
  1. function xxtea_decrypt($str, $key) {
  2.     if ($str == "") {
  3.         return "";
  4.     }
  5.     $v = str2long($str, false);
  6.     $k = str2long($key, false);
  7.     if (count($k) < 4) {
  8.         for ($i = count($k); $i < 4; $i ) {
  9.             $k[$i] = 0;
  10.         }
  11.     }
  12.     $n = count($v) - 1;
  13.  
  14.     $z = $v[$n];
  15.     $y = $v[0];
  16.     $delta = 0x9E3779B9;
  17.     $q = floor(6   52 / ($n   1));
  18.     $sum = int32($q * $delta);
  19.     while ($sum != 0) {
  20.         $e = $sum >> 2 & 3;
  21.         for ($p = $n; $p > 0; $p--) {
  22.             $z = $v[$p - 1];
  23.             $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2)   (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y)   ($k[$p & 3 ^ $e] ^ $z));
  24.             $y = $v[$p] = int32($v[$p] - $mx);
  25.         }
  26.         $z = $v[$n];
  27.         $mx = int32((($z >> 5 & 0x07ffffff) ^ $y << 2)   (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ int32(($sum ^ $y)   ($k[$p & 3 ^ $e] ^ $z));
  28.         $y = $v[0] = int32($v[0] - $mx);
  29.         $sum = int32($sum - $delta);
  30.     }
  31.     return long2str($v, true);
  32.  }

示例4:

//包装纠正后的加密函数,加密的文本越长重临值越长

复制代码 代码如下:

  1. function encrypt($txt, $key = 'abcd9667676effff') {
  2.     $s = urlencode(base64_encode(xxtea_encrypt($txt, $key)));
  3.     $s = str_replace('/', '%2F', $s);    // fix nginx / 导致 rewrite 失效的主题材料
  4.     return $s;
  5.  }

<html>

//包装校勘后的解密函数,若是密钥不准确则重回值为空

<head>
  <title></title>
</head>

  1. function decrypt($txt, $key = 'abcd9667676effff') {
  2.     $txt = str_replace('%2F', '/', $txt);    // fix nginx / 导致 rewrite 失效的标题
  3.     return xxtea_decrypt(base64_decode(urldecode($txt)), $key);    
  4.  }

<body>

用法
$v= encrypt('huqinlou0123@163.com','huqinlou');//加密,密钥为huqinlou
echo decrypt($v,'huqinlou');//解密

<?php

 function winter($num)
 {
       if($num<1000){
       //定义个位
       $ge=$num;
       //定义拾个人
       $ten=(($num0)-$ge) /10;
       //定义百位
       /*floor取整,忽略小数点后边的全数数*/
       $hundred=floor($num/100);
       $sum1=$ge*$ge*$ge $ten*$ten*$ten $hundred*$hundred*$hundred;
       if($sum1==$num){
               return 1;
                } else{
                        return 0;
                        }

               } else{
                       return -1;
                       }
         }

         if(winter(371)==-1) {
                 echo "大于1000的数";
            }else{
                  if(winter(371)) {
                          echo "Yes";
                          }
     else{
   echo "No";
   }
        }

?>

</body>
</html>

您恐怕感兴趣的文章:

  • PHP求小于1000的有所天葱数的代码
  • 有关JAVA精粹算法40题(超实用版)
  • C语言程序设计50例(杰出收藏)
  • java总括自然数中的雅蒜数的艺术分享
  • java总计自幂数和玉玲珑数
  • java总计放肆位女史花数示例(回文数)
  • python求解天葱数的主意
  • C语言美丽算法例题求100-999以内的“雅蒜数
版权声明:本文由韦德娱乐1946_韦德娱乐1946网页版|韦德国际1946官网发布于网络编程,转载请注明出处:php加密解密函数用法,php达成金盏银台数的4个示