植物大战 仿函数——C++

  • 以下是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对象对植物进行排序,最后输出按成本排序的植物列表。

猜你喜欢

转载自blog.csdn.net/TaiYang_5339/article/details/129542870