C语言零基础项目:六边形扫雷寻宝模式,详细思路+源码分享

news2025/1/12 5:53:59

程序简介

六边形扫雷,寻宝模式,稍稍介绍一下。

他也是要把所有安全的地方点出来。

他没有扫雷模式的消零算法。每一个安全的点都需要单独挖出来,一次显示一个格子。

添加了生命值的概念,也就是说存在一定的容错。

显示的数字有别于扫雷模式。点击宝藏点,会显示周围宝藏点数量,绿色;点击地雷,会显示周围地雷数量,黑色。注意,这个数字不包括自己,显示的范围自然就是 0~6 了。点击地雷会减生命值,生命值归零则结束。

所以雷和宝藏都是有价值的,都是能给准确信息的。

我能给一个参考难度:占总格子数 40%的地雷,占总地雷数 50 %的生命值。

程序运行展示

完整源代码

# include <math.h>
# include <graphics.h>
# include <string>
# include <time.h>

static double pi = acos (-1.0);            // 圆周率 π
static HWND hOut;                        // 画布

// 定义一个结构体,按钮
struct Node1
{
    int posx1, posy1, posx2, posy2;        // 坐标
    LPTSTR text;                        // 文字
    int mod;                            // 状态
};

// 定义一个结构体,六边形格子
struct Node2
{
    int i, j, k;                        // 特征值
    int mod_life;                        // 翻开
    int mod_mine;                        // 雷
    int mod_flag;                        // 标记
    int posx, posy;                        // 坐标
    int num_mine;                        // 周围雷数
    int num_peace;                        // 周围空地块
};

// 定义一个类
class Gary
{
public:
    void carry ();                        // 主进程
    void initialization ();                // 初始化
    void draw_scene ();                    // 绘制界面函数
    void draw_box (int num_box);        // 绘制格子
    void draw_flag (int num_box);        // 绘制标记
    void draw_num (int num_box, int num);    // 绘制数字
    void move ();                        // 窗口主视角
    void create ();                        // 地雷生成
    void check_over ();                    // 结束判定

    int num_button;                        // 按钮数量参数
    int exit_carry;                        // 主循函数控制参数
    int exit_move;                        // 开始界面控制参数
    int exit_game;                        // 游戏进行控制参数
    int num_life;                        // 生命值
    int num_size;                        // 边长
    int num_mine;                        // 总雷数
    int num_box;                        // 总地块数
    int num_flag;                        // 标记数
    COLORREF color_text[2];                // 按钮绘制填充
    Node1 boxm[30];                        // 按钮,预制 30 个
    Node2 box[1000];                    // 地块
};

// 标记绘制函数
void Gary::draw_flag (int num_box)
{
    setlinestyle (PS_SOLID, 1);
    setlinecolor (BLACK);
    line (box[num_box].posx + 2, box[num_box].posy + 7, box[num_box].posx + 2, box[num_box].posy - 7);
    setfillcolor (LIGHTRED);
    setlinecolor (LIGHTRED);
    fillrectangle (box[num_box].posx - 7 + 2, box[num_box].posy - 7, box[num_box].posx + 2, box[num_box].posy - 1);
}

// 数字绘制函数
void Gary::draw_num (int num_box, int num)
{
    int i;
    // 画六边形,格子处于点击后状态
    setfillcolor (RGB (170, 170, 170));
    setlinecolor (RGB (85, 85, 85));
    POINT pts[6];
    setlinestyle (PS_SOLID, 1);
    for (i = 0; i < 6; i++)
    {
        pts[i].x = long(box[num_box].posx + 14.0 * cos (60.0 * double (i) * pi / 180.0));
        pts[i].y = long(box[num_box].posy + 14.0 * sin (60.0 * double (i) * pi / 180.0));
    }
    fillpolygon (pts, 6);

    // 数字绘制
    TCHAR s[15];
    settextstyle (20, 0, _T ("Consolas"));
    _stprintf_s (s, _T ("%0.1d"), num);
    outtextxy (box[num_box].posx - 5, box[num_box].posy - 10, s);
}

