CSP-202309-2 坐标变换(其二)(模拟,c++,vector建二叉树)

计算机软件能力认证考试系统

问题描述

试题编号:202309-3
试题名称:梯度求解
时间限制:1.0s
内存限制:512.0MB
问题描述:

背景
西西艾弗岛运营公司近期在大力推广智能化市政管理系统。这套系统是由西西艾弗岛信息中心研发的。它的主要目的是,通过详细评估岛上各处的市政设施的状况,来指导市政设施的维护和更新。这套系统的核心是一套智能化的传感器网络,它能够自动地对岛上的市政设施进行评估。对市政设施的维护是需要一定成本的,而年久失修的市政设施也可能给岛上的居民造成损失。为了能够平衡成本和收益,信息中心研发了一款数学模型,描述这些变量和损益之间的复杂数学关系。要想得到最优化的成本,就要依靠梯度下降算法来求解。

梯度下降算法中,求解函数在一点处对某一自变量的偏导数是十分重要的。小 C 负责实现这个功能,但是具体的技术实现,他还是一头雾水,希望你来帮助他完成这个任务。

问题描述
设被求算的函数 u=f(x1,x2,…,xn),本题目要求你求出 u 对 xi 在 (a1,a2,…,an) 处的偏导数 ∂u∂xi(a1,a2,…,an)。

求算多元函数在一点处对某一自变量的偏导数的方法是:将函数的该自变量视为单一自变量,其余自变量认为是常数,运用一元函数求导的方法求出该偏导数表达式,再代入被求算的点的坐标即可。

例如,要求算 u=x1⋅x1⋅x2 对 x1 在 (1,2) 处的偏导数,可以将 x2 视为常数,依次应用求导公式。先应用乘法的求导公式:(x1⋅(x1⋅x2))′=x1′(x1⋅x2)+x1(x1⋅x2)′;再应用常数与变量相乘的求导公式,得到 x1′⋅x1⋅x2+x1⋅x2⋅x1′;最后应用公式 x′=1 得到 1⋅x1⋅x2+x1⋅x2⋅1。整理得 ∂u∂x1=2x2⋅x1。再代入 (1,2) 得到 ∂u∂x1(1,2)=4。

常见的求导公式有:

(是常数)c′=0 (c是常数)
x′=1
(u+v)′=u′+v′
(是常数)(cu)′=cu′ (c是常数)
(u−v)′=u′−v′
(uv)′=u′v+uv′
本题目中,你需要求解的函数 f 仅由常数、自变量和它们的加法、减法、乘法组成。且为程序识读方便,函数表达式已经被整理为逆波兰式(后缀表达式)的形式。例如,x1⋅x1⋅x2 的逆波兰式为 x1 x1 * x2 *。逆波兰式即为表达式树的后序遍历的结果。若要从逆波兰式还原原始计算算式,可以按照这一方法进行:假设存在一个空栈 S,依次读取逆波兰式的每一个元素,若读取到的是变量或常量,则将其压入 S 中;若读取到的是计算符号,则从 S 中取出两个元素,进行相应运算,再将结果压入 S 中。最后,若 S 中存在唯一的元素,则该表达式合法,其值即为该元素的值。例如对于逆波兰式 x1 x1 * x2 *,按上述方法读取,栈 S 的变化情况依次为(左侧是栈底,右侧是栈顶):

x1;
x1,x1;
(x1⋅x1);
(x1⋅x1),x2;
((x1⋅x1)⋅x2)。
输入格式
从标准输入读入数据。

输入的第一行是由空格分隔的两个正整数 n、m,分别表示要求解函数中所含自变量的个数和要求解的偏导数的个数。

输入的第二行是一个逆波兰式,表示要求解的函数 f。其中,每个元素用一个空格分隔,每个元素可能是:

一个自变量 xi,用字符 x 后接一个正整数表示,表示第 i 个自变量,其中 i=1,2,…,n。例如,x1 表示第一个自变量 x1。
一个整常数,用十进制整数表示,其值在 −105 到 105 之间。
一个运算符,用 + 表示加法,- 表示减法,* 表示乘法。
输入的第三行到第 m+2 行,每行有 n+1 个用空格分隔的整数。其中第一个整数是要求偏导数的自变量的编号 i=1,2,…,n,随后的整数是要求算的点的坐标 a1,a2,…,an。
输入数据保证,对于所有的 i=1,2,…,n,ai 都在 −105 到 105 之间。

输出格式
输出到标准输出中。

