数据结构(1~10)

news2025/1/11 1:35:26

(1)双栈

#include <iostream>
#include <algorithm>
using namespace std;
// 定义栈元素的类型
typedef int SElemType;

// 定义双栈数据结构
typedef struct {
    int top[2];
    int bot[2];
    SElemType *V;
    int m;
} DblStack;

// 初始化双栈
void InitDblStack(DblStack *S, int maxSize) {
    S->m = maxSize;
    S->V = new SElemType[maxSize]; // 使用 new 替代 malloc
    S->bot[0] = -1;
    S->top[0] = -1; // 0号栈为空
    S->bot[1] = maxSize;
    S->top[1] = maxSize; // 1号栈为空
}

// 判断0号栈是否为空
bool StackEmpty0(DblStack *S) {
    return S->top[0] == -1;
}

// 判断1号栈是否为空
bool StackEmpty1(DblStack *S) {
    return S->top[1] == S->m;
}

// 判断双栈是否已满
bool StackFull(DblStack *S) {
    return S->top[0] + 1 == S->top[1];
}

// 0号栈进栈操作
bool Push0(DblStack *S, SElemType e) {
    if (StackFull(S)) {
        std::cout << "栈溢出!" <<endl;
        return false;
    }
    S->V[++(S->top[0])] = e;
    return true;
}

// 1号栈进栈操作
bool Push1(DblStack *S, SElemType e) {
    if (StackFull(S)) {
        cout << "栈溢出!" << endl;
        return false;
    }
    S->V[--(S->top[1])] = e;
    return true;
}

// 0号栈出栈操作
bool Pop0(DblStack *S, SElemType *e) {
    if (StackEmpty0(S)) {
        cout << "栈下溢!" << endl;
        return false;
    }
    *e = S->V[(S->top[0])--];
    return true;
}

// 1号栈出栈操作
bool Pop1(DblStack *S, SElemType *e) {
    if (StackEmpty1(S)) {
       cout << "栈下溢!" << endl;
        return false;
    }
    *e = S->V[(S->top[1])--];
    return true;
}

// 打印栈数组
void PrintStack(DblStack *S) {
    cout << "栈数组: ";
    for (int i = 0; i < S->m; i++) {
        std::cout << S->V[i] << " ";
    }
    cout << "\n栈顶索引: 0: " << S->top[0] << ", 1: " << S->top[1] << endl;
}

int main() {
    DblStack S;
    int maxSize = 10;
    InitDblStack(&S, maxSize);

    // 测试0号栈
    Push0(&S, 1);
    Push0(&S, 2);
    Push0(&S, 3);
    int e;
    Pop0(&S, &e);
    cout << "从0号栈弹出: " << e << endl;

    // 测试1号栈
    Push1(&S, 7);
    Push1(&S, 8);
    Push1(&S, 9);
    Pop1(&S, &e);
    cout << "从1号栈弹出: " << e << endl;

    // 打印栈数组
    PrintStack(&S);

    // 释放内存
    delete[] S.V; 

    return 0;
}

(2)回文数

#include <iostream>
#include<string> 
#include<algorithm>
using namespace std;
int main() 
{
	string s;
	cin >> s;
	string oris = s;
	reverse(s.begin(),s.end());
	if(oris == s)
	cout <<"YES"<< endl;
	else
	cout << "NO" << endl; 
    return 0;
}

(3)设从键盘输入一整数的序列:a1,a2,a3,...,an,用栈结构存储输入的整数,当ai不等于-1时,将ai进栈;当ai=-1时,输出栈顶整数并出栈

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>

const int  MAX_SIZE = 100 ;

typedef struct {
    int data[MAX_SIZE]; // 存储栈中元素的数组
    int top; // 栈顶位置
} Stack;

// 初始化栈
void initStack(Stack *s) {
    s->top = -1; // 栈顶位置初始化为-1,表示栈为空
}

// 判断栈是否为空
bool isEmpty(Stack *s) {
    return s->top == -1;
}

// 判断栈是否满
bool isFull(Stack *s) {
    return s->top == MAX_SIZE - 1;
}

// 压栈操作
bool push(Stack *s, int value) {
    if (isFull(s)) {
        printf("栈满,无法压栈!\n");
        return false;
    }
    s->data[++(s->top)] = value; // 先增加栈顶位置,再赋值
    return true;
}

