C++中的多态和模板

news2025/4/8 0:25:15

#include <iostream>
#include <cstdlib>
#include <ctime>
#include <string>

using namespace std;

// 武器基类
class Weapon {
public:
    virtual ~Weapon() {}
    virtual string getName() const = 0;  // 获取武器名称
    virtual int getAtk() const = 0;      // 获取武器攻击力
};

// 具体武器类
class Sword : public Weapon {
public:
    string getName() const override { return "Sword"; }
    int getAtk() const override { return 10; }
};

class Blade : public Weapon {
public:
    string getName() const override { return "Blade"; }
    int getAtk() const override { return 7; }
};

class Axe : public Weapon {
public:
    string getName() const override { return "Axe"; }
    int getAtk() const override { return 15; }
};
// 英雄类
class Hero {
public:
    enum class Profession { Warrior, Archer, Mage };

    Hero(Profession profession) : profession(profession) {}

    // 获取英雄职业
    Profession getProfession() const { return profession; }

private:
    Profession profession;
};
class Monster {
public:
    Monster() {
        // 初始化随机种子
        srand(static_cast<unsigned int>(time(0)));
    }

    // 怪物死亡时掉落武器
    Weapon* die(const Hero& hero) {
        cout << "Monster died!" << endl;

        // 根据英雄职业或随机规则决定掉落武器
        Weapon* droppedWeapon = dropWeapon(hero);
        cout << "Dropped weapon: " << droppedWeapon->getName() << end

        return droppedWeapon;
    }

private:
    // 根据英雄职业或随机掉落武器
    Weapon* dropWeapon(const Hero& hero) {
        if (hero.getProfession() == Hero::Profession::Warrior) {
            return new Axe();  // 战士掉落斧头
        } else if (hero.getProfession() == Hero::Profession::Archer) 
            return new Sword();  // 弓箭手掉落长剑
        } else if (hero.getProfession() == Hero::Profession::Mage) {
            return new Blade();  // 法师掉落短剑
        }

        // 如果是其他职业,随机掉落武器
        int randChoice = rand() % 3;
        if (randChoice == 0) {
            return new Sword();
        } else if (randChoice == 1) {
            return new Blade();
        } else {
            return new Axe();
        }
    }
};
int main() {
    // 创建不同职业的英雄
    Hero warrior(Hero::Profession::Warrior);
    Hero archer(Hero::Profession::Archer);
    Hero mage(Hero::Profession::Mage);

    // 创建怪物
    Monster monster;

    // 模拟怪物死亡并掉落武器
    Weapon* weapon1 = monster.die(warrior);  // 战士掉落斧头
    Weapon* weapon2 = monster.die(archer);   // 弓箭手掉落长剑
    Weapon* weapon3 = monster.die(mage);     // 法师掉落短剑

    // 删除掉落的武器,防止内存泄漏                                  
    delete weapon1;
    delete weapon2;
    delete weapon3;

    return 0;
}



#include <iostream>
using namespace std;

template <typename T>
class List {
public:
    struct Node {
        T val;
        Node* next;
        Node* prev;
    };

    // 构造函数
    List() : head(nullptr), tail(nullptr) {}

    // 析构函数
    ~List() {
        clear();
    }

    // 向链表末尾添加元素
    void push_back(const T& value) {
        Node* newNode = new Node{value, nullptr, tail};  // 创建新节点
        if (tail) {
            tail->next = newNode;  // 如果链表非空,将新的节点连接到尾节
        }
        tail = newNode;  // 更新尾节点
        if (!head) {
            head = newNode;  // 如果链表为空,更新头节点
        }
    }

    // 访问链表中指定位置的元素
    T& operator[](size_t index) {
        Node* current = head;
        size_t count = 0;
        while (current && count < index) {
            current = current->next;
            count++;
        }
        if (current) {
            return current->val;
        }
        throw out_of_range("Index out of range");
    }

    // 打印链表内容
    friend ostream& operator<<(ostream& os, const List<T>& list) {
        Node* current = list.head;
        while (current) {
            os << current->val << " ";
            current = current->next;
        }
        return os;
    }

