比值计算 - 荣耀机试真题题解 ( 第1题 100 分)

系统:牛客网

考试时长: 90分钟

试卷总分: 300分 (总共 2 题)

题目描述

已知差值 x = 10 ∗ l o g 10 ( S / N ) − 10 ∗ l o g 10 ( S / ( N + k ∗ N ) ) x=10*log10(S/N)-10*log10(S/(N+k*N)) x=10∗log10(S/N)−10∗log10(S/(N+k∗N)),计算10*log(k)并打印出来(整数即可)

输入描述

差值 x

输出描述

10*log10(k) 并打印出来(整数即可)

示例1

复制代码
输入:
0.1

输出:
-16

示例2

复制代码
输入:
0.5

输出:
-9

示例3

复制代码
输入:
0.1

输出:
-16

示例4

复制代码
输入:
3

输出:
0

题解

乍一看这个题好像跟算法没什么关系。仔细推导发现是道 数学题

数学基础知识

  • l o g a ( x y ) = l o g a x + l o g a y log_a(xy) = log_ax + log_ay loga(xy)=logax+logay
  • l o g a ( x / y ) = l o g a x − l o g a y log_a(x/y) = log_ax - loga_y loga(x/y)=logax−logay

推导过程

复制代码
x=10*log10(S/N)-10*log10(S/(N+k*N))

x=10*log10(S/N)-10*log10(S/(N(1+k)))

x=10*log10(S/N)-10*log10(S/N * 1/(1+k))

x=10*log10(S/N)-(10*log10(S/N) + 10*log10(1/(1+k)))

x=-10*log10(1/(1+k)))

x=-(10*log10(1) - 10*log10(1+k))

x=10*log10(1+k)

k = 10^(x/10) - 1

10log10(k) = 10log10(10^(x/10) - 1)

Python

python 复制代码
import math


def calc(x):
    # 10*log10(k) = 10*log10(10(x/10)-1)
    return int(10 * math.log10(10**(x/10) - 1))

x_value = float(input())
result = calc(x_value)
print(result)

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

相关推荐
Jia ming1 分钟前
《智能法官软件项目》—数据可视化模块
python·信息可视化·教学·案例·智能法官软件
Anastasiozzzz11 分钟前
LeetCode 287 寻找重复数字
算法·leetcode·职场和发展
im_AMBER11 分钟前
Leetcode 123 二叉树的层平均值 | 二叉树的右视图 | 二叉树的层序遍历
数据结构·学习·算法·leetcode·二叉树
We་ct11 分钟前
LeetCode 100. 相同的树:两种解法(递归+迭代)详解
前端·算法·leetcode·链表·typescript
样例过了就是过了19 分钟前
LeetCode热题100 轮转数组
数据结构·算法·leetcode
Web极客码19 分钟前
CentOS 7 删除文件却不释放空间?从 inode、文件描述符到 VFS 的底层原理解析
python·centos·numpy
ShineWinsu19 分钟前
对于stack和queue经典算法题目:155. 最小栈、JZ31 栈的压入、弹出序列和102. 二叉树的层序遍历的解析
数据结构·c++·算法·面试·力扣·笔试·牛客网
能源系统预测和优化研究23 分钟前
【原创改进代码】考虑电动汽车移动储能特性的多区域电网功率波动平抑优化调控
大数据·算法·能源
_F_y23 分钟前
两个数组的动态规划
算法·动态规划
每天要多喝水24 分钟前
动态规划Day32:最长公共子序列
算法·动态规划