AoC ‘- 日历史学家歇斯底里(C# 和 Python)#剧透

aoc ‘- 日历史学家歇斯底里(c# 和 python)#剧透

今天的挑战非常简单:

第 1 部分:
为了解决这个问题,我们必须

根据字符串输入创建 2 个数字列表,按升序排序对于list1中的每个数字,在list2中获取相同的索引,并找到两个数字之间的距离。 然后将距离相加

简单吧。

第 2 部分:

这有点棘手,但我的解决方案的主要概念是:

立即学习“Python免费学习笔记(深入)”;

创建一个字典,其中 key 是 lista 中的数字,value 使用 count() 方法统计 listb 中与 key 相同的数字(与 lista 索引相同的数字)。

那么这只是一个将键乘以值并对总数求和的简单情况。

csharp 第 1 部分和第 2 部分:

var input = file.readalllines("./input_1.txt")    .select(s => s.split([' '], stringsplitoptions.removeemptyentries)).tolist();var lists = processlines(input);part1(lists.list1, lists.list2);part2(lists.list1, lists.list2);return;void part1(list list1, list list2){    var ordered1 = list1.orderby(x => x).tolist();    var ordered2 = list2.orderby(x => x).tolist();    var totals = ordered1        .select((t, i) => math.abs(t - ordered2[i]))        .select(difference => (long)difference)        .tolist();    console.writeline("sum of differences: " + totals.sum());}void part2(list list1, list list2){    var counts = list1.todictionary(        number => number,        number => list2.count(x => x == number)    );    var sum = counts.sum(x => x.value * x.key);    console.writeline("sum of counts: " + sum);}(list list1, list list2) processlines(list rows){    var list1 = new list();    var list2 = new list();    foreach (var row in rows)    {        list1.add(int.parse(row[0]));        list2.add(int.parse(row[1]));    }    return (list1, list2);}

第 1 部分 – python

相同的概念不同的语法 – 很多
使用内置的 zip 函数和列表理解功能更加简洁。

def get_steps(list1, list2):    totals = [abs(value - partner_item)              for value, partner_item in zip(list1, list2)]    print("Sum Total:", sum(totals))def read_input(file_name):    list1, list2 = zip(*((int(num1), int(num2))                       for num1, num2 in (line.split() for line in open(file_name))))    return sorted(list1), sorted(list2)list1, list2 = read_input("input.txt")get_steps(list1, list2)

第 2 部分 – 进行中(已经晚了)⏰

以上就是AoC ‘- 日历史学家歇斯底里(C# 和 Python)#剧透的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1354564.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 18:38:16
下一篇 2025年12月13日 18:38:25

相关推荐

发表回复

登录后才能评论
关注微信