截断的整数除法删除
truncated integer division removal
T 如何避免此代码中的截断整数除法?我的排序数组是1 1 1 1 1 1
,所以 a[0] = 1 和 a[n] 应该是 1/2 = 0.5。
int main()
{
long long n,w;
scanf("%lld %lld", &n, &w);
long long arr[2*n];
for(long long i = 0; i < 2 * n; i++)
{
scanf("%lld", &arr[i]);
}
sort(arr,arr+2*n);
long long a = arr[0];
long long b = (float)(arr[n]/2); // <--- this part of code
cout << " a is " << a << endl;
cout << " b is " << b << endl;
long long m = min(a,b);
cout << " m is " << m << endl;
long long and = min(m * n + m * 2LL * n, w);
printf("%lld", ans);
return 0;
}
b
变量不能容纳浮点数,因为它是一个整数。不仅转换为float
发生得太晚,而且您将结果存储在整数变量中。你怎么能期待整数结果以外的东西?
float b = ((float)arr[n])/2.f;
会给更好的结果。
结果:
arr[n] / 2
是一个整数表达式,因为两个操作数都是整数。因此,它执行整数除法,并且您将失去所需的精度。之后将(整数(结果转换为float
将无济于事,因为精度不存在。
要获得所需的精度,请在除法前将两个操作数都设为 float
s:
float b = (float) arr[n] / 2.f;
如何避免此代码中截断的整数除法?
将值缩放 2,最后仅除以 2。
int main(void) {
long long n,w;
scanf("%lld %lld", &n, &w);
long long arr[2*n];
for(long long i = 0; i < 2 * n; i++)
{
scanf("%lld", &arr[i]);
}
sort(arr,arr+2*n);
long long a2 = arr[0]*2;
long long b2 = arr[n];
printf("a*2 %lldn", a2);
printf("b*2 %lldn", b2);
long long m2 = min(a2,b2);
printf("m*2 %lldn", m2);
long long ans2 = min(m2 * n + m2 * 2LL * n, w*2);
printf("answers*2 %lldn", ans);
printf("answers %lld.%dn", ans2/2, abs(ans%2)*5);
return 0;
}
注意:在 C 中,确定long long min(long long a, long long b)
具有该签名。
相关文章:
- 将数组的地址分配给变量并删除
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- C/C++编译器通常会删除重复的库吗
- 从链接列表c++中删除一个项目
- C++如何通过用户输入删除列表元素
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 是否需要删除包含对象的"pair"?
- 如何在自删除后将对象设置为nullptr
- 迭代时从向量和内存中删除对象
- 使用函数"remove"删除重复元素
- 如何从多映射中删除特定的重复项
- 运算符C++ "delete []"仅删除 2 个前值
- 删除指向指针的指针是运行时错误吗
- 将指针设置为"nullptr"并不能防止双重删除?
- 为什么示例代码访问IUnknown中已删除的内存
- 如何通过 getter 函数删除矢量的元素?
- 从控制台中删除最后打印的元素
- C++中的线程安全删除
- 截断的整数除法删除
- 删除除法中的精度