- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我需要将以太坊(加密货币)余额导出到 Postgres,但我需要将它们压缩成一个 blob,因为它们太多了,我必须为每个 block 存储状态。余额存储在 big.Int
中,但大多数帐户的余额为 0(或非常接近于 0),所以我想到了这种压缩算法:
Format (single record):
8bits: the length of the bit string
following bits : the actual big.Int converted into bits with Int.Bits() function
余额以 1/10^18 的精度存储,因此 1 个以太币存储为 1 位和 18 个零。我的算法是最好的压缩方法吗?或者有更好的主意吗?
例如,另一个想法是选择一个 float64 ,但我不确定它是否可以容纳所有值范围。 1 以太币是 1
和 18 个零,但加密货币交易所可能有数百万以太币的余额,因此最大值是 1
和大约 25 个零。或者我可以在最坏的情况下选择 float128。
你有什么建议?
最佳答案
为了最大压缩,使用Bytes()
(返回[]byte
),而不是Bits()
(返回[]单位
)。例如,一个零余额,一个公共(public)值,是一个字节的 blob。此外,允许负余额。例如,
package main
import (
"fmt"
"math/big"
)
func CompressBalance(i *big.Int) []byte {
if i == nil {
return nil
}
if i.BitLen() == 0 {
return []byte{0}
}
byts := i.Bytes()
if len(byts) > 0x7F {
return nil
}
blob := make([]byte, 1+len(byts))
blob[0] = byte(len(byts))
blob[0] |= byte(i.Sign()) & 0x80
copy(blob[1:], byts)
return blob
}
func DecompressBalance(b []byte) *big.Int {
if len(b) <= 0 {
return nil
}
if 1+int(b[0]&0x7F) != len(b) {
return nil
}
i := new(big.Int)
if b[0] == 0 {
return i
}
i.SetBytes(b[1:])
if b[0]&0x80 == 0x80 {
i.Neg(i)
}
return i
}
func main() {
tests := []string{
"0",
"1925000288124900513257758", // 1,925,000.288124900513257758
"-1925000288124900513257758", // -1,925,000.288124900513257758
}
for _, s := range tests {
i := new(big.Int)
i, ok := i.SetString(s, 10)
if !ok {
fmt.Println("error:", i, ok)
}
blob := CompressBalance(i)
j := DecompressBalance(blob)
fmt.Printf("i: %s\nj: %s\nblob: %d %v\n", i, j, len(blob), blob)
}
}
Playground :https://play.golang.org/p/zClfVxG6agL
输出:
i: 0
j: 0
blob: 1 [0]
i: 1925000288124900513257758
j: 1925000288124900513257758
blob: 12 [11 1 151 162 121 135 80 245 19 41 153 30]
i: -1925000288124900513257758
j: -1925000288124900513257758
blob: 12 [139 1 151 162 121 135 80 245 19 41 153 30]
金融交易需要准确的数字。按照设计, float 是一个近似值。
关于go - 压缩存储在 big.Int 中的余额的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48697055/
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Big Theta Notation - what exactly does big Theta represent
我有一个作业要证明这些是对还是错: a) 150n^3 + 43n^2 + 50^n + 3 = Ω(n^5) b) n^10 + 30n^8 + 80n^6 = O(n^12) c) 55n + 3
我可以在 big.Int 上使用像 Text() 这样的方法,它工作正常,但是如果我返回一个 big.Int 然后使用“myfunc().Text()”会抛出一个错误,而如果我返回一个 * big.I
我正在用 PHP 开发一个网络应用程序,此时核心库的大小为 94kb。虽然我认为我现在是安全的,但多大才算太大?脚本的大小是否会成为一个问题,如果是这样,可以通过将脚本拆分为多个库来改善这一点吗? 我
我正在复习 Big-Oh 符号,但我在理解这个问题的解决方案时遇到了问题: Is 2n + 10 ≡ O(n)? Can we find c and n0? 2n + 10 = 10 n >= 10/
我最近陷入了争论/辩论中,我试图对正确的解决方案做出明确的判断。 众所周知, n! grows very quickly ,但究竟有多快,足以“隐藏”可能添加到其中的所有其他常量? 让我们假设我有这个
我很难找出这段代码的 Big-O 符号。 我需要找到两个 for 循环的符号。 public static int fragment(int n) { int sum = 0; for (in
给定两个函数: f(n)=O(log2n) 和 g(n)=O(log10n) 其中一个是否支配另一个? 最佳答案 请记住,任何碱基的对数都可以转换为仅以常数变化的公共(public)碱基。 因此它们都
经过修改,我们得出结论,时间复杂度实际上是O(2^n) 问题是时间复杂度是多少?是 O(2^n) 还是? 我相信这是因为 for 循环被认为运行了 n 次。然后嵌套的 while 循环运行 2^n 次
以下嵌套循环的 Big-O 时间复杂度是多少: for (int i = 0; i < N; i++) { for (int j = i + 1; j < N; j++) {
我很想知道经验丰富的 C 程序员认为可以按值传递的参数大小的上限是什么。 上下文:我有机会使用 2×2 矩阵,它位于一个结构体中: typedef struct { double a, b, c,
我很想知道经验丰富的 C 程序员认为可以按值传递的参数大小的上限是什么。 上下文:我有机会使用 2×2 矩阵,它位于一个结构体中: typedef struct { double a, b, c,
假设我们有一个问题,我们使用 X 算法实现了 O(n) 或 O(log n) 或 etc...。 n 的值何时大到我们必须考虑替代实现?让我们看看我是否可以更好地解释自己。 For n=10,000
这属于哪种 Big-O 表示法?我知道 setSearch() 和 removeAt() 是 O(n) 的顺序(假设它们是任意一种)。我知道如果没有 for 循环它肯定是 O(n),但是我很困惑如何计
这是我的问题,我已经设法为 a 部分提出了一个答案,但对于 b 部分,我对 b 部分的答案并不是很自信。 在最近的一起法庭案件中,一名法官以蔑视城市为由,下令第一天罚款 2 美元。 之后的每一天,直到
我正在尝试计算以下算法的大 O,但我很困惑,需要一些帮助: Algorithm 1. DFS(G,n) Input: G- the graph n- the current node 1
我们有一个使用 F5 BIG-IP 服务器进行负载平衡的潜在客户端。在确定我们是否可以将我们的产品与他们的负载均衡器干净地集成时,我开始查看 F5 提供的 API。问题是,如果没有 F5 服务器,我无
我正在尝试使用 react-big-calendar 包。 http://intljusticemission.github.io/react-big-calendar/examples/index.
我的任务是尝试找到给定 Java 方法的 big-O 和 big-Omega,但不知道如何找到。我知道 big-O 给出了上限,big-Omega 给出了下限,但是在查看程序(更不用说递归程序)时,我
我正在尝试确定以下陈述是对还是错。 如果 f(n) ∈ O(n) 且 g(n) ∈ Ω(n),则 f(n) + g(n) ∈ Θ(n)。 我想我理解添加相同的渐近 big-O。 O(n) + O(n)
我是一名优秀的程序员,十分优秀!