作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一串数字,例如“1324436234235464234”。我需要将此字符串转换为“5R2f2t4”或其他符号序列,不是很长,所有这些都必须在客户端上实现。完成此转换后,需要将其转换回服务器端(node.js)。
它看起来像加密/解密任务,但在这种情况下我不关心安全性。是否可以实现这个转换序列?
更新:我无法使用数据库。
最佳答案
由于您的输入字符串始终具有相同的长度,因此您可以将十进制转换为其他更高的基数。
转换为缩写形式:
const encode = (alphabetString, input) => {
const alphabet = Array.from(alphabetString);
const digits = input.split('').map(Number);
const result = [];
for (;;) {
let isZero = true;
// Divide the number in `digits` by the alphabet size
let carry = 0;
for (let i = 0; i < digits.length; i++) {
const digit = 10 * carry + digits[i];
if (digit !== 0) {
isZero = false;
}
digits[i] = digit / alphabet.length >>> 0;
carry = digit % alphabet.length;
}
if (isZero) {
break;
}
result.push(alphabet[carry]);
}
return result.reverse().join('') || alphabet[0];
};
const ALPHABET = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';
console.log(encode(ALPHABET, '1324436234235464234'));
使用 BigInt
支持进行转换(即您使用的是 Node.js 10):
const decode = (alphabet, input) => {
const map = new Map(
Array.from(alphabet, Array.of)
);
const fromBase = BigInt(alphabet.length);
let value = 0n;
for (const c of input) {
value = fromBase * value + BigInt(map.get(c));
}
return String(value);
};
const ALPHABET = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';
console.log(decode(ALPHABET, '1Zpvmcf1O26').padStart(19, '0'));
没有 BigInt
支持的转换:
const decode = (alphabet, input) => {
const map = new Map(
Array.from(alphabet, Array.of)
);
const digits = Array.from(input, c => map.get(c));
const result = [];
for (;;) {
let isZero = true;
let carry = 0;
for (let i = 0; i < digits.length; i++) {
const digit = alphabet.length * carry + digits[i];
if (digit !== 0) {
isZero = false;
}
digits[i] = digit / 10 >>> 0;
carry = digit % 10;
}
if (isZero) {
break;
}
result.push(carry);
}
return result.reverse().join('') || '0';
};
const ALPHABET = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';
console.log(decode(ALPHABET, '1Zpvmcf1O26').padStart(19, '0'));
对于 19 位数字的输入,使用 ASCII 数字和字母 (62) 给出的结果长度可达 11。如果您可以毫无问题地在字母表中放入更多字符,例如您试图在一条推文中容纳尽可能多的 19 位字符串以供机器读取,那么就这样做 – 每个额外的字符都会产生一些数字投入时间缩短(但返回递减)。
如果您需要与旧版浏览器兼容,请注意,仅在使用需要多个 UTF-16 代码单元的字符时才需要 const Alphabet = Array.from(alphabetString)
。仅使用 ASCII,您可以删除该行并将 alphabetString
重命名为 alphabet
。
关于javascript - 如何将 NumPy 字符串转换为较短的版本,然后恢复为正常形式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51575069/
我是一名优秀的程序员,十分优秀!