    // 清除链表
    void clear() {
        Node* current = head;
        while (current) {
            Node* nextNode = current->next;
            delete current;  // 删除当前节点
            current = nextNode;  // 移动到下一个节点
        }
        head = tail = nullptr;  // 头尾指针置空
    }

private:
    Node* head;  // 链表头
    Node* tail;  // 链表尾
};

int main() {
    List<int> myList;
    myList.push_back(10);
    myList.push_back(20);
    myList.push_back(30);
    cout << "链表内容: " << myList << endl;

    cout << "访问索引1的元素: " << myList[1] << endl;

    return 0;
}
                                                                       
                                                                       
                                                                       

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2330124.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Wireshark 安装保姆教程(图文详解)

一、Wireshark 简介 Wireshark是使用最广泛的一款开源抓包软件&#xff0c;常用来检测网络问题、攻击溯源、或者分析底层通信机制。它使用WinPCAP作为接口&#xff0c;直接与网卡进行数据报文交换&#xff0c;它支持在 Windows、Mac OS、Linux 等多种主流操作系统上运行 &…

下载安装Node.js及其他环境

提示&#xff1a;从Node版本降级到Vue项目运行 文章目录 下载Node.js环境配置配置环境变量 安装 cnpm&#xff08;我需要安装&#xff09;安装脚手架安装依赖安装淘宝镜像&#xff08;注意会更新&#xff09;cnpm vs npm 与新旧版本核心差异包管理器不同功能差异如何选择&#…

MyBatis Plus 在 ZKmall开源商城持久层的优化实践

ZKmall开源商城作为基于 Spring Cloud 的高性能电商平台&#xff0c;其持久层通过 MyBatis Plus 实现了多项深度优化&#xff0c;涵盖分库分表、缓存策略、分页性能、多租户隔离等核心场景。以下是具体实践总结&#xff1a; 一、分库分表与插件集成优化 1. 分库分表策略 ​Sh…

rust 同时处理多个异步任务,并在一个任务完成退出