// 弹栈操作
bool pop(Stack *s, int *value) {
    if (isEmpty(s)) {
        printf("栈空,无法弹栈!\n");
        return false;
    }
    *value = s->data[(s->top)--]; 
    return true;
}

// 获取栈顶元素
bool top(Stack *s, int *value) {
    if (isEmpty(s)) {
        printf("栈空,无法获取栈顶元素!\n");
        return false;
    }
    *value = s->data[s->top];
    return true;
}

int main() {
    Stack s;
    initStack(&s);
    int input;

    printf("请输入一整数的序列,以-1表示输出栈顶并出栈:\n");

    while (scanf("%d", &input) != EOF) {
        if (input != -1) {
            if (!push(&s, input)) {

               break; 
            }
        } else {
            int value;
            if (top(&s, &value) && pop(&s, &value)) {
                printf("栈顶整数:%d\n", value);
            }
        }
    }
    return 0;
}

(4)从键盘上输入一个后缀表达式,规定:后缀表达式长度不超过一行,以’$'结束操作数之间用空格分割。且操作符只有 + - * / 四种。
后缀表达式:234 34 + 2 *$

#include <iostream>
#include <stack>
#include <sstream>
#include <string>
#include <cctype>

using namespace std;

// 函数:判断一个字符串是否是有效的操作符
bool isOperator(const string& token) {
    return token == "+" || token == "-" || token == "*" || token == "/";
}

// 函数:将字符串转换为整数
int stringToInt(const string& str) {
    return stoi(str);
}

// 函数:计算两个操作数的结果,根据给定的操作符
int applyOperator(const string& op, int a, int b) {
    if (op == "+") return a + b;
    if (op == "-") return a - b;
    if (op == "*") return a * b;
    if (op == "/") {
        if (b == 0) {
            cerr << "Error: Division by zero!" << endl;
            exit(EXIT_FAILURE); // 处理除以零的错误情况
        }
        return a / b;
    }
    return 0; 
}

int main() {
    stack<int> values; // 用于存储操作数的栈
    string line;
    getline(cin, line, '$'); // 从键盘读取一行输入,直到遇到'$'字符

    istringstream iss(line); // 使用输入字符串流来解析输入
    string token;
    while (iss >> token) 
	{ 
        if (isOperator(token))
		 { // 如果token是操作符
            int b = values.top(); values.pop(); 
            int a = values.top(); values.pop(); 
            int result = applyOperator(token, a, b); // 计算结果
            values.push(result); // 将结果压入栈中
        }
		 else 
		{ 
            values.push(stringToInt(token)); // 将操作数转换为整数并压入栈中
        }
    }

    // 栈中应该只剩下一个元素,即表达式的最终结果
    if (!values.empty()) {
        cout << "计算结果: " << values.top() << endl;
    } else {
        cerr << "错误:后缀表达式计算结果导致了一个空堆栈! " << endl;
    }

    return 0;
}

(5)假设以I和O分别表示入栈和出栈操作。

#include <iostream>
#include <string>

using namespace std;

//检查给定的IO序列是否为合法序列
bool isValidSequence(const string& sequence) 
{
    int balance = 0; // 用于跟踪栈的平衡状态
    for (char ch : sequence) 
	{
        if (ch == 'I')
		 {
            balance++; // 入栈操作,增加平衡计数
        }
		 else if (ch == 'O') 
		 {
            if (balance == 0) 
			{
                // 出栈操作,但栈为空,因此序列非法
                return false;
            }
            balance--; // 出栈操作,减少平衡计数
        } 
		else 
		{
            // 序列中包含非法字符
            return false;
        }
    }
    return balance == 0;
}

int main() {
    string sequence;
    cout << "请输入一个由I和O组成的序列:";
    cin >> sequence;

    if (isValidSequence(sequence)) {
        cout << "序列是合法的。" << endl;
    } else {
        cout << "序列是非法的。" << endl;
    }

    return 0;
}

(6)假设以带头结点的循环链表表示队列

#include <stdio.h>
#include <stdlib.h>

// 定义链表结点结构
typedef struct Node {
    int data;
    struct Node* next;
} Node;

// 定义队列结构,包含一个指向队尾元素的指针
typedef struct {
    Node* tail; 
} CircularQueue;

