list与sort()

运行代码:

cpp 复制代码
//list与sort()
#include"std_lib_facilities.h"
//声明Item类
struct Item
{
	string name;
	int iid;
	double value;

	Item():name(" "),iid(0),value(0.0){}
	Item(string ss,int ii,double vv):name(ss),iid(ii),value(vv){}
	
	friend istream& operator>>(istream& is, Item& ii);
	friend ostream& operator<<(ostream& os, const Item& ii);

};

//------------------------------------------------------------
//重载Item类的输入和输出操作符
istream& operator>>(istream& is, Item& ii)
{
	is >> ii.name >> ii.iid >> ii.value;
	return is;
}

ostream& operator<<(ostream& os, const Item& ii)
{
	os << ii.name << " " << ii.iid << " " << ii.value;
	return os;
}

//----------------------------------------------------------
//定义根据name进行排序的函数(字典序)
bool sort_by_name(Item& ii1,Item& ii2)
{
	return ii1.name < ii2.name;
}

//------------------------------------------------------------
//定义根据iid进行排序的函数(升序)
bool sort_by_iid(Item& ii1, Item& ii2)
{
	return ii1.iid < ii2.iid;
}

//------------------------------------------------------------
//定义根据value进行排序的函数(降序)
bool sort_by_value(Item& ii1, Item& ii2)
{
	return ii1.value > ii2.value;
}

//-------------------------------------------------------------
int main()
try
{
	cout << "输入读取文件名: ";
	string from_file;
	cin >> from_file;

	ifstream is(from_file.c_str());
	if (!is)error("can't open ", from_file);

	istream_iterator<Item>ii(is);
	istream_iterator<Item>eos;
	ostream_iterator<Item>oo(cout, "\n");

	list<Item>ll(ii, eos);
	ll.sort(sort_by_value);
	copy(ll.begin(), ll.end(), oo);

	return 0;
}
catch (exception& e) {
	cerr << "error:" << e.what() << '\n';
	keep_window_open();
	return 1;
}
catch (...) {
	cerr << "Oops:unknown exception!\n";
	keep_window_open();
	return 2;
}

读取文件:Item_file.txt

Max 2 43.2
Jane 3 34.2
Tom 3 32.4
Mary 8 23.0
Peter 5 32.5
Max 2 43.2
Jane 3 34.2
Tom 3 32.4
Mary 8 23.0
Peter 5 32.5

运行结果:

相关推荐
penguin_bark31 分钟前
904. 水果成篮
算法
Black—slience31 分钟前
LeetCode2207解题思路
java·算法·leetcode·动态规划
西农小陈32 分钟前
python-金币/打分/小理学数列3
数据结构·python·算法
楼下创了电瓶车34 分钟前
力扣224. 基本计算器
数据结构·算法·leetcode
丹柒七36 分钟前
力扣刷题之1014.最佳观光组合
数据结构·算法·leetcode
luthane37 分钟前
python 实现random forest classifier随机森林分类器算法
python·算法·随机森林
sjsjs111 小时前
【数据结构-栈】力扣682. 棒球比赛
数据结构·算法·leetcode
范特西元前1 小时前
【数据结构中的哈希】
数据结构·算法·哈希算法
@nastyboy2 小时前
数据结构:链表算法题
c语言·开发语言·数据结构·算法
极客小张3 小时前
基于STM32的智能家居交互终端:使用FreeRTOS与MQTT协议的流程设计
c语言·stm32·物联网·算法·毕业设计·智能家居·交互