use std::thread; use tokio::{sync::mpsc,time::{sleep, Duration}, };async fn check_for_one() {// 该函数会每秒打印一次 "write"loop {println!("write");sleep(Duration::from_secs(1)).await;} }async fn start_print_task() -> Result<(), (…

使用注解开发springMVC

引言 在学习过第一个springMVC项目建造过后&#xff0c;让我们直接进入真实开发中所必需的注解开发&#xff0c; 是何等的简洁高效&#xff01;&#xff01; 注&#xff1a;由于Maven可能存在资源过滤的问题&#xff0c;在maven依赖中加入 <build><resources>&l…

【Axure元件分享】时间范围选择器

时间范围选择器下拉选择开始时间和结束时间&#xff0c;实现效果如下。 源文件截图&#xff1a; 元件获取方式&#xff1a;

【Linux操作系统——学习笔记三】Linux环境下多级目录构建与管理的命令行实践报告

1.在用户主目录下&#xff0c;使用以下方法新建目录&#xff0c;并显示详细执行过程&#xff1a; &#xff08;1&#xff09;使用绝对路径在当前目录下创建 new_dir目录 &#xff08;2&#xff09;使用相对路径、在当前目录创建dir1、dir2、dir3目录 &#xff08;3&#xff09…

C# 与 相机连接

一、通过组件连接相机 需要提前在VisionPro里面保存一个CogAcqFifoTool相机工具为 .vpp 定义一个相机工具 CogAcqFifoTool mAcq null;将保存的相机工具放入mAcq中 string path “C:\Acq.vpp”; mAcq (CogAcqFifoTool)CogSerializer.LoadObjectFrommFile(path);给窗口相机…

JAVA学习小记之IO流04--转换流篇

转换流: 按照A规则存储&#xff0c;同样按照A规则解析&#xff0c;那么就能显示正确的文本符号。反之&#xff0c;按照A规则存储&#xff0c;再按照B规则解析&#xff0c;就会导致乱码现象。 转换的原因是&#xff1a; 有的文件并非是按UTF-8编码&#xff0c;那么在读文件内容…

SH 和 BASH 有什么不同 ?

当谈到 shell 脚本编写时&#xff0c;经常出现两个突出的 shell&#xff0c;Bourne shell (SH) 和 Bourne Again shell (Bash)。两者都是基于 unix 和 linux 的系统的组成部分&#xff0c;提供与操作系统交互的接口。本文旨在深入研究这两种 shell 之间的复杂差异&#xff0c;揭…

Qt 音乐播放器项目

具体代码见&#xff1a;https://gitee.com/Suinnnnnn/MusicPlayer 文章目录 0. 预备1. 界面1.1 各部位长度1.2 ui文件1.3 窗口前置设置1.4 设置QSS 2. 自定义控件2.1 按钮2.2 推荐页面2.3 CommonPage2.4 滑杆 3. 音乐管理4. 歌词界面4.1 ui文件4.2 LrcPage.h文件 5. 音乐播放控…

.NET用C#在PDF文档中添加、删除和替换图片

在当今数字化文档处理场景中&#xff0c;动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一。通过C#在.NET平台实现图片的添加、替换和删除功能&#xff0c;不仅能显著提升PDF文档的视觉表现力与信息承载效率&#xff0c;更可满足数据动态更新、内容精准维护等复杂业…

anaconda安装使用+pytorch环境配置(cpu)+pycharm环境配置(详细教程)

一、anaconda下载 1.anaconda官网尝试下载&#xff1a; 官网网址&#xff1a;Anaconda | Built to Advance Open Source AI 1.进入官网 2.点击Products->Distribution&#xff0c;跳过注册进入下载页面 3.选择系统下载 2.清华镜像下载 1.网址&#xff1a;Index of /anac…

c++STL入门

目录 什么是STL&#xff1f; vector容器 构造函数 赋值操作 vector容量和大小 vector存放内置数据类型 vector存放自定义数据类型 存放指针 vector容器嵌套容器 string容器 构造函数 赋值操作 字符串拼接 查找和替换 string字符串比较 string字符存取 string插…

electron-update + nginx热更新

1.安装"electron-updater": “^6.6.2”, npm i electron-updater2.创建checkUpdate.js // 引入自动更新 const {autoUpdater} require(electron-updater); const { dialog } require(electron); // 自动更新检查 export function checkForUpdates() {// 检查新版…

前端知识点---本地存储(javascript)

localStorage 是浏览器提供的一个 本地存储 API&#xff0c;可以在用户的浏览器中存储数据&#xff0c;数据不会随页面刷新而丢失。 1. 基本用法 (1) 存储数据&#xff08;setItem&#xff09; localStorage.setItem("username", "zhangsan");存储 “use…

QML 批量创建模块 【Repeater】 组件详解

在 QML 中&#xff0c;Repeater 组件是一种非常实用的工具&#xff0c;能够批量创建控件&#xff0c;尤其是在我们需要根据数据动态生成多个相同类型的控件时。无论是列表、网格&#xff0c;还是动态生成按钮、标签等控件&#xff0c;Repeater 都能轻松胜任。 1. Repeater 组件…

【Python】Python 环境 + Pycharm 编译器 官网免费下载安装(图文教程,新手安装,Windows 10 系统)

目录 Python 环境的下载安装第一步 进入官网第二步 找到匹配 windows 系统的 python 下载页面第三步 根据电脑 cpu 架构选择 python 版本第四步 安装 python 环境第五步 验证 python 环境变量 Pycharm 的下载安装第一步 进入官网第二步 安装 Pycharm Community Edition第三步 第…

在 Elasticsearch 中使用 Amazon Nova 模型

作者&#xff1a;来自 Elastic Andre Luiz 了解如何在 Elasticsearch 中使用 Amazon Nova 系列模型。 在本文中&#xff0c;我们将讨论 Amazon 的 AI 模型家族——Amazon Nova&#xff0c;并学习如何将其与 Elasticsearch 结合使用。 关于 Amazon Nova Amazon Nova 是 Amazon …

sql server数据库可疑修复

sql server数据库可疑修复 从上图可以看到数据库nchrdb显示可疑&#xff0c;导致原因为NC系统在增加公共薪资项目的时候&#xff0c;扩展字段报错了&#xff0c;第一次遇到这种情况&#xff0c;折腾了很久终于解决&#xff0c;记下解决方案&#xff1a; 1&#xff0c;将SQL数据…