2024河南商丘ICPC Problem B. 表达式求导

题目描述

给定一个合法的函数表达式f(x),请你求出y=f(x)在a处的导数值,输入保证此处导数值一定存在,答案四舍五入保留两位小数。

该函数表达式被称为合法,即满足以下要求:

  1. x一定合法。

  2. 如果表达式A合法,表达式BBB合法,那么A+B,A−B一定合法。

  3. 如果表达式A合法,那么ln(A)ln(A)ln(A)也合法。

输入描述

本题有多组数据。

第一行输入整数T(1≤T≤30)T(1 \le T \le 30)T(1≤T≤30),表示数据组数。

接下来每组数据包含两行。

其中第一行输入一个字符串S,表示f(x)f(x)f(x)的函数表达式,1≤∣S∣≤20。

其中第二行输入一个至多两位小数的浮点数a(0≤a≤20),含义如上所示。

输出描述

输出一个浮点数,表示y=f(x)在a处的导数值,答案四舍五入保留两位小数。

示例1

|-----------------------|------|
| 输入 | 输出 |
| 1 ln(x)+x 0.5 | 3.00 |

思路

用定义求导 [f(x+Δx)-f(x)]/Δx,给Δx个很小的值就可以

python秒了

代码

python 复制代码
import re
import math

def rep_x(str):
    pattern = r'(\d)([a-zA-Z])'
    res = re.sub(pattern, r'\1*\2', str)
    return res

def ln(x):
    return math.log(x)

def cos(x):
    return math.cos(x)

def sin(x):
    return math.sin(x)

def solve():
    a=rep_x(input().replace('^','**'))
    x=float(input())
    dt = 0.0000000001

    res1 = eval(a)
    x += dt
    res2 = eval(a)

    res = (res2-res1)/dt

    print("%.2f"%(res))

t=int(input())
for i in range(t):
    solve()
相关推荐
地平线开发者5 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮5 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者5 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考6 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx9 小时前
CART决策树基本原理
算法·机器学习
Wect9 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱10 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
Gorway17 小时前
解析残差网络 (ResNet)
算法
拖拉斯旋风17 小时前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect17 小时前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript