You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
hello-algo/codes/zig/chapter_array_and_linkedlist/list.zig

79 lines
2.3 KiB

// File: list.zig
// Created Time: 2023-01-07
// Author: codingonion (coderonion@gmail.com)
const std = @import("std");
const inc = @import("include");
// Driver Code
pub fn main() !void {
// 初始化列表
var nums = std.ArrayList(i32).init(std.heap.page_allocator);
// 延迟释放内存
defer nums.deinit();
try nums.appendSlice(&[_]i32{ 1, 3, 2, 5, 4 });
std.debug.print("列表 nums = ", .{});
inc.PrintUtil.printList(i32, nums);
// 访问元素
var num = nums.items[1];
std.debug.print("\n访问索引 1 处的元素,得到 num = {}", .{num});
// 更新元素
nums.items[1] = 0;
std.debug.print("\n将索引 1 处的元素更新为 0 ,得到 nums = ", .{});
inc.PrintUtil.printList(i32, nums);
// 清空列表
nums.clearRetainingCapacity();
std.debug.print("\n清空列表后 nums = ", .{});
inc.PrintUtil.printList(i32, nums);
// 在尾部添加元素
try nums.append(1);
try nums.append(3);
try nums.append(2);
try nums.append(5);
try nums.append(4);
std.debug.print("\n添加元素后 nums = ", .{});
inc.PrintUtil.printList(i32, nums);
// 在中间插入元素
try nums.insert(3, 6);
std.debug.print("\n在索引 3 处插入数字 6 ,得到 nums = ", .{});
inc.PrintUtil.printList(i32, nums);
// 删除元素
_ = nums.orderedRemove(3);
std.debug.print("\n删除索引 3 处的元素,得到 nums = ", .{});
inc.PrintUtil.printList(i32, nums);
// 通过索引遍历列表
var count: i32 = 0;
var i: i32 = 0;
while (i < nums.items.len) : (i += 1) {
count += nums[i];
}
// 直接遍历列表元素
count = 0;
for (nums.items) |x| {
count += x;
}
// 拼接两个列表
var nums1 = std.ArrayList(i32).init(std.heap.page_allocator);
defer nums1.deinit();
try nums1.appendSlice(&[_]i32{ 6, 8, 7, 10, 9 });
try nums.insertSlice(nums.items.len, nums1.items);
std.debug.print("\n将列表 nums1 拼接到 nums 之后,得到 nums = ", .{});
inc.PrintUtil.printList(i32, nums);
// 排序列表
std.mem.sort(i32, nums.items, {}, comptime std.sort.asc(i32));
std.debug.print("\n排序列表后 nums = ", .{});
inc.PrintUtil.printList(i32, nums);
_ = try std.io.getStdIn().reader().readByte();
}