输出 m 行,每行一个整数,表示对应的偏导数对 109+7 取模的结果。即若结果为 y,输出为 k,则保证存在整数 t,满足 y=k+t⋅(109+7) 且 0≤k<109+7。

样例 1 输入
2 2
x1 x1 x1 * x2 + *
1 2 3
2 3 4

样例 1 输出
15
3

样例 1 说明
读取逆波兰式,可得被求导的式子是:u=x1⋅(x1⋅x1+x2),即 u=x13+x1x2。

对 x1 求偏导得 ∂u∂x1=3x12+x2。代入 (2,3) 得到 ∂u∂x1(2,3)=15。

对 x2 求偏导得 ∂u∂x2=x1。代入 (3,4) 得到 ∂u∂x2(3,4)=3。

样例 2 输入
3 5
x2 x2 * x2 * 0 + -100000 -100000 * x2 * -
3 100000 100000 100000
2 0 0 0
2 0 -1 0
2 0 1 0
2 0 100000 0

样例 2 输出
0
70
73
73
999999867

样例 2 说明
读取逆波兰式,可得被求导的式子是:u=x2⋅x2⋅x2+0−(−105)⋅(−105)⋅x2,即 u=x23−1010x2。

因为 u 中实际上不含 x1 和 x3,对这两者求偏导结果均为 0。

对 x2 求偏导得 ∂u∂x2=3x22−1010。

评测用例规模与约定
测试点    n    m    表达式的性质
1, 2    =1    ≤100    仅含有 1 个元素
3, 4    =1    ≤100    仅含有一个运算符
5, 6    ≤10    ≤100    含有不超过 120 个元素,且不含乘法
7, 8    ≤10    ≤100    含有不超过 120 个元素
9, 10    ≤100    ≤100    含有不超过 120 个元素
提示
C++ 中可以使用 std::getline(std::cin, str) 读入字符串直到行尾。

当计算整数 n 对 M 的模时,若 n 为负数,需要注意将结果调整至区间 [0,M) 内。

解析:

参考来源:第31次CCF计算机软件能力认证 - ~Lanly~ - 博客园 (cnblogs.com)

从题目中可以看逆波兰式就是表达树的后序遍历,所以我们可以利用二叉树的递归遍历进行求解。

同时,我们可以利用vector向量建立二叉树,用链表也行,但是会比较麻烦。

具体请看代码:

