学长学姐们的测试-2

     学长学姐们觉得出测试题很有趣呢!于是刚刚返校的我们就又迎来了一次测试。

   考试难度:队列;出题人:Cansult,Slr,Milky-way。

   当然这个难度是不用信的,因为它并不靠谱...

  T1:宽嫂的小裙子

  题意概述:Cansult得到了一块m*n的布,要把它裁成一个个正方形做裙子,还要对每一块剪开的布进行锁边(只锁一边就可以),最小化这个代价。

  看起来像个贪心,事实上也是,每次按照最大的裁,裁到裁完为止...然后我就爆0啦!因为没开longlong,果然一个中考过去什么都忘了...

    

# include <cstdio>
# include <iostream>

using namespace std;

int t;
long long a,b,r,ans=0;

int main()
{
    freopen("skirt.in","r",stdin);
    freopen("skirt.out","w",stdout);

    scanf("%d",&t);
    for (int i=1;i<=t;++i)
    {
        ans=0;
        scanf("%lld%lld",&a,&b);
        if(a<b) swap(a,b);
        while (b!=0)
        {
            r=a/b;
            ans+=r*b;
            a=a%b;
            swap(a,b);
        }
        printf("%lld\n",ans);
    }
    fclose(stdin);
    fclose(stdout);
    return 0;
}

skirt

  

   T2:宽嫂的缝纫

  bzoj原题生成树:https://www.lydsy.com/JudgeOnline/problem.php?id=2467

   算是个结论题?首先从每个五边形中都得删掉一条,然后还可以再从任意一个里面删一条...就没啦,可是考试的时候1h也没想出来qwq

  

  T3:宽嫂的初中回忆

  题意概述:给定$a$,$b$,$c$,$k$,求$f[x]^{a}*b+c=x,0<=x<=k$的根的个数;

  当然先打个暴力啦:

   

# include <cstdio>
# include <iostream>

using namespace std;

int t;
long long p;
int a,b,c,k,f,J;
int q[1000000];
int h=0,ans=0;

int main()
{
    freopen("mem.in","r",stdin);
    freopen("mem.out","w",stdout);

    scanf("%d",&t);
    for (int i=1;i<=t;i++)
    {
        scanf("%d%d%d%d",&a,&b,&c,&k);
        ans=0;
        for (int j=0;j<=k;++j)
        {
            f=0;
            J=j;
            while (J)
            {
                f+=J%10;
                J=J/10;
            }
            p=1;
            for (int x=1;x<=a;x++)
                p=(long long)p*f;
            p*=b;
            p+=c;
            if(p==j) ans++,q[++h]=j;
        }
        if(ans==0)
        {
            printf("0\n-1\n");
            continue;
        }
        printf("%d\n",ans);
        for (int j=1;j<=h;j++)
            printf("%d ",q[j]);
        h=0;
        printf("\n");
    }
    fclose(stdin);
    fclose(stdout);
    return 0;
}

mem(40pts)

   正解是枚举$f[x]$,因为$k<=10^{9}$,所以$f[x]$并不会很大。

  T4:宽嫂的军训

  CQOI原题:https://www.luogu.org/problemnew/show/P1627

   打了一个略微优秀的暴力水了80,赛后知道我的写法是枚举i,j,其实可以枚举i,把j的值先存起来,就可以A了,感觉很亏...

   

# include <cstdio>
# include <iostream>

using namespace std;

int t;
long long p;
int a,b,c,k,f,J;
int q[1000000];
int h=0,ans=0;

int main()
{
    freopen("mem.in","r",stdin);
    freopen("mem.out","w",stdout);

    scanf("%d",&t);
    for (int i=1;i<=t;i++)
    {
        scanf("%d%d%d%d",&a,&b,&c,&k);
        ans=0;
        for (int j=0;j<=k;++j)
        {
            f=0;
            J=j;
            while (J)
            {
                f+=J%10;
                J=J/10;
            }
            p=1;
            for (int x=1;x<=a;x++)
                p=(long long)p*f;
            p*=b;
            p+=c;
            if(p==j) ans++,q[++h]=j;
        }
        if(ans==0)
        {
            printf("0\n-1\n");
            continue;
        }
        printf("%d\n",ans);
        for (int j=1;j<=h;j++)
            printf("%d ",q[j]);
        h=0;
        printf("\n");
    }
    fclose(stdin);
    fclose(stdout);
    return 0;
}

