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()
相关推荐
君义_noip2 小时前
信息学奥赛一本通 1661:有趣的数列 | 洛谷 P3200 [HNOI2009] 有趣的数列
c++·算法·组合数学·信息学奥赛·csp-s
程序员:钧念2 小时前
深度学习与强化学习的区别
人工智能·python·深度学习·算法·transformer·rag
英英_3 小时前
MATLAB数值计算基础教程
数据结构·算法·matlab
一起养小猫4 小时前
LeetCode100天Day14-轮转数组与买卖股票最佳时机
算法·leetcode·职场和发展
hele_two4 小时前
快速幂算法
c++·python·算法
l1t4 小时前
利用DeepSeek将python DLX求解数独程序格式化并改成3.x版本
开发语言·python·算法·数独
jllllyuz5 小时前
基于子集模拟的系统与静态可靠性分析及Matlab优化算法实现
算法·matlab·概率论
程序员-King.5 小时前
day143—递归—对称二叉树(LeetCode-101)
数据结构·算法·leetcode·二叉树·递归
BlockChain8885 小时前
字符串最后一个单词的长度
算法·go
爱吃泡芙的小白白5 小时前
深入解析:2024年AI大模型核心算法与应用全景
人工智能·算法·大模型算法