-
以下是C++中实现植物大战的一个仿函数的示例:
```cpp #include <iostream> #include <string> #include <vector> class Plant { public: Plant(const std::string& n, int c) : name(n), cost(c) {} const std::string getName() const { return name; } int getCost() const { return cost; } private: std::string name; int cost; }; class PlantList { public: PlantList() { addPlant(Plant("Sunflower", 50)); addPlant(Plant("Peashooter", 100)); addPlant(Plant("Cherry Bomb", 150)); addPlant(Plant("Wall-nut", 50)); addPlant(Plant("Potato Mine", 25)); } void addPlant(const Plant& p) { plants.emplace_back(p); } const std::vector<Plant>& getPlants() const { return plants; } private: std::vector<Plant> plants; }; class PlantCost { public: bool operator()(const Plant& p1, const Plant& p2) const { return p1.getCost() < p2.getCost(); } }; int main() { PlantList list; std::cout << "Plant List (sorted by cost):" << std::endl; PlantCost costSort; std::vector<Plant> plants = list.getPlants(); std::sort(plants.begin(), plants.end(), costSort); for (const Plant& p : plants) { std::cout << p.getName() << " - " << p.getCost() << " suns" << std::endl; } return 0; } ```
该示例包括三个类:`Plant`类表示植物对象,`PlantList`类保存所有的可选植物,`PlantCost`仿函数按成本从低到高对植物进行排序。在`main()`函数中, PlantList对象实例化并使用PlantCost对象对植物进行排序,最后输出按成本排序的植物列表。
植物大战 仿函数——C++
猜你喜欢
转载自blog.csdn.net/TaiYang_5339/article/details/129542870
今日推荐
周排行