// 初始化队列
void initQueue(CircularQueue* q) 
{
    // 创建一个头结点,它同时也是尾结点的前驱
    q->tail = (Node*)malloc(sizeof(Node));
    if (q->tail == NULL) {
        printf("内存分配失败 ");
        exit(1);
    }
    q->tail->data = 0; 
    q->tail->next = q->tail; 
}

// 入队列操作
void enqueue(CircularQueue* q, int value) 
{
    Node* newNode = (Node*)malloc(sizeof(Node));
    if (newNode == NULL) {
        printf("内存分配失败 ");
        exit(1);
    }
    newNode->data = value;
    newNode->next = q->tail->next;
    q->tail->next = newNode;
    q->tail = newNode; 
}

// 出队列操作,返回队首元素的值,并移除该元素
int dequeue(CircularQueue* q) 
{
    if (q->tail->next == q->tail) 
	{
        printf("栈是空的");
        exit(1); 
    }
    Node* temp = q->tail->next;
    int value = temp->data; 
    q->tail->next = temp->next; 

    free(temp); // 释放队首元素的内存
    return value;
}

// 打印队列中的所有元素(用于调试)
void printQueue(CircularQueue* q) {
    if (q->tail->next == q->tail) {
        printf("Queue is empty\n");
        return;
    }
    Node* current = q->tail->next;
    while (current != q->tail) {
        printf("%d ", current->data);
        current = current->next;
    }
    printf("\n");
}

// 主函数用于测试队列操作
int main() {
    CircularQueue q;
    initQueue(&q);
    
    enqueue(&q, 1);
    enqueue(&q, 2);
    enqueue(&q, 3);
    
    printQueue(&q); // 输出: 1 2 3
    
    printf("队列: %d\n", dequeue(&q)); 
    
    printQueue(&q); // 输出: 2 3
    
    return 0;
}

(7)假设以数组q[m]存放

#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>

#define M 5 // 队列的最大容量

typedef struct {
    int Q[M]; // 队列元素数组
    int front; // 队头指针
    int rear; // 队尾指针
    int tag; // 队列状态标志,0表示空,1表示满,-1表示初始状态(可选,用于更明确的初始化检查)
} CircularQueue;

// 初始化队列
void initQueue(CircularQueue* q) {
    q->front = 0;
    q->rear = 0;
    q->tag = -1; 
}

// 判断队列是否为空
bool isEmpty(CircularQueue* q) {
    return q->tag == 0 && q->front == q->rear;
}

// 判断队列是否已满
bool isFull(CircularQueue* q) {
    return q->tag == 1 || ((q->rear + 1) % M == q->front);
}

// 入队列操作
bool enqueue(CircularQueue* q, int value) {
    if (isFull(q)) {
        printf("队列已满,无法入队\n");
        return false;
    }
    if (q->tag == -1) {
        q->tag = 0; // 如果队列处于初始状态,则将其设置为空状态
    }
    q->Q[q->rear] = value;
    q->rear = (q->rear + 1) % M;
    if (q->rear == q->front) { 
        if (!isEmpty(q)) { 
            q->tag = 1;
        }
    }
    return true;
}

// 出队列操作
bool dequeue(CircularQueue* q, int* value) {
    if (isEmpty(q)) {
        printf("队列为空,无法出队\n");
        return false;
    }
    *value = q->Q[q->front];
    q->front = (q->front + 1) % M;
    if (q->front == q->rear) { // 出队后front追上了rear,队列变为空
        q->tag = 0;
    } else {
        q->tag = -1;
    }

    return true;
}

int main() {
    CircularQueue q;
    initQueue(&q);

    // 测试入队列操作
    enqueue(&q, 1);
    enqueue(&q, 2);
    enqueue(&q, 3);
    enqueue(&q, 4);
    enqueue(&q, 5); // 此时队列应已满

    // 测试出队列操作
    int value;
    dequeue(&q, &value);
    printf("出队元素: %d\n", value);
    dequeue(&q, &value);
    printf("出队元素: %d\n", value);

    // 再次测试入队列操作,检查队列是否能正确循环
    enqueue(&q, 6);
    printf("入队元素: 6\n");

    // 检查队列状态
    if (isEmpty(&q)) {
        printf("队列为空\n");
    } else if (isFull(&q)) {
        printf("队列已满\n");
    } else {
        printf("队列既不满也不空\n");
    }


    return 0;
}

(8)如果允许在循环队列的

#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>

#define M 5 // 队列的最大容量

