我有这张地图:map<int, int > items
。
给定一个键,我希望此映射返回与键相对应的项(如果存在),否则映射将使用键立即返回小于给定键的项。
例如,如果我有:
items[0]=0;
items[6]=10;
items[15]=18;
items[20]=22;
而不是key = 15,我希望地图返回值为18的项目,否则对于key = 9,我希望该地图返回值为10的项目。
我没有为这种情况找到一个功能。但我试着用这种方式:
itlow=items.lower_bound(key);
if(!items.count(key))
itlow--;
return itlow->second;
这可以按照我的意愿工作,默认情况下在地图中输入最小值items[0]=0
,但我知道itlow--;
这不是很好的编程。我能怎么做?谢谢大家。
答案 0 :(得分:2)
您只需要检查itlow
是否已经items.begin()
。如果是,地图中没有这样的元素:
itlow=items.lower_bound(key);
if(itlow->first == key)
return itlow->second;
else if(itlow != items.begin())
itlow--;
return itlow->second;
else
throw some_exception();
您可以返回迭代器,而不是抛出异常,如果找不到这样的元素,则可以返回items.end()
。
#include <iostream>
#include <map>
using namespace std;
map<int, int>::const_iterator find(const map<int, int> &items, int value)
{
auto itlow = items.lower_bound(value);
if(itlow->first == value)
return itlow;
else if(itlow != items.cbegin())
return --itlow;
else
return items.cend();
}
int main()
{
map<int, int> items;
items[2]=0;
items[6]=10;
items[15]=18;
items[20]=22;
auto i = find(items, 0);
if(i != items.cend())
{
cout << i->second << endl;
}
i = find(items, 15);
if(i != items.cend())
{
cout << i->second << endl;
}
i = find(items, 9);
if(i != items.cend())
{
cout << i->second << endl;
}
}