gpt4 book ai didi

c++ - 我怎样才能(安全地)除以一个最大值,得到一个浮点值?

转载 作者:太空狗 更新时间:2023-10-29 21:36:27 27 4
gpt4 key购买 nike

我想计算转换系数。为此,我必须除以例如的最大值。 ushort 为 uchar 的最大值。

我想通过将参数传递给函数或类型名来动态地执行此操作。然后我想选择最大值并执行计算。

有两个问题:

  1. 如何动态选择最大值?
  2. 如何安全地划分这两个值?

已知所有值都适合 double 的范围。

理想情况下我想做这样的事情:

double x = numeric_limits<T>::max / numeric_limits<T2>::max;

但是这是不正确/不可能的。

最佳答案

您提出的想法应该可行:

#include <iostream>
#include <limits>

template <typename T, typename T2>
double get_ratio()
{
return static_cast<double>(std::numeric_limits<T>::max()) / std::numeric_limits<T2>::max();
}

int main()
{
auto ratio = get_ratio<unsigned short, unsigned char>();
std::cout << ratio << '\n';
return 0;
}

demo

关于c++ - 我怎样才能(安全地)除以一个最大值,得到一个浮点值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40181993/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com