typedef struct {
    int Q[M]; // 队列元素数组
    int front; // 队头指针
    int rear; // 队尾指针(指向下一个空闲位置)
    int size; // 队列中当前元素的个数
} CircularQueue;

// 初始化队列
void initQueue(CircularQueue* q) {
    q->front = 0;
    q->rear = 0;
    q->size = 0;
}

// 判断队列是否为空
bool isEmpty(CircularQueue* q) {
    return q->size == 0;
}

// 判断队列是否已满
bool isFull(CircularQueue* q) {
    return q->size == M;
}

// 从队头插入元素
bool enqueueFront(CircularQueue* q, int value) {
    if (isFull(q)) {
        printf("队列已满,无法从队头插入\n");
        return false;
    }
    int newFront = (q->front - 1 + M) % M; // 计算新的队头位置(考虑循环)
    if (newFront == q->rear) {

        printf("内部错误:插入位置冲突\n");
        return false;
    }
    q->Q[newFront] = value;
    q->front = newFront;
    q->size++;
    return true;
}

// 从队尾删除元素
bool dequeueRear(CircularQueue* q, int* value) {
    if (isEmpty(q)) {
        printf("队列为空,无法从队尾删除\n");
        return false;
    }
    *value = q->Q[q->rear - 1]; 
    q->rear = (q->rear - 1 + M) % M; // 更新队尾指针(考虑循环)
    q->size--;
    if (q->size == 0) {
        q->front = 0;
        q->rear = 0;
    }
    return true;
}

// 打印队列元素(用于调试)
void printQueue(CircularQueue* q) {
    if (isEmpty(q)) {
        printf("队列为空\n");
        return;
    }
    printf("队列元素: ");
    int i = q->front;
    for (int count = 0; count < q->size; count++) {
        printf("%d ", q->Q[i]);
        i = (i + 1) % M;
    }
    printf("\n");
}

int main() {
    CircularQueue q;
    initQueue(&q);

    // 测试从队头插入
    enqueueFront(&q, 10);
    enqueueFront(&q, 20);
    enqueueFront(&q, 30);
    printQueue(&q); // 应打印: 队列元素: 30 20 10

    // 测试从队尾删除
    int value;
    dequeueRear(&q, &value);
    printf("从队尾删除的元素: %d\n", value); 
    printQueue(&q);

    return 0;
}

(10)已知f为单链表的

#include <iostream>
#include <climits> 

// 定义链表节点结构
struct Node {
    int data;
    Node* next;
    
    // 构造函数
    Node(int val) : data(val), next(nullptr) {}
};

// (1)求链表中的最大整数
int findMaxRecursive(Node* head) {

    if (head == nullptr) {
        std::cerr << "Error: head is nullptr" << std::endl;
        exit(EXIT_FAILURE); 
    }
    // 只有一个元素时,直接返回该元素
    if (head->next == nullptr) {
        return head->data;
    }
    // 递归情况:比较当前元素和剩余链表中的最大值
    int maxInRest = findMaxRecursive(head->next);
    return (head->data > maxInRest) ? head->data : maxInRest;
}

// (2)求链表的节点个数
int countNodesRecursive(Node* head) {
    // 基本情况:链表为空时,节点个数为0
    if (head == nullptr) {
        return 0;
    }
    // 递归情况:当前节点加上剩余链表的节点个数
    return 1 + countNodesRecursive(head->next);
}

// (3)求链表中所有元素的平均值(使用辅助函数)
double findAverageHelper(Node* head, int& totalSum, int& totalCount) {

    if (head == nullptr) {
        return 0;
    }

    totalSum += head->data;
    totalCount++;

    return findAverageHelper(head->next, totalSum, totalCount);
}

double findAverageRecursive(Node* head) {
    int totalSum = 0;
    int totalCount = 0;
    // 调用辅助函数进行递归计算
    findAverageHelper(head, totalSum, totalCount);
    // 返回平均值
    return (totalCount > 0) ? static_cast<double>(totalSum) / totalCount : 0.0;
}

int main() {
    // 创建链表:1 -> 3 -> 2 -> 5 -> 4
    Node* first = new Node(1);
    first->next = new Node(3);
    first->next->next = new Node(2);
    first->next->next->next = new Node(5);
    first->next->next->next->next = new Node(4);

    // 测试函数
    std::cout << "最大整数: " << findMaxRecursive(first) << std::endl; // 应输出5
    std::cout << "节点个数: " << countNodesRecursive(first) << std::endl; // 应输出5
    std::cout << "所有整数的平均值: " << findAverageRecursive(first) << std::endl; // 应输出3.0

    return 0;
}

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

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

