题目编号 标题
0 JABUKE
1 MATRIX
2 PLES
3 金明的预算方案(budget.pas/cpp)
0:
题目描述
Mirko 最近发现了一个古老的游戏。这个游戏的屏幕有N列。在屏幕的底部,有个占M(M<N)列的船。在玩这个游戏的过程中,我们可以左右移动这条船,但是这条船必须时刻完整的在屏幕里面。这条船开始的时候是在最左边的。
有一些苹果从这个屏幕的顶部掉下来,每个苹果会从屏幕N列中的某一列的顶部掉下来,垂直下落直到到达屏幕的底部。当前一个苹果掉落在底部以后,后一个苹果开始下落。
一个苹果被船接到是这么定义的:这条船占有这个苹果掉下来的那一列。我们的目标是接到所有的苹果,在这种情况下,我们要求在所有苹果的掉落过程中,尽量减少船的移动总距离。
输入
第一行包括两个整数N和M(1<=M<N<=10),第二行输入一个整数J,表示苹果的总个数,接下来的J行,每行一个整数,表示相应的苹果掉落在第几列。
输出
输出只有一个整数,代表在所有苹果下落的过程中,我们需要最少的移动船的总距离。
样例输入
5 1
3
1
5
3
样例输出
6
数据范围限制
提示
输入:
5 2
3
1
5
3
输出:
4
这题……
水爆了
#include<iostream>
using namespace std;
int m,n,x1,x,y,t,k;
int main(){
cin>>n>>m;
cin>>t;
x=1;y=m;
for(int i=1;i<=t;i++){
cin>>x1;
if(x1>=x&&x1<=y)continue;
if(x1>y){
k+=(x1-y);
x+=(x1-y);
y=x1;
}
else
if(x1<x){
k+=(x-x1);
y-=(x-x1);
x=x1;
}
}
cout<<k;
return 0;
}
1:
题目描述
总所周知,我们住在一个N*N的方阵(正方形)里面。其中每个小格子中都有一个整数。为了离开这个方阵,我们必须找到最美丽的子方阵。
如果我们定义A为某个方阵主对角线上的和,定义B为某个方阵副对角线上的和,那这个方阵的美丽值就是A-B。
输入
第一行包括一个正整数N(2<=N<=400),表示这个方阵的边长。接下来N行,每行包括N个整数,范围在-1000到1000之间,代表方阵中的各个整数。
输出
只有一行一个整数,表示我们可以找到的最美丽子方阵的美丽值。
(主对角线是从左上角到右下角,副对角线反之。求所有子矩阵美丽值的最大值)
样例输入
如提示
样例输出
如提示
数据范围限制
如题
提示
前缀和+暴力AC
#include<iostream>
using namespace std;
int n,maxx,a[500][500],a1[500][500],a2[500][500];
int main(){
cin>>n;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)cin>>a[i][j];
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
a1[i][j]=a[i][j]+a1[i-1][j-1];
for(int i=1;i<=n;i++)
for(int j=n;j>=1;j--)
a2[i][j]=a[i][j]+a2[i-1][j+1];
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
for(int k=1;i+k-1<=n&&j+k-1<=n;k++){
int x=i,y=j,x1=i+k-1,y1=j+k-1;
int sum=a1[x1][y1]-a1[x-1][y-1];
int sw=y1;
y1=y;
y=sw;
sum=sum-(a2[x1][y1]-a2[x-1][y+1]);
if(sum>maxx)maxx=sum;
}
}
}
cout<<maxx;
return 0;
}