OpenJudge 2712

本文介绍了一道关于细菌繁殖速度的编程题目,细菌的数量每天翻倍。文章提供了两种计算从初始日期到目标日期细菌数量的方法,并附带了具体的实现代码。

2712:细菌繁殖

Time Limit:
1000ms
Memory Limit:
65536kB
Description
一种细菌的繁殖速度是每天成倍增长。例如:第一天有10个,第二天就变成20个,第三天变成40个,第四天变成80个,……。现在给出第一天的日期和细菌数目,要你写程序求出到某一天的时候,细菌的数目。
Input
第一行有一个整数n,表示测试数据的数目。其后n行每行有5个整数,整数之间用一个空格隔开。第一个数表示第一天的月份,第二个数表示第一天的日期,第三个数表示第一天细菌的数目,第四个数表示要求的那一天的月份,第五个数表示要求的那一天的日期。已知第一天和要求的一天在同一年并且该年不是闰年,要求的一天一定在第一天之后。数据保证要求的一天的细菌数目在长整数(long)范围内。
Output
对于每一组测试数据,输出一行,该行包含一个整数,为要求的一天的细菌数。
Sample Input
2
1 1 1 1 2
2 28 10 3 2
Sample Output
2
40
//两个同一年的日期相减 
第一版 
int month[12]={31,28,31,30,31,30,31,31,30,31,30,31};//无闰年 
int start_m,start_d,end_m,end_d;
int start_num;
int sum_d = 0;
if(start_m=end_m)
    sum_d = end_d - start_d;
else
{
    sum_d += month[start_m-1] - start_d;
    for(i=start_m+1;i<end_month;i++)
        sum_d += month[i-1];
    sum_d += end_d;
}
结果:start_num*pow(2,sum_day);



第二版
int day_of_year(int m,int d)//计算某月某日为非闰年中的第几天
 {   
     int res=0,a[]={31,28,31,30,31,30,31,31,30,31,30,31};   
     for (int i=0;i<=m-2;i++)      res+=a[i];
     return res+d;
 }
 

  



转载于:https://www.cnblogs.com/hxsyl/archive/2012/08/16/2642190.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值