草庐IT

long-double

全部标签

c++ - 模板代码中的 float 或 double

下面的例子可能看起来很荒谬,但它是一个更大的高性能代码的一部分,在这个代码中所介绍的技术是有意义的。我提到这一点是为了防止有人怀疑XY问题——很可能不是。我有一个带有模板化/编译时操作数的函数:templateintmul(intx){returnM*x;}现在我想对double做同样的事情,这是-当然-不允许的:template//youcan'tdothat!intmul(doublex){returnM*x;}所以为了在编译时仍然放入double,我只看到以下解决方案://createmyconstantsstructSevenPointFive{staticconstexprd

c++ - 初始化 std::pair<double, std::array<std::pair<double, double>, 3>>

谁能建议以下代码中std::vector::push_back调用中std::make_pair调用的正确语法:#include#include#includeintmain(){typedefstd::pairPairType;std::vector>>myVector;doubleKey=0.0;PairTypePair1=std::make_pair(1.0,2.0);PairTypePair2=std::make_pair(3.0,4.0);PairTypePair3=std::make_pair(5.0,6.0);myVector.push_back(std::make_pa

c++ - 在不丢失信息的情况下将 double 转换为 int64_t 并返回

这个问题可能有人问过,但我搜索过,找不到答案。我正在实现一个玩具虚拟机,其中OpCodes采用以下形式:std::tuple//instructionop1,op2我正在尝试将一个double值打包到其中一个操作数中,并在处理它时再次读回它。这不能可靠地工作。doubled=...autoa=static_cast(d);autob=static_cast(a)//sometimes,b!=d有没有办法将double的位表示打包成int64_t,然后读回该位模式以获得与以前完全相同的double? 最佳答案 static_cast执

c++ - 如何计算 double 的平均值,使总误差最小?

假设我们有一个很长的double组,比如说,N==1000000。arrayarr;计算平均值有两种简单的方法。首先doubleresult=0;for(doublex:arr){result+=x;}result/=arr.size();当值的总和很大时,这可能不准确。float会失去精度。另一种方法是:doubleresult=0;for(doublex:arr){result+=x/arr.size();}当数字较小时,这可能会失去精度。是否有任何故障安全方法来计算float的简单平均值?仅使用标准库的解决方案值得赞赏。 最佳答案

c++ - 使用 Int 的初始化列表初始化 Long Double 的 vector

假设我有一个简单的类:classPvector{private:std::vectorpoint_list;public:Pvector(std::initializer_listcoords):point_list(coords){}Pvector(std::initializer_listcoords):point_list(coords){}};这将无法编译,因为longdouble模板化的std::vector无法从int类型模板化的初始化列表中初始化自身.然而,这很不方便,因为删除了第二个构造函数后,我无法在我的代码中执行以下操作:Pvectorpiece_movement(

c++ - "integer constant is too large for ‘long’ 求最大质因数时键入"

我正在解决Euler项目3:Description:Theprimefactorsof13195are5,7,13and29.Whatisthelargestprimefactorofthenumber600851475143?这是我生成答案的代码。但是我需要一个整数类型来保存600851475143。当我在Mac上的GCC上编译它时,我得到:integerconstantistoolargefor‘long’type".我预计longlong可以轻松持有这个数字。我也试过让它未签名。为什么我的代码不能保存这么小的数字?我该怎么做才能让它发挥作用?#include#includeusi

c++ - 将 double 与双文字进行比较?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:HowshouldIdofloatingpointcomparison?是否不建议在C++中比较double和double文字的相等性,因为我猜它取决于编译器?更准确地说,比较硬编码的double(源代码中的文字)和应该计算的double是不行的,因为计算结果的最后一个数字可能与一个不同编译器到另一个。这不规范吗?我听说Knuth的TeXbook中提到了这一点,对吗?如果这一切都是真的,解决方案是什么?

c++ - 在一系列值之间生成随机 double

我目前无法生成介于-32.768和32.768之间的随机数。它一直给我相同的值,但在小数字段中有一个小的变化。例如:27.xxx。这是我的代码,如有任何帮助,我们将不胜感激。#include#include#includeusingnamespacestd;intmain(){srand(time(NULL));doubler=(68.556*rand()/RAND_MAX-32.768);cout 最佳答案 我应该提一下,如果你使用的是C++11编译器,你可以使用类似这样的东西,它实际上更容易阅读,也更难搞砸:#include#i

c++ - `intmax_t` 在具有 64 位 `long int` 和 `long long int` 的平台上应该是什么?

在C++标准18.4中它指定:typedef'signedintegertype'intmax_t;根据具有64位longint和64位longlongint的平台标准,这个“有符号整数类型”应该是?请注意,longint和longlongint是不同的基本类型。C++标准说:Theheaderdefinesallfunctions,types,andmacrosthesameas7.18intheCstandard.在C标准(N1548)的7.18中,它说:Thefollowingtypedesignatesasignedintegertypecapableofrepresentin

c++ - 如何从 C++ 中的 pthread 返回 double 值?

阅读此主题后:HowtoreturnavaluefromthreadinC关于如何从pthread返回整数值我测试过它是否可以用于double,但它没有。有没有办法像原始线程中描述的那样从pthread进程返回double、长整数或字符串,而不是返回整数42?如果是怎么办?如果我有一个包含10个位置的静态数组和10个pthread每次修改不同的位置,我会遇到麻烦吗?一个例子就像“线程0只修改数组[0],线程1只修改数组[1]等等”。 最佳答案 线程只需为您希望它返回的结果动态分配内存:void*myThread(void*){dou