diff --git a/lib/std/rand.zig b/lib/std/rand.zig index c13d2895c9..e94578c119 100644 --- a/lib/std/rand.zig +++ b/lib/std/rand.zig @@ -343,7 +343,7 @@ pub const Random = struct { /// /// This is useful for selecting an item from a slice where weights are not equal. /// `T` must be a numeric type capable of holding the sum of `proportions`. - pub fn weightedIndex(r: std.rand.Random, comptime T: type, proportions: []T) usize { + pub fn weightedIndex(r: std.rand.Random, comptime T: type, proportions: []const T) usize { // This implementation works by summing the proportions and picking a random // point in [0, sum). We then loop over the proportions, accumulating // until our accumulator is greater than the random point. diff --git a/lib/std/rand/test.zig b/lib/std/rand/test.zig index cae77d6e37..1ad9adbeb8 100644 --- a/lib/std/rand/test.zig +++ b/lib/std/rand/test.zig @@ -452,7 +452,7 @@ test "Random weightedIndex" { var prng = DefaultPrng.init(0); const random = prng.random(); - var proportions = [_]T{ 2, 1, 1, 2 }; + const proportions = [_]T{ 2, 1, 1, 2 }; var counts = [_]f64{ 0, 0, 0, 0 }; const n_trials: u64 = 10_000;