亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? stl_valarray.h

?? 粗慥集成算法集合 ,并有詳細的文檔資料和測試數(shù)據(jù)處
?? H
?? 第 1 頁 / 共 4 頁
字號:
  // Extension: check for an empty gslice.
  bool _M_empty() const { return _M_lengths.size() == 0; }

  // Extension: number of indices this gslice represents.  (For a degenerate
  // gslice, they're not necessarily all distinct.)
  size_t _M_size() const {
    return !this->_M_empty()
      ? accumulate(_M_lengths._M_first + 1,
                   _M_lengths._M_first + _M_lengths._M_size,
                   _M_lengths[0],
                   multiplies<size_t>())
      : 0;
  }

private:
  size_t _M_start;
  valarray<size_t> _M_lengths;
  valarray<size_t> _M_strides;
};

// This is not an STL iterator.  It is constructed from a gslice, and it
// steps through the gslice indices in sequence.  See 23.3.6 of the C++
// standard, paragraphs 2-3, for an explanation of the sequence.  At
// each step we get two things: the ordinal (i.e. number of steps taken),
// and the one-dimensional index.

template <class _Size>
struct _Gslice_Iter_tmpl {
  _Gslice_Iter_tmpl(const gslice& __gslice)
    : _M_step(0), _M_1d_idx(__gslice.start()),
      _M_indices(size_t(0), __gslice._M_lengths.size()),
      _M_gslice(__gslice)
    {}
    
  bool _M_done() const { return _M_indices[0] == _M_gslice._M_lengths[0]; }

  bool _M_incr();

  _Size _M_step;
  _Size _M_1d_idx;

  valarray<_Size> _M_indices;
  const gslice& _M_gslice;
};

typedef _Gslice_Iter_tmpl<size_t> _Gslice_Iter;

template <class _Tp>
class gslice_array {
  friend class valarray<_Tp>;
public:
  typedef _Tp value_type;

  void operator= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] = __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator*= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] *= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator/= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] /= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator%= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] %= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator+= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] += __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator-= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] -= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator^= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] ^= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator&= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] &= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator|= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] |= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator<<= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] <<= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator>>= (const valarray<value_type>& __x) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] >>= __x[__i._M_step]; while(__i._M_incr());
    }
  }

  void operator= (const value_type& __c) const {
    if (!_M_gslice._M_empty()) {
      _Gslice_Iter __i(_M_gslice);
      do _M_array[__i._M_1d_idx] = __c; while(__i._M_incr());
    }
  }

  ~gslice_array() {}

private:                        
  gslice_array(gslice __gslice, valarray<_Tp>& __array)
    : _M_gslice(__gslice), _M_array(__array)
    {}

  gslice                _M_gslice;
  valarray<value_type>& _M_array;

private:                        // Disable assignment
  void operator=(const gslice_array&);
};

// valarray member functions dealing with gslice and gslice_array.  Note
// that it is illegal (behavior is undefined) to construct a gslice_array
// from a degenerate gslice.

template <class _Tp>
inline valarray<_Tp>::valarray(const gslice_array<_Tp>& __x)
  : _Valarray_base<_Tp>(__x._M_gslice._M_size())
{
  typedef typename __type_traits<_Tp>::has_trivial_default_constructor
          _Is_Trivial;
  _M_initialize(_Is_Trivial());  
  *this = __x;
}

template <class _Tp>
inline gslice_array<_Tp> valarray<_Tp>::operator[](gslice __slice) {
  return gslice_array<_Tp>(__slice, *this);
}


//----------------------------------------------------------------------
// mask_array

template <class _Tp>
class mask_array {
  friend class valarray<_Tp>;
public:
  typedef _Tp value_type;

  void operator=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] = __x[__idx++];
  }

  void operator*=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] *= __x[__idx++];
  }

  void operator/=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] /= __x[__idx++];
  }

  void operator%=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] %= __x[__idx++];
  }

  void operator+=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] += __x[__idx++];
  }

  void operator-=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] -= __x[__idx++];
  }
  
  void operator^=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] ^= __x[__idx++];
  }

  void operator&=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] &= __x[__idx++];
  }

  void operator|=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] |= __x[__idx++];
  }

  void operator<<=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] <<= __x[__idx++];
  }

  void operator>>=(const valarray<value_type>& __x) const {
    size_t __idx = 0;
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] >>= __x[__idx++];
  }

  void operator=(const value_type& __c) const {
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
      if (_M_mask[__i]) _M_array[__i] = __c;
  }

  ~mask_array() {}

  // Extension: number of true values in the mask
  size_t _M_num_true() const {
    size_t __result = 0;
    for (size_t __i = 0; __i < _M_mask.size(); ++__i)
      if (_M_mask[__i]) ++__result;
    return __result;
  }

private:
  mask_array(const valarray<bool>& __mask, valarray<_Tp>& __array)
    : _M_mask(__mask), _M_array(__array)
    {}

  valarray<bool> _M_mask;
  valarray<_Tp>& _M_array;

private:                        // Disable assignment
  void operator=(const mask_array&);
};

