问题 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;
}