int转字符串实现方法
温馨提示:
本文最后更新于 2021年02月25日,已超过 1,430 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我。
抖音的分享链接一般为: https://v.douyin.com/JGoSFt2/
那么后面那串 JGoSFt2 是什么呢?
其实后面那串为分享id转字符串,原始数据可能为 :1091566355946 ,通过特定算法转换为了更短的字符串
实现代码为:
<?php
namespace EasySwoole\Utility;
class IntStr
{
public const intMax = 9223372036854775668;
private const alphabet = [
'A', 'a', 'B', 'b', 'C', 'c', 'D', 'd', 'E', 'e',
'F', 'f', 'G', 'g', 'H', 'h', 'I', 'i', 'J', 'j',
'K', 'k', 'L', 'l', 'M', 'm', 'N', 'n', 'O', 'o',
'P', 'p', 'Q', 'q', 'R', 'r', 'S', 's', 'T', 't',
'U', 'u', 'V', 'v', 'W', 'w', 'X', 'x', 'Y', 'y',
'Z', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9'
];
public static function toAlpha($number): string
{
if ($number < 0 && $number > self::intMax) {
throw new \InvalidArgumentException('number error');
}
$alpha = '';
if ($number <= 61) {
return self::alphabet[$number];
} elseif ($number > 61) {
$dividend = ($number + 1);
while ($dividend > 0) {
$modulo = ($dividend - 1) % 62;
if ($modulo < 0) {
$modulo = 62 + $modulo;
}
$alpha = self::alphabet[$modulo] . $alpha;
$dividend = bcdiv(($dividend - $modulo) , 62);
}
}
return $alpha;
}
public static function toNum($string): int
{
$alpha_flip = array_flip(self::alphabet);
$return_value = -1;
$length = strlen($string);
for ($i = 0; $i < $length; $i++) {
$return_value +=
($alpha_flip[$string[$i]] + 1) * bcpow(62, ($length - $i - 1));
}
return $return_value;
}
}
运行:
<?php
include "./vendor/autoload.php";
var_dump(\EasySwoole\Utility\IntStr::toNum('JGoSFt2'));
var_dump(\EasySwoole\Utility\IntStr::toAlpha(100000000000000));
正文到此结束
- 本文标签: 算法 编程语言
- 本文链接: https://www.php20.cn/article/273
- 版权声明: 本文由仙士可原创发布,转载请遵循《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权