// 场景绘制函数
void Gary::draw_scene ()
{
    TCHAR s[15];
    int i, j;
    setlinecolor (BLACK);
    setfillcolor (WHITE);
    setlinestyle (PS_SOLID, 1);
    // 主界面
    fillrectangle (401, 0, 650, 400);
    // 根据按钮数量绘制    
    settextcolor (BLACK);
    for (i = 0; i < num_button; i++)
    {
        setfillcolor (color_text[boxm[i].mod]);
        setbkcolor (color_text[boxm[i].mod]);
        // 边框
        fillrectangle (boxm[i].posx1, boxm[i].posy1, boxm[i].posx2, boxm[i].posy2);
        // 文字
        outtextxy (boxm[i].posx1 + (boxm[i].posx2 - boxm[i].posx1) / 2 - textwidth (boxm[i].text) / 2, boxm[i].posy1 + 4, boxm[i].text);
    }

    // 设置参数
    setbkcolor (WHITE);
    settextcolor (BLACK);
    setlinecolor (BLACK);

    // 变量绘制
    j = 25;
    // 生命值
    i = 1;
    setbkcolor (color_text[boxm[i].mod]);
    _stprintf_s (s, _T ("%0.1d"), num_life);
    outtextxy (boxm[i].posx1 + (boxm[i].posx2 - boxm[i].posx1) / 2 - textwidth (boxm[i].text) / 2, boxm[i].posy1 + j, s);
    // 边长
    i = 2;
    setbkcolor (color_text[boxm[i].mod]);
    _stprintf_s (s, _T ("%0.1d"), num_size);
    outtextxy (boxm[i].posx1 + (boxm[i].posx2 - boxm[i].posx1) / 2 - textwidth (boxm[i].text) / 2, boxm[i].posy1 + j, s);
    // 总地雷数
    i = 3;
    setbkcolor (color_text[boxm[i].mod]);
    _stprintf_s (s, _T ("%0.1d"), num_mine);
    outtextxy (boxm[i].posx1 + (boxm[i].posx2 - boxm[i].posx1) / 2 - textwidth (boxm[i].text) / 2, boxm[i].posy1 + j, s);
    // 格子
    i = 4;
    setbkcolor (color_text[boxm[i].mod]);
    _stprintf_s (s, _T ("%0.1d"), num_box);
    outtextxy (boxm[i].posx1 + (boxm[i].posx2 - boxm[i].posx1) / 2 - textwidth (boxm[i].text) / 2, boxm[i].posy1 + j, s);
    // 标记数
    i = 5;
    setbkcolor (color_text[boxm[i].mod]);
    _stprintf_s (s, _T ("%0.1d"), num_flag);
    outtextxy (boxm[i].posx1 + (boxm[i].posx2 - boxm[i].posx1) / 2 - textwidth (boxm[i].text) / 2, boxm[i].posy1 + j, s);

    FlushBatchDraw ();
}

// 地雷生成函数
void Gary::create ()
{
    int i, j;
    // 设置雷
    for (i = 0; i < num_mine; i++)
    {
        // 随机
        j = rand () % 1000;
        while (box[j].mod_mine == 1 || box[j].mod_life == 1)
        {
            // 随机
            j = rand () % 1000;
        }
        // 是雷
        box[j].mod_mine = 1;
    }
    // 周边雷数统计
    // 遍历
    for (i = 0; i <= 888; i++)
    {
        if (box[i].mod_life == 0)
        {
            // 遍历
            for (j = 0; j <= 999; j++)
            {
                // 排除自己
                if (j != i && box[j].mod_life == 0)
                {
                    // 周围六个
                    if ((box[j].posx - box[i].posx) * (box[j].posx - box[i].posx) + (box[j].posy - box[i].posy) * (box[j].posy - box[i].posy) <= 900)
                    {
                        // 是雷
                        if (box[j].mod_mine == 1)
                        {
                            // 周边雷数参数加一
                            box[i].num_mine++;
                        }
                        // 不是雷
                        else if (box[j].mod_mine == 0)
                        {
                            // 周边安全数参数加一
                            box[i].num_peace++;
                        }
                    }
                }
            }
        }
    }
}