// valarray member functions dealing with mask_array

template <class _Tp>
inline valarray<_Tp>::valarray(const mask_array<_Tp>& __x)
  : _Valarray_base<_Tp>(__x._M_num_true())
{
  typedef typename __type_traits<_Tp>::has_trivial_default_constructor
          _Is_Trivial;
  _M_initialize(_Is_Trivial());  
  *this = __x;
}

// Behavior is undefined if __x._M_num_true() != this->size()
template <class _Tp>
inline valarray<_Tp>& valarray<_Tp>::operator=(const mask_array<_Tp>& __x) {
  size_t __idx = 0;
  for (size_t __i = 0; __i < __x._M_array.size(); ++__i)
    if (__x._M_mask[__i]) (*this)[__idx++] = __x._M_array[__i];
  return *this;
}

template <class _Tp>
inline mask_array<_Tp> valarray<_Tp>::operator[](const valarray<bool>& __mask)
{
  return mask_array<_Tp>(__mask, *this);
}


//----------------------------------------------------------------------
// indirect_array

template <class _Tp>
class indirect_array {
  friend class valarray<_Tp>;
public:
  typedef _Tp value_type;

  void operator=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] = __x[__i];
  }

  void operator*=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] *= __x[__i];
  }

  void operator/=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] /= __x[__i];
  }

  void operator%=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] %= __x[__i];
  }

  void operator+=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] += __x[__i];
  }

  void operator-=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] -= __x[__i];
  }

  void operator^=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] ^= __x[__i];
  }

  void operator&=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] &= __x[__i];
  }

  void operator|=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] |= __x[__i];
  }

  void operator<<=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] <<= __x[__i];
  }

  void operator>>=(const valarray<value_type>& __x) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] >>= __x[__i];
  }

  void operator=(const value_type& __c) const {
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
      _M_array[_M_addr[__i]] = __c;
  }

  ~indirect_array() {}

private:
  indirect_array(const valarray<size_t>& __addr, valarray<_Tp>& __array)
    : _M_addr(__addr), _M_array(__array)
    {}

  valarray<size_t> _M_addr;
  valarray<_Tp>&   _M_array;

private:                        // Disable assignment
  void operator=(const indirect_array&);
};

// valarray member functions dealing with indirect_array

template <class _Tp>
inline valarray<_Tp>::valarray(const indirect_array<_Tp>& __x)
  : _Valarray_base<_Tp>(__x._M_addr.size())
{
  typedef typename __type_traits<_Tp>::has_trivial_default_constructor
          _Is_Trivial;
  _M_initialize(_Is_Trivial());  
  *this = __x;
}


template <class _Tp>
inline indirect_array<_Tp>
valarray<_Tp>::operator[](const valarray<size_t>& __addr)
{
  return indirect_array<_Tp>(__addr, *this);
}

__STL_END_NAMESPACE

#  undef __STL_DO_ABS
#  undef __STL_DO_ACOS
#  undef __STL_DO_ASIN
#  undef __STL_DO_ATAN
#  undef __STL_DO_ATAN2
#  undef __STL_DO_COS
#  undef __STL_DO_COSH
#  undef __STL_DO_LOG
#  undef __STL_DO_LOG10
#  undef __STL_DO_POW
#  undef __STL_DO_SIN
#  undef __STL_DO_SINH
#  undef __STL_DO_SQRT
#  undef __STL_DO_TAN
#  undef __STL_DO_TANH

# if !defined (__STL_LINK_TIME_INSTANTIATION)
#  include <stl_valarray.c>
# endif

#endif /* __SGI_STL_VALARRAY */