#include<iostream>
#include<string>
#include<cstring>
#include<cmath>
#include<ctime>
#include<algorithm>
#include<utility>
#include<stack>
#include<queue>
#include<vector>
#include<set>
#include<math.h>
#include<map>
#include<sstream>
using namespace std;
typedef long long LL;
#define CH 1
#define CONST 2
#define OP 3
const int mod = 1e9 + 7;
int n, m;
vector<int>lc;
vector<int>rc;
vector<int>info;
vector<int>kind;
stack<int>stk;
vector<int>a(200);
// 定义递归函数 solve,计算表达式树节点的值和导数
pair<int, int> solve(int u, int x) {if (kind[u] == CH) {return pair<int, int>{a[info[u]], (info[u] == x)};}else if (kind[u] == CONST) {return pair<int, int>{info[u], 0};}else {auto lans = solve(lc[u], x), rans = solve(rc[u], x);int sum = 0, dsum = 0;if (info[u] == '+') {sum = lans.first + rans.first;dsum = lans.second + rans.second;}else if (info[u] == '-') {sum = lans.first - rans.first;dsum = lans.second - rans.second;}else {sum = 1ll*lans.first * rans.first % mod;dsum = (1ll*lans.first * rans.second%mod + 1ll*lans.second * rans.first%mod);//1ll 是一种常见的编码技巧,用于将数字字面量转换为长长整型(long long)类型。}sum = (sum % mod + mod) % mod;dsum = (dsum % mod + mod) % mod;return pair<int, int>{sum, dsum};}
}
int main() {cin >> n >> m;string s;getline(cin, s);getline(cin, s);int cnt = 0;istringstream q(s);//q 是一个 istringstream 对象,用于从字符串中读取数据。//getline(qwq, s, ' ') 是 C++ 中的输入流操作,//用于从输入流 qwq 中读取一行(以换行符 '\n' 结束的一行)并存储到字符串 s 中,//直到遇到指定的分隔符(在这里是空格 ' ')为止。while (getline(q, s, ' ')) {if (s.size() == 1 && (s[0] == '+' || s[0] == '*' || s[0] == '-')) {int rson = stk.top();stk.pop();int lson = stk.top();stk.pop();lc.push_back(lson);rc.push_back(rson);info.push_back(s[0]);kind.push_back(OP);stk.push(cnt);cnt++;}else if (s[0] == 'x') {int x = stoi(s.substr(1));//subStr 是从第二个字符开始的子串,stoi 将其转换为整数。x--;lc.push_back(-1);rc.push_back(-1);info.push_back(x);kind.push_back(CH);stk.push(cnt);cnt++;}else {int x = stoi(s);lc.push_back(-1);rc.push_back(-1);info.push_back(x);kind.push_back(CONST);stk.push(cnt);cnt++;}}int root = stk.top();// 处理每个查询for (int i = 1; i <= m; i++) {int x;cin >> x;x--;//由于我们是从0开始记录,所以这里要-1for (int j = 0; j < n; j++) {cin >> a[j];}cout << solve(root, x).second << endl;}return 0;
}

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

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

相关文章

DAPP开发【11】IPFS星际文件管理系统【简介,实践看12】

IPFS&#xff08;InterPlanetary File System&#xff09;是一个点对点的分布式文件系统&#xff0c;旨在创建一个更快速、更安全和更开放的 Web。它不同于传统的 HTTP 协议&#xff0c;因为它不需要使用一个固定的地址来访问文件&#xff0c;而是通过一个基于内容寻址的系统&a…

HeartBeat监控Mysql状态

目录 一、概述 二、 安装部署 三、配置 四、启动服务 五、查看数据 一、概述 使用heartbeat可以实现在kibana界面对 Mysql 服务存活状态进行观察&#xff0c;如有必要&#xff0c;也可在服务宕机后立即向相关人员发送邮件通知 二、 安装部署 参照章节&#xff1a;监控组件…

S32K324 UDS Bootloader开发-下位机篇-App软件开发

文章目录 前言ld文件修改增加编译文件CAN发送与接收发送接收函数调用UDS协议增加校验算法Hex文件合并总结前言 本文参考NXP官网的S32K3 Bootloader,移植实现UDS刷写功能。本文是APP软件的修改 本文参考NXP官网的S32K324 UBL,其中有一些Bug,也有一些和上位机不兼容的地方,在本…

每日一博 - 图解5种Cache策略

文章目录 概述读策略Cache AsideRead Through 写策略Write ThroughWrite AroundWrite Back 使用场景举例 概述 缓存是在系统中存储数据的临时存储器&#xff0c;用于提高访问速度。缓存策略定义了如何在缓存和主存之间管理数据 读策略 Read data from the system: &#x1f5…

vue3原生方法滚动列表

效果图 代码 import { ref, onBeforeUnmount, onUnmounted } from "vue"; //定时器初始化 let timer ref(null); //ref绑定初始化 let roll ref(null); //等同于vue2中的beforeDestroy onBeforeUnmount(() > {//清除定时器clearTimeout(timer.value); }); //等同…

AGI时代探导开发的智能化落地之路:中国企业低代码及无代码应用价值报告V6

今天分享的AGI系列深度研究报告&#xff1a;《AGI时代探导开发的智能化落地之路&#xff1a;中国企业低代码及无代码应用价值报告V6》。 &#xff08;报告出品方&#xff1a;甲子光年智库&#xff09; 报告共计&#xff1a;47页 点击添加图片描述&#xff08;最多60个字&…

机器学习与人工智能:一场革命性的变革

机器学习与人工智能&#xff1a;一场革命性的变革 人工智能的概述什么是机器学习定义解释 数据集结构机器学习应用场景 人工智能的概述 1956年8月&#xff0c;在美国汉诺斯小镇宁静的达特茅斯学院中&#xff0c;约翰麦卡锡&#xff08;John McCarthy&#xff09;、马文闵斯基&…

数据链路层的作用和三个基本问题

目录 一. 数据链路层的作用二. 数据链路层解决的三个问题2.1 数据链路和帧2.2 三个基本问题(重要)2.2.1 封装成帧2.2.2 透明传输2.2.3 差错检测 \quad 一. 数据链路层的作用 \quad \quad \quad 光有链路不能传输数据, 还要加上协议, 这样才是数据链路 数据链路层的作用就是负责…

RHEL8_Linux虚拟数据优化器VDO

本章主要介绍虚拟化数据优化器 什么是虚拟数据优化器VDO创建VDO设备以节约硬盘空间 1.了解什么是VDO VDO全称是Virtual Data Optimize&#xff08;虚拟数据优化)&#xff0c;主要是为了节省硬盘空间。 现在假设有两个文件file1和 file2&#xff0c;大小都是10G。file1和 fil…

.NET 材料检测系统崩溃分析

Windbg 分析 1. 到底是哪里的崩溃 一直跟踪我这个系列的朋友应该知道分析崩溃第一个命令就是 !analyze -v &#xff0c;让windbg帮我们自动化异常分析。 0:033> !analyze -v CONTEXT: (.ecxr) rax00000039cccff2d7 rbx00000039c85fc2b0 rcx00000039cccff2d8 rdx000000000…

洛谷P3807 Lucas定理

传送门&#xff1a; P3807 【模板】卢卡斯定理/Lucas 定理 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)https://www.luogu.com.cn/problem/P3807题干&#xff1a; 给定整数n,m,p 的值&#xff0c;求出C&#xff08;nm&#xff0c;n&#xff09;​mod p 的值。 输入数据保证…

5分钟搞懂K8S Pod Terminating/Unknown故障排查

Kubernetes集群中的Pod有时候会进入Terminating或Unknown状态&#xff0c;本文列举了6种可能的原因&#xff0c;帮助我们排查这种现象。原文: K8s Troubleshooting — Pod in Terminating or Unknown Status 有时我们会看到K8S集群中的pod进入"Terminating"或"U…

每日一练【查找总价格为目标值的两个商品】

一、题目描述 题目链接 购物车内的商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况&#xff0c;返回任一结果即可。 示例 1&#xff1a; 输入&#xff1a;price [3, 9, 12, 15], target 18 输出&#xff1a;[3,15] …

成都工业学院Web技术基础(WEB)实验一:HTML5排版标签使用

写在前面 1、基于2022级计算机大类实验指导书 2、代码仅提供参考&#xff0c;前端变化比较大&#xff0c;按照要求&#xff0c;只能做到像&#xff0c;不能做到一模一样 3、图片和文字仅为示例&#xff0c;需要自行替换 4、如果代码不满足你的要求&#xff0c;请寻求其他的…

Python+AI实现AI绘画

&#x1f517; 运行环境&#xff1a;Python &#x1f6a9; 撰写作者&#xff1a;左手の明天 &#x1f947; 精选专栏&#xff1a;《python》 &#x1f525; 推荐专栏&#xff1a;《算法研究》 &#x1f510;#### 防伪水印——左手の明天 ####&#x1f510; &#x1f497; 大家…

Gemini与GPT-4的巅峰对决:AI界的双壁之战

随着人工智能技术的飞速发展&#xff0c;AI领域的竞争越来越激烈。在这个充满挑战与机遇的时代&#xff0c;两个备受瞩目的AI巨头——Gemini Pro和GPT-4&#xff0c;成为了人们关注的焦点。这两者都以其强大的功能和卓越的性能&#xff0c;引领着AI领域的发展潮流。本文将详细介…

MyBatisX插件

MyBatisX插件 MyBatis-Plus为我们提供了强大的mapper和service模板&#xff0c;能够大大的提高开发效率。 但是在真正开发过程中&#xff0c;MyBatis-Plus并不能为我们解决所有问题&#xff0c;例如一些复杂的SQL&#xff0c;多表联查&#xff0c;我们就需要自己去编写代码和SQ…

connection error;reply-code=503;unknown exchange type ‘x-delayed-message‘

错误原因 这个错误表明你的 RabbitMQ 服务器不认识交换机类型 “x-delayed-message”&#xff0c;这通常是因为你的 RabbitMQ 服务器没有启用 rabbitmq_delayed_message_exchange 插件&#xff0c;或者插件版本与你的 RabbitMQ 服务器不兼容。 解决方法 启用 RabbitMQ 延迟队…

JAVA安全之Spring参数绑定漏洞CVE-2022-22965

前言 在介绍这个漏洞前&#xff0c;介绍下在spring下的参数绑定 在Spring框架中&#xff0c;参数绑定是一种常见的操作&#xff0c;用于将HTTP请求的参数值绑定到Controller方法的参数上。下面是一些示例&#xff0c;展示了如何在Spring中进行参数绑定&#xff1a; 示例1&am…

2024年C语言基础知识入门来了,一文搞定C语言基础知识!

一、C语言基础知识入门 c语言基础知识入门一经出现就以其功能丰富、表达能力强、灵活方便、应用面广等特点迅速在全世界普及和推广。C语言不但执行效率高而且可移植性好&#xff0c;可以用来开发应用软件、驱动、操作系统等&#xff0c;2024年C语言基础知识入门大全。C语言基础…