// 结束判断函数
void Gary::check_over ()
{
    int i, k;
    k = 0;
    for (i = 0; i <= 888; i++)
    {
        // 每有一个翻开且不是雷的点,则加一
        if (box[i].mod_mine == 0 && box[i].mod_life == 1)
        {
            k++;
        }
    }
    // 全翻开则结束
    if (k == num_box - num_mine)
    {
        // 将所有未翻开雷做上标记
        for (i = 0; i <= 888; i++)
        {
            if (box[i].mod_mine == 1 && box[i].mod_life == 0)
            {
                draw_flag (i);
            }
        }
        // 胜利标志:笑脸
        setfillcolor (WHITE);
        setlinecolor (WHITE);
        fillrectangle (50, 20, 75, 45);
        settextstyle (30, 0, _T ("Wingdings"));
        setbkmode (TRANSPARENT);
        settextcolor (BLACK);
        outtextxy (50, 20, 0x4A);
        setbkmode (OPAQUE);
        settextstyle (20, 0, _T ("Consolas"));
        // 结束变化
        exit_game = 1;
        boxm[1].mod = 0;
        boxm[2].mod = 0;
        boxm[3].mod = 0;
        boxm[6].mod = 0;
        boxm[7].mod = 1;
        num_flag = 0;
        // 绘制
        draw_scene ();
    }
}

// 格子绘制函数
void Gary::draw_box (int num_box)
{
    int i;
    int posx, posy;

    // 六边形绘制
    posx = box[num_box].posx;
    posy = box[num_box].posy;

    POINT pts[6];
    setlinestyle (PS_SOLID, 2);
    // 背景色
    setfillcolor (RGB (255, 255, 255));
    for (i = 0; i < 6; i++)
    {
        pts[i].x = long(posx + 14.0 * cos (60.0 * double (i) * pi / 180.0));
        pts[i].y = long(posy + 14.0 * sin (60.0 * double (i) * pi / 180.0));
    }
    solidpolygon (pts, 6);
    // 灰边
    setlinecolor (RGB (85, 85, 85));
    line (pts[0].x, pts[0].y, pts[1].x, pts[1].y);
    line (pts[5].x, pts[5].y, pts[0].x, pts[0].y);
    line (pts[1].x, pts[1].y, pts[2].x, pts[2].y);
    // 前景色
    setfillcolor (RGB (170, 170, 170));
    for (i = 0; i < 6; i++)
    {
        pts[i].x = long(posx + 12.0 * cos (60.0 * double (i) * pi / 180.0));
        pts[i].y = long(posy + 12.0 * sin (60.0 * double (i) * pi / 180.0));
    }
    solidpolygon (pts, 6);
    FlushBatchDraw ();
}

// 初始化函数
void Gary::initialization ()
{
    int i, j, k, t;
    // 随机初始化
    srand ((unsigned)time (NULL));
    // 颜色初始化
    color_text[0] = WHITE;
    color_text[1] = RGB (170, 170, 170);

    // 按钮的初始化
    num_button = 10;

    // 坐标
    for (i = 0; i < 10; i++)
    {
        boxm[i].posx1 = 410 + 120 * (i % 2);
        boxm[i].posy1 = 25 + 75 * (i / 2);
        boxm[i].posx2 = 520 + 120 * (i % 2);
        boxm[i].posy2 = 75 + 75 * (i / 2);
    }

    // 内容
    boxm[0].text = _T ("寻宝模式");    boxm[1].text = _T ("生命值");
    boxm[2].text = _T ("地图边长");    boxm[3].text = _T ("总地雷数");
    boxm[4].text = _T ("总地块数");    boxm[5].text = _T ("已标记数");
    boxm[6].text = _T ("开始");        boxm[7].text = _T ("重置");
    boxm[8].text = _T ("截图");        boxm[9].text = _T ("退出");

    // 状态
    boxm[0].mod = 1;
    boxm[1].mod = 1;
    boxm[2].mod = 1;
    boxm[3].mod = 1;
    boxm[4].mod = 1;
    boxm[5].mod = 1;
    boxm[6].mod = 1;
    boxm[7].mod = 0;
    boxm[8].mod = 0;
    boxm[9].mod = 0;

    num_box = 3 * num_size * (num_size - 1) + 1;
    num_flag = 0;

    // 绘制参数初始化
    setlinecolor (BLACK);
    setlinestyle (PS_SOLID, 1);
    settextstyle (20, 0, _T ("Consolas"));
    // 第一次绘制
    draw_scene ();

    // 重置
    setfillcolor (WHITE);
    fillrectangle (0, 0, 400, 400);

    // 平静脸
    setfillcolor (WHITE);
    setlinecolor (WHITE);
    fillrectangle (50, 20, 75, 45);
    settextstyle (30, 0, _T ("Wingdings"));
    setbkmode (TRANSPARENT);
    settextcolor (BLACK);
    outtextxy (50, 20, 0x4B);
    setbkmode (OPAQUE);
    settextstyle (20, 0, _T ("Consolas"));

    // 格子初始化
    for (t = 0; t <= 999; t++)
    {
        // 已翻开
        box[t].mod_life = 1;
        // 城墙
        box[t].mod_mine = 2;
        // 坐标,点不到
        box[t].posx = -200;
        box[t].posy = -200;
    }

    // 初始化
    for (i = 0; i < num_size; i++)
    {
        for (j = 0; j < num_size; j++)
        {
            for (k = 0; k < num_size; k++)
            {
                // 特征值至少一个为零
                if (i == 0 || j == 0 || k == 0)
                {
                    // 编号
                    t = i * 100 + j * 10 + k;
                    // 特征值
                    box[t].i = i;
                    box[t].j = j;
                    box[t].k = k;
                    // 未翻开
                    box[t].mod_life = 0;
                    // 不是雷
                    box[t].mod_mine = 0;
                    // 未标记
                    box[t].mod_flag = 0;
                    // 坐标
                    box[t].posx = 200 + 22 * (j - k);
                    box[t].posy = 200 - 25 * i + 13 * (j + k);
                    // 周围雷数初始化
                    box[t].num_mine = 0;
                    box[t].num_peace = 0;
                    // 绘制地块
                    draw_box (t);
                }
            }
        }
    }
    // 地雷生成函数
    create ();
}

