如何在此代码中避免截断的整数除法?我排序的数组是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;
}
答案 0 :(得分:1)
b
变量不能保存浮点数,因为它是一个整数。不仅您转换为float
的时间太晚,而且您将结果存储在整数变量中。你怎么能期待别的东西而不是整数结果?
float b = ((float)arr[n])/2.f;
会给出更好的结果。
答案 1 :(得分:0)
结果:
arr[n] / 2
是整数表达式,因为两个操作数都是整数。因此,它执行整数除法,您将失去所需的精度。之后将(整数)结果转换为float
将无济于事,因为精度只是不存在。
要获得所需的精度,请在分割前设置两个操作数float
:
float b = (float) arr[n] / 2.f;
答案 2 :(得分:0)
如何避免此代码中的截断整数除法?
将值缩放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 %lld\n", a2);
printf("b*2 %lld\n", b2);
long long m2 = min(a2,b2);
printf("m*2 %lld\n", m2);
long long ans2 = min(m2 * n + m2 * 2LL * n, w*2);
printf("ans*2 %lld\n", ans);
printf("ans %lld.%d\n", ans2/2, abs(ans%2)*5);
return 0;
}
注意:在C中,确保long long min(long long a, long long b)
具有该签名。