2020-5-4

 

问题 E: 小y的tower

时间限制: 1 Sec  内存限制: 128 MB
[提交] [状态]

题目描述

如果时光回到从前,或许,一切只是虚无
小Y坐着时光穿梭机,到达了一个神奇的三维时空,在这里,开始了ta的梦幻之旅

这是一个神奇的三维世界,ta看到了许多三维立方体,每个立方体都有各自的长、宽、高。现在ta想搭起一个很高很高的tower,送给小L,但是ta非常有心,又希望这个tower有非常的稳定性(众所周知triangle是一个非常有稳定性的结构(大雾)2333)。于是,ta希望放在下面的立方体的长和宽都分别大于(严格大于哦)它上面的立方体的长和宽。现在ta想知道ta究竟能堆出多高的tower。
又由于三维立方体是长方体的,因此你可以把它随意转动,也就是说,它的长、宽、高是可以随意互换的。每种立方体的数量都可认为是无限个,当然,你不可能全部用上。
你能帮助小Y吗?

 

输入

第一行,一个整数n,表示三维立方体的数量。
接下来n行,每行三个整数,表示一个三维立方体的长、宽、高。

输出

一行,一个整数,表示可以堆起的tower的最大高度。

样例输入 Copy

2
4 8 5
2 6 3

样例输出 Copy

18

提示

样例解释
三维立方体表示为(长,宽,高);
则从下到上依次为(8,5,4),(5,4,8),(3,2,6)。
【数据范围】
对于30%的数据,n<=10;
对于60%的数据,n<=30;
对于100%的数据,n<=100。
保证答案不在32位整数内,就是pascal选手的longint以内以及c++或c选手的int内!

#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
struct node
{
  ll a,b,c;
}nd[1000];
ll ans=0,maxa,dis[10000];
int n;
bool cmp(node x,node y)
{
    return x.a<=y.a;
}
int main()
{

    scanf("%d",&n);
    for(int i=1;i<=6*n;i+=6)
    {
        scanf("%lld%lld%lld",&nd[i].a,&nd[i].b,&nd[i].c);
        nd[i+1].a=nd[i].a;nd[i+1].b=nd[i].c;nd[i+1].c=nd[i].b;
        nd[i+2].a=nd[i].c;nd[i+2].b=nd[i].b;nd[i+2].c=nd[i].a;
        nd[i+3].a=nd[i].c;nd[i+3].b=nd[i].a;nd[i+3].c=nd[i].b;
        nd[i+4].a=nd[i].b;nd[i+4].b=nd[i].c;nd[i+4].c=nd[i].a;
        nd[i+5].a=nd[i].b;nd[i+5].b=nd[i].a;nd[i+5].c=nd[i].c;
    }
    ll ans=0;
    sort(nd+1,nd+1+n*6,cmp);
  for(int i=1;i<=6*n;i++)
  {
      dis[i]=nd[i].c;
      for(int j=i-1;j>=1;j--)
      {
          if(nd[j].a<nd[i].a&&nd[j].b<nd[i].b)
            dis[i]=max(dis[i],dis[j]+nd[i].c);
      }
      ans=max(ans,dis[i]);
  }
    printf("%lld",ans);
    return 0;
}

 

 

问题 F: 小y的序列

时间限制: 1 Sec  内存限制: 128 MB
[提交] [状态]

题目描述

又是一年 NOIP,高中机房的学长们都在做题,安静的有点可怕,突然听到隔壁机房某老师熟悉的声音:“我们看一下这道题,找找规律发现这个序列很熟悉啊,就是2,3,5,7,12这其实就是一个a[i+1]-a[i]=i的序列哦,突然隔壁的吵闹声大了起来,老师,老师好像有个数写错了(大雾)~~~~~~~~~~~~ 

课后,小y大牛跑到隔壁机房在黑板上写下了这个题目,让小朋友们做:给出一个长度为n的整数序列a,你能改动最少的数,使之满足a[i+1]-a[i]=i吗?1<=i<n。

 

输入

第一行一个整数n;
第二行包含n个整数(每两个数之间有一个空格),分别表示a[1]到a[n]。

输出

输出一个整数,表示最少改多少个数

样例输入 Copy

5 
1 2 4 5 11

样例输出 Copy

1

提示

对于30%的数据 n<=1000
对于100%的数据 n<=100000
输入的其他数据的绝对值均小于等于1E9

 

https://blog.csdn.net/DaNIelLAk/article/details/105922276  这个写的好,虽然我的思路大同小异,但是我那个不够简单,这个直接将a[i]对应得a[N]找出来,直接map<a[n],cnt>然后就有了。不错不错。

 

#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
const int N=100005;
ll f[N],a[N];
int n;
map<ll,int> mp;

int main()
{

 cin>>n;
   for(int i=1;i<=100000;i++)
        f[i]=f[i-1]+i;
 for(int i=1;i<=n;i++)
    cin>>a[i];
ll kk=n-1; //不然后面会爆
 for(int i=n-1,j=0;i>=1;i--,j++)
 {
     ll sum=kk*(j+1)-f[j]+a[i];
     mp[sum]++;
 }
 int ans=1e9;
 for(auto t:mp)
 {
     ll x=t.first;
     int y=t.second;
     int cnt=n-1-y;
     if(x!=a[n]) cnt++;
     ans=min(ans,cnt);
 }
 cout<<ans;
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值