当前位置: 首页>>代码示例>>C++>>正文


C++ ObjectList::move方法代码示例

本文整理汇总了C++中ObjectList::move方法的典型用法代码示例。如果您正苦于以下问题:C++ ObjectList::move方法的具体用法?C++ ObjectList::move怎么用?C++ ObjectList::move使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在ObjectList的用法示例。


在下文中一共展示了ObjectList::move方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: InsertAndRemoveDuplicates

void Object::InsertAndRemoveDuplicates(ObjectList& set,
					      int old)  {
  cout << "******* Object::InsertAndRemoveDuplicates() " << endl;
  // This _is_ still used by Query::GatherNewObjects() by CombineMapsVQ().
  // I think no place uses this nomore.  Should be obsoleted ???

  for (size_t i=old; i<set.size(); i++) {
    size_t p = i, q = i;
    double val = set[i].Value();
    for (int j=old-1; j>=0; j--) {
      if (val>set[j].Value())
	p = j;
      else if (q!=i)
	break;
      if (q==i && set[j].Match(set[i])) {
	val = set[j].AddValue(val);  // OBS! AddValue()
	p = q = j;
      }
    }
    set.move(q, p);
    if (q==i)
      old++;
    else {
      set.swap_objects(i, set.size()-1);
      set.erase(set.size()-1);
      i--;
    }
  }
}
开发者ID:aalto-cbir,项目名称:PicSOM,代码行数:29,代码来源:Valued.C

示例2: SortListByRank

  void Object::SortListByRank(ObjectList& list) {
    int k = 0;
    for (size_t j=1; j<list.size(); j++) {
      if (!list[j].Retained())
	continue; 
      int r = list[j].Rank();
      for (k=j-1; k>=0; k--)
	if (list[k].Retained() && list[k].Rank()<=r)
	  break;
      
      /*
      cout << "Object::SortList() val[" << j << "]=" << val
	   << " val[" << k+1 << "]=" << list[k+1].Rank() << endl;
      */

      list.move(j, k+1);
    }
  }
开发者ID:aalto-cbir,项目名称:PicSOM,代码行数:18,代码来源:Valued.C

示例3: SortListByValue

  void Object::SortListByValue(ObjectList& list) {
    // This _is_ still used by Query::StageFinalSelect().
    //Obsoleted("Object::SortList(ObjectList&)");

    int k = 0;
    for (size_t j=1; j<list.size(); j++) {
      if (!list[j].Retained())
	continue; 
      float val = list[j].Value();
      for (k=j-1; k>=0; k--)
	if (list[k].Retained() && list[k].Value()>val)
	  break;
      
      /*
      cout << "Object::SortList() val[" << j << "]=" << val
	   << " val[" << k+1 << "]=" << list[k+1].Value() << endl;
      */

      list.move(j, k+1);
    }
  }
开发者ID:aalto-cbir,项目名称:PicSOM,代码行数:21,代码来源:Valued.C


注:本文中的ObjectList::move方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。