Skip to content

Commit 9b26746

Browse files
author
cpprefjp-autoupdate
committed
update automatically
1 parent 773ed7f commit 9b26746

File tree

4 files changed

+479
-305
lines changed

4 files changed

+479
-305
lines changed

reference/algorithm/equal_range.html

Lines changed: 81 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -68,7 +68,7 @@
6868

6969
</head>
7070
<body>
71-
<header data-kunai-mdinfo="{&#34;meta&#34;: {&#34;header&#34;: [&#34;algorithm&#34;], &#34;namespace&#34;: [&#34;std&#34;], &#34;id-type&#34;: [&#34;function template&#34;]}, &#34;sources&#34;: [{&#34;id&#34;: &#34;2edecb99281974d86dee9984592d7bac47bd2fe0&#34;, &#34;source&#34;: &#34;#include &lt;iostream&gt;\n#include &lt;vector&gt;\n#include &lt;algorithm&gt;\n\nint main()\n{\n std::vector&lt;int&gt; v = {3, 1, 4, 2, 5};\n\n std::sort(v.begin(), v.end());\n\n // 3\u4ee5\u4e0a\u306e\u8981\u7d20\u3068\u30013\u3088\u308a\u5927\u304d\u3044\u8981\u7d20\u3092\u4e8c\u5206\u63a2\u7d22\u3067\u691c\u7d22\n auto result = std::equal_range(v.begin(), v.end(), 3);\n\n std::cout &lt;&lt; *result.first &lt;&lt; std::endl;\n std::cout &lt;&lt; *result.second &lt;&lt; std::endl;\n}\n&#34;}], &#34;page_id&#34;: [&#34;reference&#34;, &#34;algorithm&#34;, &#34;equal_range&#34;]}">
71+
<header data-kunai-mdinfo="{&#34;meta&#34;: {&#34;header&#34;: [&#34;algorithm&#34;], &#34;namespace&#34;: [&#34;std&#34;], &#34;id-type&#34;: [&#34;function template&#34;]}, &#34;sources&#34;: [{&#34;id&#34;: &#34;2edecb99281974d86dee9984592d7bac47bd2fe0&#34;, &#34;source&#34;: &#34;#include &lt;iostream&gt;\n#include &lt;vector&gt;\n#include &lt;algorithm&gt;\n\nint main()\n{\n std::vector&lt;int&gt; v = {3, 1, 4, 2, 5};\n\n std::sort(v.begin(), v.end());\n\n // 3\u4ee5\u4e0a\u306e\u8981\u7d20\u3068\u30013\u3088\u308a\u5927\u304d\u3044\u8981\u7d20\u3092\u4e8c\u5206\u63a2\u7d22\u3067\u691c\u7d22\n auto result = std::equal_range(v.begin(), v.end(), 3);\n\n std::cout &lt;&lt; *result.first &lt;&lt; std::endl;\n std::cout &lt;&lt; *result.second &lt;&lt; std::endl;\n}\n&#34;}, {&#34;id&#34;: &#34;d6628cb857901007da30b4d960ecedd7826189f8&#34;, &#34;source&#34;: &#34;#include &lt;algorithm&gt;\n#include &lt;iostream&gt;\n#include &lt;vector&gt;\n\nstruct Point {\n int x;\n int y;\n\n bool operator==(const Point&amp; other) const = default;\n auto operator&lt;=&gt;(const Point&amp; other) const = default;\n};\n\nint main() {\n std::vector&lt;Point&gt; v = {\n {1, 2},\n {3, 4},\n {3, 4},\n {5, 6},\n };\n\n // \u5024{3, 4}\u304c\u898b\u3064\u304b\u308b\u7bc4\u56f2\u3092\u53d6\u5f97\n auto result = std::equal_range(v.begin(), v.end(), {3, 4});\n\n while (result.first != result.second) {\n std::cout &lt;&lt; result.first-&gt;x &lt;&lt; \&#34;,\&#34; &lt;&lt; result.first-&gt;y &lt;&lt; std::endl;\n ++result.first;\n }\n}\n&#34;}], &#34;page_id&#34;: [&#34;reference&#34;, &#34;algorithm&#34;, &#34;equal_range&#34;]}">
7272
<nav class="navbar navbar-default" role="navigation">
7373
<div class="container-fluid">
7474
<div class="navbar-header">
@@ -188,12 +188,12 @@
188188