相关文章

SpringBoot-Web入门-入门程序

1.如何创建一个springBoot-Web工程&#xff1f; 实战演示&#xff1a; 新建一个模块&#xff0c;找到Spring Boot选项 点击下一步之后&#xff0c;选择勾选对应的依赖。我这里勾选的是web下的Spring Web 创建完毕之后&#xff0c;在src的main下的java对应的包下创建一个Contro…

从光子到图像——相机如何捕获世界?

引言 你是否想过为何我们按一下相机快门就可以将眼前广袤多彩的世界显示于一个小小的相机屏幕上&#xff1f;本期推文中将带着大家重现从光子转换为电子、电子转换为图像中数字驱动值的整个流程。 ▲人们通过相机捕获眼前的场景 从光子到电子的转换 光线首先通过光学镜头进入相…

《机器学习》——贝叶斯算法

贝叶斯简介 贝叶斯公式&#xff0c;又称贝叶斯定理、贝叶斯法则&#xff0c;最初是用来描述两个事件的条件概率间的关系的公式&#xff0c;后来被人们发现具有很深刻的实际意义和应用价值。该公式的实际内涵是&#xff0c;支持某项属性的事件发生得愈多&#xff0c;则该属性成…

【非常详细】TCP/IP协议详解

一、TCP/IP简介 TCP/IP&#xff08;传输控制协议/互联网协议&#xff09;是一种用于连接网络设备的协议族&#xff0c;广泛应用于互联网和局域网中。它提供了在不同类型的网络上进行通信的标准和方法。 二、TCP/IP模型 TCP/IP在数据包设计上采用封装和分用的策略&#xff0c;…

Nginx代理同域名前后端分离项目的完整步骤

前后端分离项目&#xff0c;前后端共用一个域名。通过域名后的 url 前缀来区别前后端项目。 以 vue php 项目为例。直接上 server 模块的 nginx 配置。 server{ listen 80; #listen [::]:80 default_server ipv6onlyon; server_name demo.com;#二配置项目域名 index index.ht…

C++中的表达式

文章目录 算数操作符位操作符bitset对象或整型值的使用将位移操作符用作IO 赋值操作符赋值操作符的右结合性赋值操作具有低优先级 自增和自减操作符条件操作符sizeof操作符优先级new和delete表达式类型转换何时发生隐式转换显示转换旧式强制类型转换 C中的表达式由一个或多个操…

WebSocket 测试入门篇

Websocket 是一种用于 H5 浏览器的实时通讯协议&#xff0c;可以做到数据的实时推送&#xff0c;可适用于广泛的工作环境&#xff0c;例如客服系统、物联网数据传输系统&#xff0c; 基础介绍 我们平常接触最多的是 http 协议的接口&#xff0c;http 协议是请求与响应的模式&…

海外招聘丨 弗拉瑞克商学院—博士研究员:智能家居技术业务和能源管理中的数据分析和人工智能

雇主简介 Vlerick 是一所领先的国际商学院……与众不同。是的&#xff0c;我们提供完全认可的世界一流教育课程&#xff0c;将理论知识和实践见解完美结合。是的&#xff0c;我们是一家领先的学术机构&#xff0c;拥有创新和独立研究的悠久传统。是的&#xff0c;我们拥有国际…

NUTTX移植到STM32

STM32移植NUTTX 1. Ubuntu下搭建开发环境1.1 先决条件1.2 下载 NuttX1.3 使用Make 进行编译1.4 烧录运行 2.通过NUTTX点亮LED2.1 部署操作系统2.2 修改配置文件2.3 编译运行程序 开发板&#xff1a;DshanMCUF407 官方开发文档&#xff1a;安装 — NuttX latest 文档 参考文档&…

Redis 优化秒杀(异步秒杀)

目录 为什么需要异步秒杀 异步优化的核心逻辑是什么&#xff1f; 阻塞队列的特点是什么&#xff1f; Lua脚本在这里的作用是什么&#xff1f; 异步调用创建订单的具体逻辑是什么&#xff1f; 为什么要用代理对象proxy调用createVoucherOrder方法&#xff1f; 对于代码的详细…