中位数(80pts)

  

   T5:宽嫂的水晶项链

   usaco原题:https://www.luogu.org/problemnew/show/P3143

   首先从前往后扫,维护一个以i结尾的区间内,可以放到一条裙子上的最多项链,再倒着扫一次,枚举断点即可。

   

# include <cstdio>
# include <iostream>
# include <algorithm>

using namespace std;

long long rf,rx,a[500005],k;
int n;
int dp1[500005],dp2[500005];
char rc;

long long read()
{
    rc=getchar();
    rf=1;
    rx=0;
    while (!isdigit(rc))
    {
        if(rc==‘-‘) rf=-rf;
        rc=getchar();
    }
    while (isdigit(rc))
    {
        rx=(rx<<3)+(rx<<1)+(rc^48);
        rc=getchar();
    }
    return rx*rf;
}

int main()
{
    freopen("crystal.in","r",stdin);
    freopen("crystal.out","w",stdout);

    scanf("%d%lld",&n,&k);
    for (int i=1;i<=n;i++)
        a[i]=read();
    sort(a+1,a+1+n);
    int j=1;
    for (int i=1;i<=n;i++)
    {
        while (a[i]-a[j]>k) j++;
        dp1[i]=max(i-j+1,dp1[i-1]);
    }
    j=n;
    for (int i=n;i>=1;i--)
    {
        while (a[j]-a[i]>k) j--;
        dp2[i]=max(j-i+1,dp2[i+1]);
    }
    int ans=0;
    for (int i=1;i<=n;i++)
        ans=max(ans,dp1[i]+dp2[i+1]);
    cout<<ans;

    fclose(stdin);
    fclose(stdout);
    return 0;
}

crystal

  

  T6:宽嫂的学妹

  题意概述:有n块积木,每块积木的高度给出,搭两座塔,要求高度一致,求最大高度

  考到最后没有时间了,就写了一个大爆搜:

  

# include <cstdio>
# include <iostream>

using namespace std;

int n;
int ans=0;
int a[10005];
int s[10005];

void dfs(int x,int l,int r)
{
    if(x==n+1)
    {
        if(l==r) ans=max(ans,l);
        return ;
    }
    if(l+s[x]<r) return;
    if(r+s[x]<l) return;
    dfs(x+1,l+a[x],r);
    dfs(x+1,l,r+a[x]);
    dfs(x+1,l,r);
}

int main()
{
//    freopen("cxy.in","r",stdin);
//    freopen("cxy.out","w",stdout);

    scanf("%d",&n);
    for (int i=1;i<=n;i++)
        scanf("%d",&a[i]);
    for (int i=n;i>=1;i--)
        s[i]=s[i+1]+a[i];
    dfs(1,0,0);
    if(ans==0)
        printf("Impossible");
    else
        printf("%d",ans);

//    fclose(stdin);
//    fclose(stdout);
    return 0;
}

cxy(40pts)

  

  

  

  

  

  

原文地址:https://www.cnblogs.com/shzr/p/9206312.html

时间: 2024-08-04 11:56:27

学长学姐们的测试-2的相关文章

【51CTO学院三周年】我和老师和学长学姐们不得不说的故事

事情从2014年的某一天说起,不小心认识了三个字互联网,让我对这个世界有了新的看法,直至现在我成为互联网行业中的一员,我觉得一切都是缘分吧,在接触的过程中,认识一群我都不知道他们再干什么的,他们是做什么的朋友,在他们的介绍下,明白了程序,编程,计算机,等等,慢慢的才有后面的故事.... 在和朋友们的接触过程中,我认识了PHP,JAVA,Html,CSS,js等等,在认识的过程中,我发现了至少目前来说我没有讨厌的事情,编写程序,将现实的世界,写进一行一行的代码中.作为一个小白很明白在学习的过程中是

学姐学长们的测试

2018-5-26 学长学姐们决定给我们来一次测试.(milky-way,zzzyc,xMinh) 这次考试总结一下就是把能想到的错误全犯了一遍... T1:最小子段和 给定n个数,选出连续且非空的一段,使得子段和最小.内存:3MB 做这道题的时候不知道怎么想的,以为3MB只能开4个int,于是就爆了int,发现的时候已经交上去不能改了.只得了40,白丢了60分... 这道题我的做法很奇怪,是把所有数都取反后做最大子段和,最后输出时再取反. # include <cstdio> # inclu