// 窗口主视角函数,获取用户操作
void Gary::move ()
{
    // 鼠标定义
    ExMessage m;
    TCHAR ss[15];
    int i, t;
    exit_move = 0;
    exit_game = 0;
    while (exit_move == 0)
    {
        // 鼠标信息
        if (peekmessage (&m, EM_MOUSE | EM_KEY))
        {
            // 左键单击判断
            if (m.message == WM_LBUTTONDOWN)
            {
                // 判断是否点击了格子
                if (m.x > 0 && m.y > 0 && m.x < 400 && m.y < 400 && exit_game == 0)
                {
                    for (t = 0; t <= 888; t++)
                    {
                        // 成功点击未标记的空格子
                        if ((m.x - box[t].posx) * (m.x - box[t].posx) + (m.y - box[t].posy) * (m.y - box[t].posy) <= 144 && box[t].mod_life == 0 && box[t].mod_flag == 0)
                        {
                            // 点击的格子不是雷
                            if (box[t].mod_mine == 0)
                            {
                                // 绿色,安全,绘制
                                settextcolor (LIGHTGREEN);
                                draw_num (t, box[t].num_peace);
                                // 改为翻开
                                box[t].mod_life = 1;
                            }
                            // 点击的格子雷
                            else if (box[t].mod_mine == 1)
                            {
                                // 扣除生命值
                                num_life--;
                                // 黑色,危险,绘制
                                settextcolor (BLACK);
                                draw_num (t, box[t].num_mine);
                                // 改为翻开
                                box[t].mod_life = 1;
                                // 生命值减为零
                                if (num_life <= 0)
                                {
                                    // 失败标志:哭脸
                                    setfillcolor (WHITE);
                                    setlinecolor (WHITE);
                                    fillrectangle (50, 20, 75, 45);
                                    settextstyle (30, 0, _T ("Wingdings"));
                                    setbkmode (TRANSPARENT);
                                    settextcolor (BLACK);
                                    outtextxy (50, 20, 0x4C);
                                    setbkmode (OPAQUE);
                                    settextstyle (20, 0, _T ("Consolas"));
                                    // 失败
                                    exit_game = 1;
                                    boxm[1].mod = 0;
                                    boxm[2].mod = 0;
                                    boxm[3].mod = 0;
                                    boxm[6].mod = 0;
                                    boxm[7].mod = 1;
                                    num_flag = 0;
                                }
                                // 绘制
                                draw_scene ();
                            }
                            // 成功结束判断
                            check_over ();
                            break;
                        }
                    }
                }

                // 判断是否点击了可点击按钮
                for (i = 0; i < num_button; i++)
                {
                    if (m.x > boxm[i].posx1 && m.y > boxm[i].posy1 && m.x < boxm[i].posx2 && m.y < boxm[i].posy2 && boxm[i].mod == 0)
                    {
                        break;
                    }
                }

                // 点击矩形按钮
                switch (i)
                {
                // 生命值:num_life
                case 1:
                {
                    // 输入
                    InputBox (ss, 10, _T ("输入生命值(1 ~ 999)"));
                    _stscanf_s (ss, _T ("%d"), &i);
                    if (i > 0 && i <= 999)
                    {
                        num_life = i;
                    }
                    else { MessageBox (hOut, _T ("输入错误,不在范围内"), _T ("来自小豆子的提醒"), MB_OK); }
                    // 绘制
                    draw_scene ();
                    break;
                }
                // 地图边长:num_size
                case 2:
                {
                    // 输入
                    InputBox (ss, 10, _T ("输入边长(2 ~ 8)"));
                    _stscanf_s (ss, _T ("%d"), &i);
                    if (i > 1 && i <= 8)
                    {
                        num_size = i;
                        num_box = 3 * num_size * (num_size - 1) + 1;
                    }
                    else { MessageBox (hOut, _T ("输入错误,不在范围内"), _T ("来自小豆子的提醒"), MB_OK); }
                    // 绘制
                    draw_scene ();
                    break;
                }
                // 总地雷数:num_mine
                case 3:
                {
                    InputBox (ss, 10, _T ("输入地雷数(1 ~ 总格子数)"));
                    _stscanf_s (ss, _T ("%d"), &i);
                    if (i > 0 && i < num_box)
                    {
                        num_mine = i;
                    }
                    else { MessageBox (hOut, _T ("输入错误,不在范围内"), _T ("来自小豆子的提醒"), MB_OK); }
                    // 绘制
                    draw_scene ();
                    break;
                }
                // 开始
                case 6:
                {
                    num_box = 3 * num_size * (num_size - 1) + 1;
                    if (num_mine < num_box && num_life > 0)
                    {
                        exit_game = 0;
                        // 初始化
                        initialization ();
                    }
                    else
                    {
                        MessageBox (hOut, _T ("请将雷数修改为小于格子数或将生命值修改为大于零"), _T ("来自小豆子的提醒"), MB_OK);
                    }
                    break;
                }
                // 重置
                case 7:
                {
                    // 结束游戏进程,进入准备阶段
                    if (exit_game == 0)
                    {
                        exit_game = 1;
                        boxm[1].mod = 0;
                        boxm[2].mod = 0;
                        boxm[3].mod = 0;
                        boxm[6].mod = 0;
                        boxm[7].mod = 1;
                        num_flag = 0;
                        // 绘制
                        draw_scene ();
                    }
                    break;
                }
                // 截图
                case 8:
                {
                    saveimage (_T ("image.png"));
                    break;
                }
                // 退出
                case 9:
                {
                    exit_game = 1;
                    exit_move = 1;
                    exit_carry = 1;
                    break;
                }
                default:break;
                }
            }
            // 右键,且处于游戏进行状态
            else if (m.message == WM_RBUTTONDOWN && exit_game == 0)
            {
                for (t = 0; t <= 888; t++)
                {
                    // 成功点击空格子
                    if ((m.x - box[t].posx) * (m.x - box[t].posx) + (m.y - box[t].posy) * (m.y - box[t].posy) <= 144 && box[t].mod_life == 0)
                    {
                        // 标记状态转换
                        box[t].mod_flag = (box[t].mod_flag == 0 ? 1 : 0);
                        // 绘制
                        draw_box (t);
                        // 画小旗子
                        if (box[t].mod_flag == 1)
                        {
                            draw_flag (t);
                            num_flag++;
                        }
                        else
                        {
                            num_flag--;
                        }
                        // 绘制
                        draw_scene ();
                    }
                }
            }
        }
    }
}

