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()
相关推荐
Jay20021117 小时前
【机器学习】30 基于内容的过滤算法
人工智能·算法·机器学习
冰西瓜6007 小时前
分治(二)算法设计与分析 国科大
数据结构·算法
小小晓.7 小时前
Pinely Round 2 (Div. 1 + Div. 2)
c++·算法
清风拂山岗 明月照大江7 小时前
简单文件 IO 示例:使用系统调用读写文件
开发语言·c++·算法
Hcoco_me7 小时前
大模型面试题15:DBSCAN聚类算法:步骤、缺陷及改进方向
算法·数据挖掘·聚类
AI绘画哇哒哒7 小时前
AI 智能体长期记忆系统架构设计与落地实践
人工智能·学习·算法·ai·程序员·产品经理·转行
加藤不太惠7 小时前
【无标题】
java·数据结构·算法
金色旭光7 小时前
目标追踪算法+卡尔曼滤波原理+ByteTrack使用
算法
夏乌_Wx8 小时前
练题100天——DAY22:数字拼接+只出现一次的数字
java·数据结构·算法
listhi5208 小时前
MOEAD算法实现详解(基于Python与MATLAB)
python·算法·matlab