summaryrefslogtreecommitdiff
path: root/util/mem.zig
diff options
context:
space:
mode:
Diffstat (limited to 'util/mem.zig')
-rw-r--r--util/mem.zig17
1 files changed, 17 insertions, 0 deletions
diff --git a/util/mem.zig b/util/mem.zig
new file mode 100644
index 0000000..89ba67b
--- /dev/null
+++ b/util/mem.zig
@@ -0,0 +1,17 @@
+const std = @import("std");
+const math = std.math;
+
+/// Returns the position of the smallest number in a slice.
+pub fn min_idx(comptime T: type, slice: []const T) usize {
+ var best = slice[0];
+ var idx: usize = 0;
+
+ for (slice[1..]) |item, i| {
+ const possible_best = math.min(best, item);
+ if (best > possible_best) {
+ best = possible_best;
+ idx = i + 1;
+ }
+ }
+ return idx;
+}