更新:我遵循约翰的指导,并修改了他的代码,通过创建比较函数解决了我的问题,并将其插入到STL地图中的比较参数中。由于我的字符串日期严格按照显示的格式,使用substr会很好。我的输出和代码仅供参考。STL地图排序
Date Total Sales
01JAN1900 $4
20JAN1902 $40
18NOV1912 $2500
19NOV1912 $2500
19OCT1923 $25
01JAN1991 $22
15NOV1991 $300
Grand Total: $5391
struct CompareDates
:
public std::binary_function <bool, std::string, std::string>
{
bool operator() (const std::string& lhs, const std::string& rhs)
{
if(lhs.substr(5,4) < rhs.substr(5,4))
{
return true;
}
else if (lhs.substr(5,4) == rhs.substr(5,4) && lhs.substr(2,3) < rhs.substr(2,3))
{
return true;
}
else if (lhs.substr(5,4) == rhs.substr(5,4) && lhs.substr(2,3) == rhs.substr(2,3) && lhs.substr(0,2) < rhs.substr(0,2))
{
return true;
}
else
{
return false;
}
}
};
map<string, double,CompareDates> dailyDatePrices;
初始问题:我需要将原始数据分类为日常报告格式。因此,我使用STL map
将日期作为关键字和物品价格存储为值。从我读的内容来看,STL地图是自动排序的。不过,我不希望它按照地图进行排序,因为它会生成下面所述的不需要的当前报告输出。我会根据字符串日期进行排序(从最早到最新),并希望它是完全格式。在使用map之前,我已经使用矢量和函数比较器对日期进行了排序。有什么办法可以做到吗?谢谢!
Raw Data
STRAW:10:15NOV1991
TOY:10:15NOV1991
BARLEY:5:01OCT1992
Undesired Current Report Output
01OCT1992 5
15NOV1991 20
Expected Report Output
15NOV1991 20
01OCT1992 5
使用选择的排序标准实例化映射。 – juanchopanza
你将不得不将字符串转换为日期,并让日期的顺序得到正确的顺序(或使用强的比较器来完成该顺序) - 最好查找日期库 – Mark
你的'日期类定义?该类中具体是'operator <'? – Naveen