189189
<p class="text-right"><small>
190190
最終更新日時(UTC):
191-
<span itemprop="datePublished" content="2021-12-16T12:39:17">
192-
2021年12月16日 12時39分17秒
191+
<span itemprop="datePublished" content="2025-05-27T05:53:08">
192+
2025年05月27日 05時53分08秒
193193
</span>
194194
<br/>
195195
<span itemprop="author" itemscope itemtype="http://schema.org/Person">
196-
<span itemprop="name">rsk0315</span>
196+
<span itemprop="name">Akira Takahashi</span>
197197
</span>
198198
が更新
199199
</small></p>
@@ -214,31 +214,49 @@
214214

215215
<div class="identifier-type">function template</div><div class="header">&lt;algorithm&gt;</div><h1 itemprop="name"><span class="namespace" title="namespace std">std::</span><span class="token">equal_range</span></h1>
216216
<div itemprop="articleBody"><p><div class="codehilite"><pre><span></span><code><span class="k">namespace</span> <span class="n">std</span> <span class="p">{</span>
217-
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span> <span class="k">class</span> <span class="nc">T</span><span class="o">&gt;</span>
217+
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span>
218+
<span class="k">class</span> <span class="nc">T</span><span class="o">&gt;</span>
218219
<span class="n"><a href="../utility/pair.html">pair</a></span><span class="o">&lt;</span><span class="n">ForwardIterator</span><span class="p">,</span> <span class="n">ForwardIterator</span><span class="o">&gt;</span>
219220
<span class="n">equal_range</span><span class="p">(</span><span class="n">ForwardIterator</span> <span class="n">first</span><span class="p">,</span>
220221
<span class="n">ForwardIterator</span> <span class="n">last</span><span class="p">,</span>
221222
<span class="k">const</span> <span class="n">T</span><span class="o">&amp;</span> <span class="n">value</span><span class="p">);</span> <span class="c1">// (1) C++03</span>
222-
223-
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span> <span class="k">class</span> <span class="nc">T</span><span class="o">&gt;</span>
223+
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span>
224+
<span class="k">class</span> <span class="nc">T</span><span class="o">&gt;</span>
224225
<span class="k">constexpr</span> <span class="n"><a href="../utility/pair.html">pair</a></span><span class="o">&lt;</span><span class="n">ForwardIterator</span><span class="p">,</span> <span class="n">ForwardIterator</span><span class="o">&gt;</span>
225226
<span class="n">equal_range</span><span class="p">(</span><span class="n">ForwardIterator</span> <span class="n">first</span><span class="p">,</span>
226227
<span class="n">ForwardIterator</span> <span class="n">last</span><span class="p">,</span>
227228
<span class="k">const</span> <span class="n">T</span><span class="o">&amp;</span> <span class="n">value</span><span class="p">);</span> <span class="c1">// (1) C++20</span>
229+
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span>
230+
<span class="k">class</span> <span class="nc">T</span> <span class="o">=</span> <span class="k">typename</span> <span class="n"><a href="../iterator/iterator_traits.html">iterator_traits</a></span><span class="o">&lt;</span><span class="n">ForwardIterator</span><span class="o">&gt;::</span><span class="n">value_type</span><span class="o">&gt;</span>
231+
<span class="k">constexpr</span> <span class="n"><a href="../utility/pair.html">pair</a></span><span class="o">&lt;</span><span class="n">ForwardIterator</span><span class="p">,</span> <span class="n">ForwardIterator</span><span class="o">&gt;</span>
232+
<span class="n">equal_range</span><span class="p">(</span><span class="n">ForwardIterator</span> <span class="n">first</span><span class="p">,</span>
233+
<span class="n">ForwardIterator</span> <span class="n">last</span><span class="p">,</span>
234+
<span class="k">const</span> <span class="n">T</span><span class="o">&amp;</span> <span class="n">value</span><span class="p">);</span> <span class="c1">// (1) C++26</span>
228235

229-
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span> <span class="k">class</span> <span class="nc">T</span><span class="p">,</span> <span class="k">class</span> <span class="nc">Compare</span><span class="o">&gt;</span>
236+
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span>
237+
<span class="k">class</span> <span class="nc">T</span><span class="p">,</span>
238+
<span class="k">class</span> <span class="nc">Compare</span><span class="o">&gt;</span>
230239
<span class="n"><a href="../utility/pair.html">pair</a></span><span class="o">&lt;</span><span class="n">ForwardIterator</span><span class="p">,</span> <span class="n">ForwardIterator</span><span class="o">&gt;</span>
231240
<span class="n">equal_range</span><span class="p">(</span><span class="n">ForwardIterator</span> <span class="n">first</span><span class="p">,</span>
232241
<span class="n">ForwardIterator</span> <span class="n">last</span><span class="p">,</span>
233242
<span class="k">const</span> <span class="n">T</span><span class="o">&amp;</span> <span class="n">value</span><span class="p">,</span>
234243
<span class="n">Compare</span> <span class="n">comp</span><span class="p">);</span> <span class="c1">// (2) C++03</span>
235-
236-
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span> <span class="k">class</span> <span class="nc">T</span><span class="p">,</span> <span class="k">class</span> <span class="nc">Compare</span><span class="o">&gt;</span>
244+
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span>
245+
<span class="k">class</span> <span class="nc">T</span><span class="p">,</span>
246+
<span class="k">class</span> <span class="nc">Compare</span><span class="o">&gt;</span>
237247
<span class="k">constexpr</span> <span class="n"><a href="../utility/pair.html">pair</a></span><span class="o">&lt;</span><span class="n">ForwardIterator</span><span class="p">,</span> <span class="n">ForwardIterator</span><span class="o">&gt;</span>
238248
<span class="n">equal_range</span><span class="p">(</span><span class="n">ForwardIterator</span> <span class="n">first</span><span class="p">,</span>
239249
<span class="n">ForwardIterator</span> <span class="n">last</span><span class="p">,</span>
240250
<span class="k">const</span> <span class="n">T</span><span class="o">&amp;</span> <span class="n">value</span><span class="p">,</span>
241251
<span class="n">Compare</span> <span class="n">comp</span><span class="p">);</span> <span class="c1">// (2) C++20</span>
252+
<span class="k">template</span> <span class="o">&lt;</span><span class="k">class</span> <span class="nc">ForwardIterator</span><span class="p">,</span>
253+
<span class="k">class</span> <span class="nc">T</span> <span class="o">=</span> <span class="k">typename</span> <span class="n"><a href="../iterator/iterator_traits.html">iterator_traits</a></span><span class="o">&lt;</span><span class="n">ForwardIterator</span><span class="o">&gt;::</span><span class="n">value_type</span><span class="p">,</span>
254+
<span class="k">class</span> <span class="nc">Compare</span><span class="o">&gt;</span>
255+
<span class="k">constexpr</span> <span class="n"><a href="../utility/pair.html">pair</a></span><span class="o">&lt;</span><span class="n">ForwardIterator</span><span class="p">,</span> <span class="n">ForwardIterator</span><span class="o">&gt;</span>
256+
<span class="n">equal_range</span><span class="p">(</span><span class="n">ForwardIterator</span> <span class="n">first</span><span class="p">,</span>
257+
<span class="n">ForwardIterator</span> <span class="n">last</span><span class="p">,</span>
258+
<span class="k">const</span> <span class="n">T</span><span class="o">&amp;</span> <span class="n">value</span><span class="p">,</span>
259+
<span class="n">Compare</span> <span class="n">comp</span><span class="p">);</span> <span class="c1">// (2) C++26</span>
242260
<span class="p">}</span>
243261
</code></pre></div>
244262
</p>
@@ -254,7 +272,20 @@ <h2><a class="cpprefjp-defined-word" data-desc="関数呼び出し式の評価
254272
</ul>
255273
<h2><a class="cpprefjp-defined-word" data-desc="関数等の意味論を構成する要素の1つ。Complexity。関数が使うアルゴリズムの空間計算量・時間計算量">計算量</a></h2>
256274
<p>最大で 2 * log2(<code>last - first</code>) + O(1) 回の比較を行う</p>
275+
<h2>備考</h2>
276+
<ul>
277+
<li>(1), (2) :<ul>
278+
<li>C++26 : 引数として波カッコ初期化<code>{}</code>を受け付ける
279+
<br />
280+
<div class="codehilite"><pre><span></span><code><span class="n"><a href="../vector/vector.html">std::vector</a></span><span class="o">&lt;</span><span class="n">T</span><span class="o">&gt;</span> <span class="n">v</span><span class="p">;</span>
281+
<span class="k">auto</span> <span class="n">result</span> <span class="o">=</span> <span class="n">std</span><span class="o">::</span><span class="n">equal_range</span><span class="p">(</span><span class="n"><a href="../vector/vector/begin.html">v.begin()</a></span><span class="p">,</span> <span class="n"><a href="../vector/vector/end.html">v.end()</a></span><span class="p">,</span> <span class="p">{</span><span class="n">a</span><span class="p">,</span> <span class="n">b</span><span class="p">});</span>
282+
</code></pre></div>
283+
</li>
284+
</ul>
285+
</li>
286+
</ul>
257287
<h2></h2>
288+
<h3>基本的な使い方</h3>
258289
<p><div class="yata" id="2edecb99281974d86dee9984592d7bac47bd2fe0"><div class="codehilite"><pre><span></span><code><span class="cp">#include</span> <span class="cpf"><a href="../iostream.html">&lt;iostream&gt;</a></span><span class="cp"></span>
259290
<span class="cp">#include</span> <span class="cpf"><a href="../vector.html">&lt;vector&gt;</a></span><span class="cp"></span>
260291
<span class="cp">#include</span> <span class="cpf"><a href="../algorithm.html">&lt;algorithm&gt;</a></span><span class="cp"></span>
@@ -273,14 +304,53 @@ <h2>例</h2>
273304
<span class="p">}</span>
274305
</code></pre></div>
275306
</div></p>
276-
<h3>出力</h3>
307+
<h4>出力</h4>
277308
<p><pre><code>3
278309
4
279310
</code></pre></p>
311+
<h3>波カッコ初期化を入力として使用する (C++26)</h3>
312+
<p><div class="yata" id="d6628cb857901007da30b4d960ecedd7826189f8"><div class="codehilite"><pre><span></span><code><span class="cp">#include</span> <span class="cpf"><a href="../algorithm.html">&lt;algorithm&gt;</a></span><span class="cp"></span>
313+
<span class="cp">#include</span> <span class="cpf"><a href="../iostream.html">&lt;iostream&gt;</a></span><span class="cp"></span>
314+
<span class="cp">#include</span> <span class="cpf"><a href="../vector.html">&lt;vector&gt;</a></span><span class="cp"></span>
315+
316+
<span class="k">struct</span> <span class="n">Point</span> <span class="p">{</span>
317+
<span class="kt">int</span> <span class="n">x</span><span class="p">;</span>
318+
<span class="kt">int</span> <span class="n">y</span><span class="p">;</span>
319+
320+
<span class="kt">bool</span> <span class="k">operator</span><span class="o">==</span><span class="p">(</span><span class="k">const</span> <span class="n">Point</span><span class="o">&amp;</span> <span class="n">other</span><span class="p">)</span> <span class="k">const</span> <span class="o">=</span> <span class="k">default</span><span class="p">;</span>
321+
<span class="k">auto</span> <span class="k">operator</span><span class="o">&lt;=&gt;</span><span class="p">(</span><span class="k">const</span> <span class="n">Point</span><span class="o">&amp;</span> <span class="n">other</span><span class="p">)</span> <span class="k">const</span> <span class="o">=</span> <span class="k">default</span><span class="p">;</span>
322+
<span class="p">};</span>
323+
324+
<span class="kt">int</span> <span class="nf">main</span><span class="p">()</span> <span class="p">{</span>
325+
<span class="n"><a href="../vector/vector.html">std::vector</a></span><span class="o">&lt;</span><span class="n">Point</span><span class="o">&gt;</span> <span class="n">v</span> <span class="o">=</span> <span class="p">{</span>
326+
<span class="p">{</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">},</span>
327+
<span class="p">{</span><span class="mi">3</span><span class="p">,</span> <span class="mi">4</span><span class="p">},</span>
328+
<span class="p">{</span><span class="mi">3</span><span class="p">,</span> <span class="mi">4</span><span class="p">},</span>
329+
<span class="p">{</span><span class="mi">5</span><span class="p">,</span> <span class="mi">6</span><span class="p">},</span>
330+
<span class="p">};</span>
331+
332+
<span class="c1">// 値{3, 4}が見つかる範囲を取得</span>
333+
<span class="k">auto</span> <span class="n">result</span> <span class="o">=</span> <span class="n"><span style="color:#ff0000">std::equal_range</span></span><span class="p">(</span><span class="n"><a href="../vector/vector/begin.html">v.begin()</a></span><span class="p">,</span> <span class="n"><a href="../vector/vector/end.html">v.end()</a></span><span class="p">,</span> <span class="p">{</span><span class="mi">3</span><span class="p">,</span> <span class="mi">4</span><span class="p">});</span>
334+
335+
<span class="k">while</span> <span class="p">(</span><span class="n">result</span><span class="p">.</span><span class="n">first</span> <span class="o">!=</span> <span class="n">result</span><span class="p">.</span><span class="n">second</span><span class="p">)</span> <span class="p">{</span>
336+
<span class="n"><a href="../iostream/cout.html">std::cout</a></span> <span class="o">&lt;&lt;</span> <span class="n">result</span><span class="p">.</span><span class="n">first</span><span class="o">-&gt;</span><span class="n">x</span> <span class="o">&lt;&lt;</span> <span class="s">","</span> <span class="o">&lt;&lt;</span> <span class="n">result</span><span class="p">.</span><span class="n">first</span><span class="o">-&gt;</span><span class="n">y</span> <span class="o">&lt;&lt;</span> <span class="n"><a href="../ostream/endl.html">std::endl</a></span><span class="p">;</span>
337+
<span class="o">++</span><span class="n">result</span><span class="p">.</span><span class="n">first</span><span class="p">;</span>
338+
<span class="p">}</span>
339+
<span class="p">}</span>
340+
</code></pre></div>
341+
</div></p>
342+
<h4>出力</h4>
343+
<p><pre><code>3,4
344+
3,4
345+
</code></pre></p>
280346
<h2>参照</h2>
281347
<ul>
282348
<li><a href="http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-defects.html#384" target="_blank">LWG Issue 384. <code>equal_range</code> has unimplementable runtime complexity</a></li>
283349
<li><a href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2017/p0202r3.html" target="_blank">P0202R3 Add Constexpr Modifiers to Functions in <code>&lt;algorithm&gt;</code> and <code>&lt;utility&gt;</code> Headers</a></li>
350+
<li><a href="https://open-std.org/jtc1/sc22/wg21/docs/papers/2024/p2248r8.html" target="_blank">P2248R8 Enabling list-initialization for algorithms</a><ul>
351+
<li>C++26で波カッコ初期化 (リスト初期化) に対応した</li>
352+
</ul>
353+
</li>
284354
</ul></div>
285355

286356
</div>

0 commit comments

Comments
 (0)