{"blog_url":"https://inamori.hateblo.jp/","provider_name":"Hatena Blog","provider_url":"https://hatena.blog","html":"<iframe src=\"https://hatenablog-parts.com/embed?url=https%3A%2F%2Finamori.hateblo.jp%2Fentry%2F2023%2F02%2F08%2F214023\" title=\"\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u3068\u6570\u5b66 030 - inamori\u2019s diary\" class=\"embed-card embed-blogcard\" scrolling=\"no\" frameborder=\"0\" style=\"display: block; width: 100%; height: 190px; max-width: 500px; margin: 10px 0px;\"></iframe>","title":"\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u3068\u6570\u5b66 030","author_url":"https://blog.hatena.ne.jp/inamori/","url":"https://inamori.hateblo.jp/entry/2023/02/08/214023","author_name":"inamori","description":"https://atcoder.jp/contests/math-and-algorithm/tasks/dp_d\u91cd\u3055\u3092\u72b6\u614b\u3068\u3059\u308bDP\u3067\u3059\u306d\u3002 // Knapsack 1 #![allow(non_snake_case)] use std::cmp::max; fn read<T: std::str::FromStr>() -> T { let mut line = String::new(); std::io::stdin().read_line(&mut line).ok(); line.trim().parse().ok().unwrap() } fn read_vec<T: std::\u2026","image_url":null,"blog_title":"inamori\u2019s diary","categories":[],"width":"100%","published":"2023-02-08 21:40:23","version":"1.0","height":"190","type":"rich"}