// Local Variables:
// mode:C++
// End:

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91视频观看视频| 国产一区二区在线免费观看| 成人av动漫网站| 亚洲女人****多毛耸耸8| 91视频com| 日韩av不卡在线观看| 26uuu国产在线精品一区二区| 紧缚捆绑精品一区二区| 国产免费成人在线视频| 成人精品一区二区三区中文字幕| 国产精品国产三级国产有无不卡| 日本国产一区二区| 日韩和的一区二区| 久久婷婷国产综合国色天香| 成人国产精品视频| 一区二区三区在线看| 666欧美在线视频| 国产精品一级在线| 曰韩精品一区二区| 精品少妇一区二区三区在线视频| 丁香激情综合五月| 亚洲线精品一区二区三区| 欧美电影免费观看高清完整版在线| 国产盗摄视频一区二区三区| 亚洲自拍另类综合| 久久久久久久久久美女| 欧美这里有精品| 久久国产婷婷国产香蕉| 亚洲欧美日本在线| 欧美精品一区在线观看| 91色视频在线| 韩国女主播一区二区三区| 亚洲毛片av在线| 久久免费看少妇高潮| 欧美三级午夜理伦三级中视频| 美腿丝袜在线亚洲一区| 亚洲人亚洲人成电影网站色| 日韩精品一区二区三区视频| av一区二区久久| 精品在线观看视频| 亚洲夂夂婷婷色拍ww47| 国产视频亚洲色图| 91精品免费在线| 色综合天天综合网天天看片| 国产一区啦啦啦在线观看| 一区二区三区国产豹纹内裤在线| 久久久久久97三级| 欧美精品成人一区二区三区四区| 成人av网在线| 国产精品夜夜爽| 麻豆精品国产传媒mv男同| 亚洲综合在线五月| 国产精品不卡在线| 久久网站最新地址| 欧美成人video| 欧美妇女性影城| 在线观看国产日韩| 91麻豆自制传媒国产之光| 成人中文字幕合集| 国产精品夜夜爽| 国产乱码一区二区三区| 免费在线观看日韩欧美| 日本网站在线观看一区二区三区| 亚洲综合网站在线观看| 国产精品三级av| 国产精品色哟哟| 国产精品久久久一区麻豆最新章节| 久久精品一区二区三区不卡牛牛| 精品少妇一区二区三区在线播放| 欧美一区二区精品在线| 宅男在线国产精品| 51久久夜色精品国产麻豆| 欧美视频自拍偷拍| 欧美影院精品一区| 在线观看视频一区二区| 日本高清免费不卡视频| 在线免费观看日韩欧美| 色视频欧美一区二区三区| 一本久道中文字幕精品亚洲嫩 | 蜜臀av一区二区在线观看| 亚洲一卡二卡三卡四卡五卡| 亚洲综合丁香婷婷六月香| 午夜亚洲福利老司机| 日韩不卡一二三区| 激情伊人五月天久久综合| 九九九精品视频| 国产成人一区在线| 92精品国产成人观看免费| 91色porny在线视频| 欧美日韩三级在线| 日韩午夜av一区| 久久精品视频一区二区| 中文在线资源观看网站视频免费不卡 | 日本系列欧美系列| 国产在线国偷精品产拍免费yy| 国产黄色精品视频| 成人18视频日本| 在线观看区一区二| 91精品国产综合久久久久久久久久 | 亚洲综合激情另类小说区| 午夜精品在线视频一区| 久久机这里只有精品| 成人av资源网站| 欧美调教femdomvk| 精品国产一区久久| 国产精品你懂的在线| 亚洲尤物视频在线| 蜜桃av一区二区三区| 成人av动漫在线| 91精品在线观看入口| 国产欧美一二三区| 亚洲第一av色| 国产精品18久久久久久久网站| 91福利资源站| 久久精品网站免费观看| 亚洲精品高清视频在线观看| 美女一区二区三区| 99视频在线精品| 欧美一级二级三级蜜桃| 国产精品午夜久久| 日韩国产精品久久久久久亚洲| 国产不卡一区视频| 欧美久久一二三四区| 国产欧美日韩精品a在线观看| 天堂蜜桃一区二区三区| 成人午夜短视频| 欧美一级理论片| 艳妇臀荡乳欲伦亚洲一区| 国产激情偷乱视频一区二区三区| 欧美日韩www| 国产精品久久久久久久午夜片| 日韩av高清在线观看| 99国产精品久久久久久久久久久| 精品美女一区二区三区| 亚洲一区在线播放| 高清成人在线观看| 日韩欧美一区二区不卡| 亚洲午夜免费视频| 99视频一区二区| 欧美精品一区二区三| 天堂精品中文字幕在线| 色婷婷综合久色| 中文字幕免费在线观看视频一区| 美女mm1313爽爽久久久蜜臀| 欧洲激情一区二区| 亚洲精品视频在线看| 成人av免费网站| 久久久久国产精品免费免费搜索| 奇米色777欧美一区二区| 欧美日韩精品一区二区三区| 亚洲精品视频在线观看网站| eeuss鲁一区二区三区| 久久久国产精品不卡| 精品一区二区在线看| 欧美一级夜夜爽| 日av在线不卡| 欧美一二区视频| 免费在线观看成人| 日韩免费成人网| 美国av一区二区| www激情久久| 国产不卡免费视频| 久久天天做天天爱综合色| 国产一区二区三区最好精华液| 精品剧情v国产在线观看在线| 美女视频一区二区三区| 欧美一个色资源| 精品一区二区三区的国产在线播放 | 国产一区二区三区最好精华液| 欧美zozo另类异族| 另类小说一区二区三区| 精品99一区二区三区| 国产一区二区91| 亚洲国产精品v| 99久久久无码国产精品| 亚洲精品成人在线| 欧美日韩一级黄| 久久精工是国产品牌吗| 国产偷国产偷精品高清尤物| proumb性欧美在线观看| 亚洲免费视频中文字幕| 欧美日韩小视频| 免费成人在线视频观看| 久久久久一区二区三区四区| jizz一区二区| 亚洲国产一区视频| 精品捆绑美女sm三区| 国产91富婆露脸刺激对白| 亚洲日穴在线视频| 欧美精品少妇一区二区三区| 狠狠色综合日日| 国产精品福利av| 欧美日本在线播放| 国产精品自拍网站| 亚洲免费资源在线播放| 欧美精品aⅴ在线视频| 国内精品视频一区二区三区八戒| 国产精品你懂的在线欣赏| 欧美日韩亚洲综合一区| 国产高清在线精品|