Vijos1901 学姐的钱包

描述 学姐每次出门逛街都要带恰好M元钱, 不过她今天却忘记带钱包了.可怜的doc只好自己凑钱给学姐, 但是他口袋里只有一元钱.好在doc的N位朋友们都特别有钱, 他们答应与doc作一些交换.其中第i位朋友说:如果doc有不少于Ri元钱,doc可以把手上所有的钱都给这位朋友,并从这位朋友手中换回Vi元钱,但是这次交换会浪费Ti的时间.doc希望可以在最短的时间内换到M元钱(其实是可以大于M的, 因为doc可以存私房钱呢), 否则学姐会生气的! 格式 输入格式 输入数据第一行给定T, 表示总的询问次

2014.11.12模拟赛【美妙的数字】| vijos1904学姐的幸运数字

美妙的数字(number.c/.cpp/.pas) 题目描述 黄巨大认为非负整数是美妙的,并且它的数值越小就越美妙.当然0是最美妙的啦. 现在他得到一串非负整数,对于每个数都可以选择先对它做二进制非运算(模二意义下0.1互换,注意前导0也要交换),然后在任意相邻的两个数之间插入二进制与.二进制或,或者二进制异或.现在他想知道这样计算完产生的最美妙的数字是多少. 一共T组数据.对于每组数据,第一行一个n,表示这组数据中一串数有多少个.下面n个非负整数,表示这串数. 样例输入 2 2 3 6 3 1

卿学姐与魔法(优先队列)

个人心得:思路很简单,不过就是会超时,而且直接用数组的话肯定不够大. 所以就用优先队列,让里面只装N个数就好了,然后再次添加时进行比较,比他小就放进去. 不过这样超时,所以先将A,B排序,然后只要比队首大就break就可以过了. 1 #include<iostream> 2 #include<cstdio> 3 #include<cstring> 4 #include<string> 5 #include<queue> 6 #include<

A - 卿学姐与公主(线段树+单点更新+区间极值)

A - 卿学姐与公主 Time Limit: 2000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 某日,百无聊赖的卿学姐打开了某11区的某魔幻游戏 在这个魔幻的游戏里,生活着一个美丽的公主,但现在公主被关押在了魔王的城堡中. 英勇的卿学姐拔出利刃冲向了拯救公主的道路. 走过了荒野,翻越了高山,跨过了大洋,卿学姐来到了魔王的第一道城关. 在这个城关面前的是魔王的精锐部队,这些士兵

qwb与学姐 (带秩并查集)

qwb与学姐 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 149  Solved: 54[Submit][Status][Web Board] Description qwb打算向学姐表白,可是学姐已经受够了他的骚扰,于是出了一个题想难住他:已知一幅n个点m条边的无向图,定义路径的值为这条路径上最短的边的长度,现在有 k个询问,询问从A点到B点的所有路径的值的最大值.qwb听完这个问题很绝望啊,聪明的你能帮帮他吗? Input 一组数据.第一行三

vijosP1903学姐的实习工资

描述 学姐去实习了, 一共实习了N天, 每一天都可以得到实习工资V[i], 这里V[1..N]被看作是整数序列.因为学姐很厉害, 所以V[1..N]是不下降的.也就是说学姐每天的工资只会越来越多, 不会变少.然而遗憾的是, 偷懒的学姐只记下来了其中M天的收入.第A[1]天获得了的工资为B[1].第A[2]天获得了的工资为B[2].第A[3]天获得了的工资为B[3]....第A[M]天获得了的工资为B[M].其中A[]是递增的.好在她记下来了第一天和第N天的收入. 也就是说A[1]=1, A[M]

qwb与学姐

qwb与学姐 Time Limit: 1 Sec  Memory Limit: 128 MB Description qwb打算向学姐表白,可是学姐已经受够了他的骚扰,于是出了一个题想难住他:已知一幅n个点m条边的无向图,定义路径的值为这条路径上最短的边的长度,现在有 k个询问,询问从A点到B点的所有路径的值的最大值.qwb听完这个问题很绝望啊,聪明的你能帮帮他吗? Input 一组数据.第一行三个整数n,m,k (1<=N<=50000,m<=200000,k<=100000).