第16周OJ-1

问题及代码

/*
完成人:贾如杉
题目描述
定义一个结构体变量(包括年、月、日)。编写一个函数days,由主函数将年、月、日传递给函数days,计算出该日在本年中是第几天并将结果传回主函数输出。


输入
年月日


输出
当年第几天

*/

struct y_m_d
{
    int year;
    int month;
    int day;
};
int days(struct y_m_d date)
{
    int day_sum;
    if(((date.year%4==0)&&(date.year%100!=0))||(date.year%400==0))
    {
        switch(date.month)
        {
        case 1:day_sum=date.day;break;
        case 2:day_sum=31+date.day;break;
        case 3:day_sum=60+date.day;break;
        case 4:day_sum=91+date.day;break;
        case 5:day_sum=121+date.day;break;
        case 6:day_sum=152+date.day;break;
        case 7:day_sum=182+date.day;break;
        case 8:day_sum=213+date.day;break;
        case 9:day_sum=244+date.day;break;
        case 10:day_sum=274+date.day;break;
        case 11:day_sum=305+date.day;break;
        case 12:day_sum=335+date.day;break;
        }

    }
    else
    {
         switch(date.month)
        {
        case 1:day_sum=date.day;break;
        case 2:day_sum=31+date.day;break;
        case 3:day_sum=59+date.day;break;
        case 4:day_sum=90+date.day;break;
        case 5:day_sum=120+date.day;break;
        case 6:day_sum=151+date.day;break;
        case 7:day_sum=181+date.day;break;
        case 8:day_sum=212+date.day;break;
        case 9:day_sum=243+date.day;break;
        case 10:day_sum=273+date.day;break;
        case 11:day_sum=304+date.day;break;
        case 12:day_sum=334+date.day;break;
        }
    }
    return day_sum;
}

int main()
{
    struct y_m_d date;
    int days(struct y_m_d);
    int day_sum;
    scanf("%d%d%d",&date.year,&date.month,&date.day);
    day_sum=days(date);
    printf("%d\n",day_sum);
    return 0;
}

运行结果


运行结果

结构体的简单运用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值