Python 中的错误处理与调试技巧

&#x1f496; 欢迎来到我的博客&#xff01; 非常高兴能在这里与您相遇。在这里&#xff0c;您不仅能获得有趣的技术分享&#xff0c;还能感受到轻松愉快的氛围。无论您是编程新手&#xff0c;还是资深开发者&#xff0c;都能在这里找到属于您的知识宝藏&#xff0c;学习和成长…

关于腾讯4K算法搭建使用

准备国内服务器一台&#xff0c;轻量服务器请尽量开全端口安装linux,centos7.6-7.9系统&#xff0c;记住纯净系统&#xff0c;然后安装宝塔宝塔安装环境为nginx1.24,7.2(PHP版本没有要求)&#xff0c;Mysql5.7(没有要求) 准备活动完毕&#xff01;&#xff01;&#xff01; 上传…

工艺参数优化、工程设计优化!GRNN神经网络+NSGAII多目标优化算法(Matlab)

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.GRNN神经网络NSGAII多目标优化算法&#xff0c;工艺参数优化、工程设计优化&#xff08;Matlab完整源码和数据&#xff09; 多目标优化是指在优化问题中同时考虑多个目标的优化过程。在多目标优化中&#xff0c;通…

【Rust自学】11.6. 控制测试运行:并行和串行(连续执行)测试

喜欢的话别忘了点赞、收藏加关注哦&#xff08;加关注即可阅读全文&#xff09;&#xff0c;对接下来的教程有兴趣的可以关注专栏。谢谢喵&#xff01;(&#xff65;ω&#xff65;) 11.6.1. 控制测试的运行方式 cargo test和cargo run一样&#xff0c;cargo test也会编译代…

nginx负载均衡-基于端口的负载均衡(一)

注意&#xff1a; (1) 做负载均衡技术至少需要三台服务器&#xff1a;一台独立的负载均衡器&#xff0c;两台web服务器做集群 一、nginx分别代理后端web1 和 web2的三台虚拟主机 1、web1&#xff08;nginx-10.0.0.7&#xff09;配置基于端口的虚拟主机 [rootOldboy extra]# …

DDcGAN_多分辨率图像融合的双鉴别条件生成对抗网络_y译文马佳义

摘要&#xff1a; 在本文中&#xff0c;我们提出了一种新的端到端模型&#xff0c;称为双鉴别条件生成对抗网络&#xff08;DDcGAN&#xff09;&#xff0c;用于融合不同分辨率的红外和可见光图像。我们的方法建立了一个生成器和两个鉴别器之间的对抗博弈。生成器的目的是基于特…

【C++/控制台】2048小游戏

源代码&#xff1a; #include <iostream> #include <windows.h> #include <stdio.h> #include <math.h> #include <stdlib.h> #include <conio.h> #include <time.h>// #define KEY_DOWN(VK_NONAME) ((GetAsyncKeyState(VK_NONAME)…

【Rust自学】11.5. 在测试中使用Result<T, E>

喜欢的话别忘了点赞、收藏加关注哦&#xff08;加关注即可阅读全文&#xff09;&#xff0c;对接下来的教程有兴趣的可以关注专栏。谢谢喵&#xff01;(&#xff65;ω&#xff65;) 11.5.1. 测试函数返回值为Result枚举 到目前为止&#xff0c;测试运行失败的原因都是因为触…

最新版IDEA新建web项目--小白也能看懂

引言&#xff1a; 此方法适用于 IntelliJ IDEA 2024.1.4 最新版本。 我最初使用的是 Tomcat 8.0.23 版本&#xff0c;搭配 JDK 17。由于 Tomcat 8.0.23 使用了已经被弃用的 JVM 参数&#xff0c;故将 Tomcat 版本更换为 10.1.1。 如果你使用 JDK 17&#xff0c;建议使用 Tom…

ue5玩家角色添加武器。切换武器位置,手上武器放到背上。演示一下人体插槽和武器的连接。仅仅演示,实际项目不是这么用的

把第一人称资源包导进来 这就是我们枪的骨骼网格体 我们找到这个骨骼 右手添加插槽 取个名字 因为武器上也有动画&#xff0c;所有武器单独写个蓝图类 新建一个蓝图类 BP_Weapon 把枪的蓝图拖到人的静态网格体下&#xff0c;成为一个部分 选中BP_Weapon的父类套接字…