第二周----玩日期(2)

/*
* Copyright (c) 2013, 烟台大学计算机学院
* All rights reserved.
* 作    者:申玉迪
* 完成日期:2014 年 3 月 8 日
* 版 本 号:v1.0
*/
#include <iostream>

using namespace std;

struct Date
{
    int year;
    int month;
    int day;
    int hour;
    int minute;
    int second;
} date1,date2;

int day(int,int,int);
int time(int,int,int);

/*输入两个人的生日,看和1900年1月1日相差多少天,然后在相减*/

int main()
{
    int d1=0,d2=0,s1=0,s2=0,s,t;/*d1,m1,y1代表第一个人的出生年月日,同理d2,m2,d2,
                            t表示相差天数,i和j分别作为循环的年和月*/
    cout<<"第一个日期:";
    cin>>date1.year>>date1.month>>date1.day>>date1.hour>>date1.minute>>date1.second;
    d1=day(date1.year,date1.month,date1.day);
    s1=time(date1.hour,date1.minute,date1.second);
    cout<<"第二个日期:";
    cin>>date2.year>>date2.month>>date2.day>>date2.hour>>date2.minute>>date2.second;
    d2=day(date2.year,date2.month,date2.day);
    s2=time(date2.hour,date2.minute,date2.second);
    t=d2-d1;
    if(t<=0)
    {
        t=-t;//若出现负数,则将其化为正数
        s=t*86400+s1-s2;
    }
    else
    {
        s=t*86400+s2-s1;
    }
    cout<<"相差"<<t<<"天。"<<endl;
    cout<<"相差"<<s<<"秒。"<<endl;

}
int day(int year,int month,int day)
{
    int d,y=0,i,j,m=0;
    for(i=1900; i<year; i++)//算出这年之前到1900年共多少天
    {
        y+=365;
        if(i%400==0||(i%4==0&&i%100!=0))
        {
            y++;
        }
    }
    for(j=0; j<month; ++j)//算出本年到生日共多少天
    {
        int x;
        if(j==2)
        {
            if(year%400==0||(year%4==0&&year%100!=0))
            {
                x=29;
            }
            else
            {
                x=28;
            }
        }
        else if(j==1||j==3||j==5||j==7||j==8||j==10||j==12)
            x=31;
        else if(j==4||j==6||j==9||j==11)
            x=30;
        else if(j==0)
            x=day;
        m+=x;
    }
    d=y+m;//生日到1900年1月1日共多少天
    return d;
}

int time(int hour,int minute,int second)
{
    int s;
    s=hour*60*60+minute*60+second;
    return s;
}


 

写这个时一开始出现些小意外,函数不知道该怎么声明,后来问了老师才明白应该在哪个地方改一改。其实这个题和第一周的项目三的选做差不多,就是多了一个秒数的问题,那个题我没用函数,这个题就用函数试了试,一开始还真是弄不出来,不实践永远不知道自己到底会不会。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
根据提供的引用内容,el-date-picker组件可以通过设置type属性来选择日期和时间的格式,但是并没有提供选择周的格式。不过我们可以通过设置value-format属性和picker-options属性来实现选择周的功能。具体步骤如下: 1.设置value-format属性为'yyyyw',表示选择的日期格式为年份和周数,例如2022年第3周。 2.设置picker-options属性,其中disabledDate函数用于禁用选择的日期,我们可以通过判断当前日期是否在选择的周内来实现禁用其他周的日期。 下面是一个示例代码: ```html <template> <div> <el-date-picker v-model="week" type="week" value-format="yyyyw" :picker-options="pickerOptions" placeholder="选择周" ></el-date-picker> </div> </template> <script> export default { data() { return { week: '', // 选择的周 pickerOptions: { disabledDate: (time) => { const currentWeek = this.getWeekNumber(new Date()); // 获取当前周 const selectedWeek = this.getWeekNumber(time); // 获取选择的周 return currentWeek !== selectedWeek; // 禁用非选择的周 }, }, }; }, methods: { // 获取当前日期所在的周数 getWeekNumber(date) { const yearStart = new Date(date.getFullYear(), 0, 1); const weekNo = Math.ceil( ((date - yearStart) / 86400000 + 1 + yearStart.getDay()) / 7 ); return weekNo; }, }, }; </script> ``` 在上面的代码中,我们定义了一个el-date-picker组件,设置了type属性为'week',value-format属性为'yyyyw',picker-options属性为一个对象,其中disabledDate函数用于禁用选择的日期。在disabledDate函数中,我们通过调用getWeekNumber方法获取当前日期和选择的日期所在的周数,然后判断它们是否相等来决定是否禁用该日期

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值