// 主进程
void Gary::carry ()
{
    // 窗口定义
    hOut = initgraph (651, 401);
    SetWindowText (hOut, _T ("六边形扫雷:扫雷模式"));
    // 参数初始化
    num_size = 5;
    num_mine = 10;
    num_life = 3;
    // 背景绘制
    setbkcolor (WHITE);
    cleardevice ();
    // 进程控制
    exit_carry = 0;
    while (exit_carry == 0)
    {
        initialization ();
        move ();
    }
    closegraph ();
}

// 主函数
int main (void)
{
    Gary G;
    G.carry ();
    return 0;
}

大家赶紧去动手试试吧!

此外,我也给大家分享我收集的其他资源,从最零基础开始的教程到C语言C++项目案例,帮助大家在学习C语言的道路上披荆斩棘!

整理分享(多年学习的源码、项目实战视频、项目笔记,基础入门教程)最重要的是你可以在群里面交流提问编程问题哦!

欢迎转行和学习编程的伙伴,利用更多的资料学习成长比自己琢磨更快哦!

【C语言】五小时快速入门C语言:https://nxv.xet.tech/s/1tvM22

【C语言】零基础到项目实战(交换机项目):https://nxv.xet.tech/s/2mF2w6

【C++】实战入门:智能婚恋交友系统:https://nxv.xet.tech/s/1eP6Qq

