2010-11-30 2 views
4

set_unionset_unionは、次のコードと同等であると主張しています:正しいstd :: set_unionコードは何ですか?

template <class InputIterator1, class InputIterator2, class OutputIterator> 
    OutputIterator set_union (InputIterator1 first1, InputIterator1 last1, 
          InputIterator2 first2, InputIterator2 last2, 
          OutputIterator result) 
{ 
    while (true) 
    { 
    if (*first1<*first2) *result++ = *first1++; 
    else if (*first2<*first1) *result++ = *first2++; 
    else { *result++ = *first1++; first2++; } 

    if (first1==last1) return copy(first2,last2,result); 
    if (first2==last2) return copy(first1,last1,result); 
    } 
} 

しかし、それは奇妙に見えます:範囲のいずれかが空であればクラッシュしませんか? 2つのif句は、whileループの始めに終わりではなくてはなりませんか?

+4

cplusplus.comは信頼できるリファレンスではありません。 ISO/IEC 14882は、 'set_union'のサンプルコードを含んでおらず、単に入力シーケンスを空にすることができる仕様です。 –

+0

実際、私はcplusplus.comが一度も好きではありませんでした。詳細は正確ではありません。 – ybungalobill

+0

@ybungalobill:私はインデックスとしてそれが好きです:) –

答えて

4

私はそれが完全に壊れていることに同意します。比較のため、ここにSTLportコードがあります:

 
template <class _InputIter1, class _InputIter2, class _OutputIter, 
      class _Compare> 
_OutputIter __set_union(_InputIter1 __first1, _InputIter1 __last1, 
         _InputIter2 __first2, _InputIter2 __last2, 
         _OutputIter __result, _Compare __comp) { 
    _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1)) 
    _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2)) 
    while (__first1 != __last1 && __first2 != __last2) { 
    if (__comp(*__first1, *__first2)) { 
     _STLP_VERBOSE_ASSERT(!__comp(*__first2, *__first1), _StlMsg_INVALID_STRICT_WEAK_PREDICATE) 
     *__result = *__first1; 
     ++__first1; 
    } 
    else if (__comp(*__first2, *__first1)) { 
     _STLP_VERBOSE_ASSERT(!__comp(*__first1, *__first2), _StlMsg_INVALID_STRICT_WEAK_PREDICATE) 
     *__result = *__first2; 
     ++__first2; 
    } 
    else { 
     *__result = *__first1; 
     ++__first1; 
     ++__first2; 
    } 
    ++__result; 
    } 
    return _STLP_STD::copy(__first2, __last2, _STLP_STD::copy(__first1, __last1, __result)); 
} 
関連する問題