Problem J

Problem Description

An array of size n ≤ 10^6 is given to you. There is a sliding window of size k which is moving from the very left of the array to the very right. You can only see the k numbers in the window. Each time the sliding window moves rightwards by one position. Following is an example: 
The array is [1 3 -1 -3 5 3 6 7], and k is 3.
Window position  Minimum value  Maximum value
[1 3 -1] -3 5 3 6 7   -1  3
1 [3 -1 -3] 5 3 6 7   -3  3
1 3 [-1 -3 5] 3 6 7   -3  5
1 3 -1 [-3 5 3] 6 7   -3  5
1 3 -1 -3 [5 3 6] 7   3  6
1 3 -1 -3 5 [3 6 7]  3  7
Your task is to determine the maximum and minimum values in the sliding window at each position. 

Input

There are several cases in the input file, each case consists of two lines. The first line contains two integers n and k which are the lengths of the array and the sliding window. There are n integers in the second line. 

Output

There are two lines in the output for each input. The first line gives the minimum values in the window at each position, from left to right, respectively. The second line gives the maximum values. 

Sample Input

8 3
1 3 -1 -3 5 3 6 7

Sample Output

-1 -3 -3 -3 3 3
3 3 5 5 6 7

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>

using namespace std;
#define N 1000005
int a[N];
int j;
int M[N];
int Ma;
int MI[N];
int mina;

int min(int x,int y)
{
    if(x<y)return x ;
    else return y;
}

int max(int x,int y)
{
    if(x>y)return x;
    else return y ;
}

struct node 
{
    int l;
    int r;
    int ma;
    int mi;
}t[N*4];

void make (int sl,int sr,int i)
{
    t[i].l=sl;
    t[i].r=sr;
    if(sl==sr)
    {
        t[i].ma=a[sr];
        t[i].mi=a[sr];
    }
    else 
    {
        int mid=(t[i].l+t[i].r)/2;
        make (sl,mid,i*2);
        make (mid+1,sr,i*2+1);
        t[i].ma=max(t[i*2].ma,t[i*2+1].ma);        
        t[i].mi=min(t[i*2].mi,t[i*2+1].mi);
    }
}
    
int  query1(int st,int ed,int i)
{
    if(st==t[i].l&&ed==t[i].r)
    //    M[j++]=t[i].ma;
        return t[i].ma;
    else if(t[i].l<t[i].r)
    {
        int mid=(t[i].l+t[i].r)/2;
        if(st>mid)
            return query1(st,ed,i*2+1);
        else if(ed<=mid)
            return query1(st,ed,i*2);
        else 
        {
            return max(query1(st,mid,i*2),query1(mid+1,ed,i*2+1));
        }
    }
}

int  query2(int st,int ed,int i)
{
    if(st==t[i].l&&ed==t[i].r)
        return t[i].mi;
    else if(t[i].l<t[i].r)
    {
        int mid=(t[i].l+t[i].r)/2;
        if(st>mid)
            return query2(st,ed,i*2+1);
        else if(ed<=mid)
            return query2(st,ed,i*2);
        else 
        {
            return min(query2(st,mid,i*2),query2(mid+1,ed,i*2+1));
        }
    }
}

int main()
{
    int n,m;
    int e;
    int i;
    while(scanf("%d %d",&n,&m)!=EOF)
    {
        memset(M,0,sizeof(M));
        memset(MI,0,sizeof(MI));
        for(i=1;i<=n;i++)
            scanf("%d",&a[i]);
        make(1,n,1);
        j=0;
        for(i=1;i<n&&(i+m-1)<=n;i++)
        {
            M[j++]=query1(i,i+m-1,1);
        }
        e=0;
        for(i=1;i<n&&(i+m-1)<=n;i++)
        {
            MI[e++]=query2(i,i+m-1,1);
        }
        for(i=0;i<e-1;i++)
            printf("%d ",MI[i]);
        printf("%d\n",MI[i]);
        for(i=0;i<e-1;i++)
            printf("%d ",M[i]);
        printf("%d\n",M[i]);
    }
    return 0;
}


题目描述 现在我们需要实现一个日期类 MyDate,它应该有以下几个功能: 1.初始化:MyDate(int year, int month, int day),其中 year 表示年份,month 表示月份,day 表示日期。 2.获取日期:int getDay(),获取当前日期。 3.获取月份:int getMonth(),获取当前月份。 4.获取年份:int getYear(),获取当前年份。 5.判断是否为闰年:bool isLeapYear(),如果是闰年则返回 true,否则返回 false。 6.计算两个日期之间相差的天数:int daysBetweenDates(MyDate& date),其中 date 是另一个 MyDate 类型的日期对象,返回当前日期与 date 日期之间相差的天数。假设 date 日期晚于当前日期。 注意事项: 1.年份 year 的范围为 [1900, 2100]。 2.月份 month 的范围为 [1, 12]。 3.日期 day 的范围为 [1, 31]。 4.两个日期之间相差的天数不会超过 int 类型能表示的范围。 5.如果输入的日期不符合要求,则输出 "invalid date"。 输入格式 第一行一个整数 T,表示共有 T 组测试数据。 每组测试数据占一行,包含六个整数 year, month, day, year2, month2, day2,其中 (year, month, day) 表示当前日期,(year2, month2, day2) 表示另一个日期。 输出格式 对于每组测试数据,输出其相差的天数。 如果输入的日期不符合要求,则输出 "invalid date"。 样例输入 3 2012 3 1 2012 3 2 2012 1 1 2012 3 1 2013 1 1 2012 3 1 样例输出 1 60 invalid date 数据说明 样例 #1: 2012 年 3 月 1 日到 2012 年 3 月 2 日相差 1 天。 样例 #2: 2012 年 1 月 1 日到 2012 年 3 月 1 日相差 60 天。 样例 #3: 2013 年 1 月 1 日不符合年份的要求,输出 "invalid date"。 解题思路 这道题目其实就是一个日期类的实现,我们需要根据题目意思,实现 MyDate 类。 首先,我们需要实现 MyDate 类的构造函数,用于初始化年月日。然后,我们需要实现 getDay(),getMonth(),getYear() 和 isLeapYear() 函数,用于获取年月日,并判断是否为闰年。 最后,我们需要实现 daysBetweenDates() 函数,用于计算两个日期之间相差的天数。我们可以先将两个日期转化为从 1900 年 1 月 1 日开始的天数,然后计算两者之间的差值即可。 注意事项: 1.要注意闰年的判断,闰年的条件是:能被 4 整除但不能被 100 整除,或者能被 400 整除。 2.要注意月份和日期的范围,例如 2 月份的日期不能超过 29。 3.要注意输入的日期是否符合要求,如果不符合要求,则输出 "invalid date"。 参考代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值