【C/C++】指针精讲:https://nxv.xet.tech/s/3w6L3x

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

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

相关文章

亚马逊云科技 2022 re:Invent 观察 | 天下武功,唯快不破

引子“天下武功&#xff0c;无坚不摧&#xff0c;唯快不破”&#xff0c;相信大家对星爷电影《功夫》中的这句话耳熟能详。实际上&#xff0c;“天下武功&#xff0c;唯快不破”最早出自古龙先生的著名武侠小说《小李飞刀》&#xff1a;“小李飞刀&#xff0c;例无虚发&#xf…

LeetCode(String) 2325. Decode the Message

1.问题 You are given the strings key and message, which represent a cipher key and a secret message, respectively. The steps to decode message are as follows: Use the first appearance of all 26 lowercase English letters in key as the order of the substit…

React生命周期详解

React 类组件生命周期 React 有两个重要阶段 render 阶段和 commit 阶段&#xff0c;React 在调和( render )阶段会深度遍历 React fiber 树&#xff0c;目的就是发现不同( diff )&#xff0c;不同的地方就是接下来需要更新的地方&#xff0c;对于变化的组件&#xff0c;就会执…

Linux杂谈之java命令

一 java &#xff08;1&#xff09;基本解读 ① JAVA8 官方命令行参数 linux版的java 重点关注&#xff1a; java、javac、jar、keytool 这三个参数学习方式&#xff1a; 通过man java和官方文档快速学习 如何在官网搜索 java的命令行参数用法 ② 语法格式 ③ 描述 1)…

Java开发为何深入人心 ?我来带你解开 Spring、IoC、DI 的秘密~

目录 一、什么是Spring? 1.1、什么是容器&#xff1f; 1.2、IoC是什么&#xff1f; 1.3、IoC带来了什么好处&#xff1f; 二、什么是DI&#xff1f; 2.1、IoC和DI有什么关系&#xff1f; 一、什么是Spring? 一句概括&#xff0c;Spring 是包含了众多⼯具⽅法的 IoC 容器…

RHCE第七天之防火墙详解

文章目录一、 基本概念二、iptables三、firewalld四、实验练习一、 基本概念 什么是防火墙&#xff1f;路由策略和策略路由/ipsec vpn gre hdlc ppp 硬件 iDS 在计算中&#xff0c;防火墙是基于预定安全规则来监视和控制传入和传出网络流量的网络安全系统。该计算机流入流出的…

React基础梳理,万字总结,总能帮到你~

第1章&#xff1a;React入门 1.1.React简介 1.英文官网: reactjs.org/2.中文官网: react.docschina.org/3.用于动态构建用户界面的 JavaScript 库(只关注于视图)4.Facebook开源 React的特点 1.声明式编码2.组件化编码3.React Native 编写原生应用4.高效&#xff08;优秀的D…

CodeCraft-22 and Codeforces Round #795 (Div. 2)

A. Beat The Odds 题目链接&#xff1a; Problem - A - Codeforces 样例输入&#xff1a; 2 5 2 4 3 6 8 6 3 5 9 7 1 3样例输出&#xff1a; 1 0题意&#xff1a;给定一个长度为n的数组&#xff0c;我们可以对这个数组进行操作&#xff0c;每次操作可以删除一个数&#xff…

计算机防勒索病毒之系统主机加固篇

​ 近年来&#xff0c;计算机以及互联网应用在中国得到普及和发展&#xff0c;已经深入到社会每个角落&#xff0c;政府&#xff0c;经济&#xff0c;军事&#xff0c;社会&#xff0c;文化和人们生活等各方面都越来越依赖于计算机和网络&#xff0c;电子政务&#xff0c;无纸办…

如何把WPS转换成PDF格式?新手也能轻松学会的方法

WPS文件是我们工作中必不可少的&#xff0c;它可以编辑文本、记录数据、展示文档等等&#xff0c;都能更好的帮我们处理工作&#xff0c;不过有的时候WPS文件在不同设备上打开可能会出现格式错误或者乱码等一系列的问题&#xff0c;这时候我们就可以将WPS文件转换成PDF文件&…

