wannafly 12 A 完全背包

题目:点击打开链接

一道简单的完全背包,本想考完试来签个到的,结果遇到了问题。

直接看代码:

#include<bits/stdc++.h>
#define ll long long int
using namespace std;
const int inf=0x7fffffff;

double dp[25],r[6];
int main(){
    int n;
    cin>>n>>r[1]>>r[2]>>r[3]>>r[5];
    memset(dp,-1.0*inf,sizeof(dp));
    dp[0]=1;
    for(int i=1;i<=5;i++){
        if(i==4) continue;
        for(int j=i;j<=n;j++){
            dp[j]=max(dp[j],dp[j-i]*pow(1.0+r[i],i));
        }
    }
    printf("%.5f",dp[n]);
    //cout<<setprecision(6)<<dp[n];
    return 0;
}

我之前写了printf("%0.5lf",dp[n]);虽然在牛客能过,在codeblocks却输出0.00000

查了下,原因在于:(之前从未注意)

(所以还是用cout好,虽然有时慢而且精度单词老记不住。。)

摘自:https://www.cnblogs.com/Xiao_bird/archive/2010/03/26/1696908.html

最近在CSDN上看到一个网友写下了类似如下代码,想以小数格式输出一个整数:

int  a  =   0 , b  =   0 ;
printf(
" %f, %d " , a, b);
可是运行结果并不尽如人意,%f字段输出了0,%d字段输出一个较大的数据。

因为我最近刚阅读了浮点数的内存表示方法,所以对上述代码做出解释如下:
%f为double类型,需要两个字节表示,所以,printf在遇到%f时即将a,b的两个整型数据都读了去,而到了需要输出%d的时候,只能读取b的下一个单元,自然不是所期望的数据了。

但是有朋友说%f是float类型,%lf才是double类型,具此我特意查阅了MSDN和Linux man手册,均没有发现此类描述,在linux man手册中,说明%lf为long double类型。
为了说明问题,我又做了几个实验:

实验一,检查%f需要读取几个字节
int  a = 0 , b = 0 , c = 5 ;
printf(
" %f,%d\n " , a, b, c);
输出结果:
0,5
结论:%f读取8个字节,即两个整型大小

实验二,检查%lf需要读取几个字节
int  a = 0 , b = 0 , c = 5 ;
printf(
" %lf,%d\n " , a, b, c);
输出结果:
0,5
结论:%lf也读取8个字节(也许和机器位宽有关,我是32位的机器)

实验三,检查printf读取float类型数据
float  a = 0.0f ;
int  b = 5 ;
printf(
" %f,%d\n " , a, b);
输出结果:
0.0,5
结论:float类型只占4个字节的数据,但前面实验一已经证明%f会读8个字节,即double类型的宽度,所以,编译器在将float类型参数入栈的时候,事先转换成了double类型。

实验四,再次证明实验三的结论
float  a = 0.0f ;
int  b = 5 ;
printf(
" %d,%d,%d\n " , a, b);
输出结果:
0,0,5
结论:a在入栈的时候,占了8个字节。

以上4步,我觉得可以证明 %f是按double类型输出的了 ,另外,我也知道了float类型在作为参数进行传递的时候,编译器会先将它转换成double类型。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值