<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<oembed>
  <author_name>mmxsrup</author_name>
  <author_url>https://blog.hatena.ne.jp/mmxsrup/</author_url>
  <blog_title>srupのメモ帳</blog_title>
  <blog_url>https://mmxsrup.hatenablog.com/</blog_url>
  <categories>
    <anon>abc</anon>
    <anon>dfs</anon>
    <anon>ワーシャルフロイド法</anon>
  </categories>
  <description>問題 問題概要 省略 解法 dfsで友達の友達を求めることにした。この時に、dfsの引き数として、現在の頂点と、前回の頂点、探索回数、スタート時点の頂点を持つことにした。前回の頂点は元の頂点に戻るのを禁止しするため。スタート時点を保持しておくのは、例えば、3つの頂点がループになっているときに、頂点1から始めた時に、2回の探索で、頂点3が友達の友達でないかと求まるが、実際は、1と3は友達なので、友達の友達にはならない。そこで、f[u][v]でuとvが友達であるかの情報を入れておいて、2回の探索後に友達でないことを確認すればいい。また、友達の友達を重複してカウントしないように、一度頂点番号をset…</description>
  <height>190</height>
  <html>&lt;iframe src=&quot;https://hatenablog-parts.com/embed?url=https%3A%2F%2Fmmxsrup.hatenablog.com%2Fentry%2F2016%2F09%2F19%2F011337&quot; title=&quot;ABC 016 C - 友達の友達 - srupのメモ帳&quot; class=&quot;embed-card embed-blogcard&quot; scrolling=&quot;no&quot; frameborder=&quot;0&quot; style=&quot;display: block; width: 100%; height: 190px; max-width: 500px; margin: 10px 0px;&quot;&gt;&lt;/iframe&gt;</html>
  <image_url></image_url>
  <provider_name>Hatena Blog</provider_name>
  <provider_url>https://hatena.blog</provider_url>
  <published>2016-09-19 01:13:37</published>
  <title>ABC 016 C - 友達の友達</title>
  <type>rich</type>
  <url>https://mmxsrup.hatenablog.com/entry/2016/09/19/011337</url>
  <version>1.0</version>
  <width>100%</width>
</oembed>