[Leetcode] 传递信息(有向图路径)

小朋友 A 在和 ta 的小伙伴们玩传信息游戏&#xff0c;游戏规则如下&#xff1a;有 n 名玩家&#xff0c;所有玩家编号分别为 0 &#xff5e; n-1&#xff0c;其中小朋友 A 的编号为 0每个玩家都有固定的若干个可传信息的其他玩家&#xff08;也可能没有&#xff09;。传信息的…

Python数据分析之Pandas

文章目录前言一、输入输出1.1 txt1.2 csv1.3 excel1.4 json1.5 sql1.6 html1.7 latex二、数据结构2.1 一维数据 Series2.2 二维数据 DataFrame2.2.1 数据查看2.2.2 数据遍历2.2.3 数据选取2.2.4 数据处理2.2.5 数据统计2.3 索引对象 Index2.4 时间戳 TimeStamp三、窗口函数3.1 …

【每日一题】【LeetCode】【第十天】只出现一次的数字

解决之路 题目描述 测试案例&#xff08;部分&#xff09; 第一次 和昨天的题目有点类似&#xff0c;昨天是找重复&#xff0c;今天是找不重复。那直接按昨天第二次思路来写这次的代码。 class Solution(object):def singleNumber(self, nums):nums.sort()for i in range(l…

在线计算lncRNA-mRNA共表达相关系数,并使用cytoscape绘制共表达网络图

长链非编码RNA(Long noncoding RNA)是一类长度大于200 nt&#xff0c;不编码蛋白质的RNA。LncRNA的功能多样&#xff0c;如图1所示&#xff0c;A&#xff1a;充当蛋白质和染色质的连接因子&#xff0c;引起染色质重构&#xff08;chromatin remodeling&#xff09;&#xff1b;…

内存函数细节及实现

1、memcpy内存拷贝 不仅可以拷贝&#xff0c;还可以拷贝整型、结构体等&#xff0c;因为直接拷贝了内存。 因为不知道要拷贝的类型是什么&#xff0c;所以都用void*来接收。num是拷贝的字节数 拷贝时可任意选择dest&#xff0c;src&#xff0c;以及字节数。返回void*类型的指…

01什么是FPGA?

FPGA 是一种硬件可重构的体系结构。它的英文全称是Field Programmable Gate Array&#xff0c;中文名是现场可编程门阵列。 FPGA就是一个可以通过编程来改变内部结构的芯片&#xff0c;FPGA常年来被用作专用芯片&#xff08;ASIC&#xff09;的小批量替代品&#xff0c; 同时也…

PMP考试流程是怎么样的?

别的问题我可能不太了解&#xff0c;但考试流程我绝对是非常清楚了&#xff01;话不多说&#xff0c;直接放流程给到大家&#xff0c;好歹通过考试了&#xff0c;基本的情况还是能给大家讲解一下的。希望能够给有需要的同学提供点帮助。 先把考试的流程看仔细了&#xff0c;之…

核心乐理---音程名称

定义 音程是连个音之间的距离&#xff0c;是音乐中的距离&#xff0c;可以便于我们描述音符间的距离&#xff0c;便于与他人进行沟通交流。 就好像是厘米&#xff0c;米这些这些物理中的长度单位一样 度 度是音程的单位。 从一个音的名字念到另一个音的名字&#xff0c;一共念…

瑞幸“复制”拼多多

&#xff08;图片来源于网络&#xff0c;侵删&#xff09; 来源 | 螳螂观察 文 | 叶小安 在电商界&#xff0c;拼多多杀出阿里京东围剿重围&#xff0c;奠定现今电商行业“猫狗拼”三分天下的格局&#xff0c;这是多少后辈们参考的范本。 在咖啡界&#xff0c;瑞幸凭借低价…

ESP32基于Arduino框架,SD卡+MAX98357模块+MP3播放器

ESP32基于Arduino框架&#xff0c;SD卡MAX98357模块MP3播放器&#x1f3ac;原创作者的制作教程讲解以及源码&#xff1a; 35 ESP32之简单的完整功能SD卡MP3播放器的制作讲解&#xff08;ESP32-audioI2S库介绍&#xff09;- 基于Arduino链接&#xff1a;https://pan.baidu.com/s…