第一题 小苹果
总结
1,考试时对题目理解不透彻,推导方法错误。
2,耗费时间太多,考场经验不足。
3,代码调试能力有待加强。
4,思路不够清晰。
题目描述
小 Y 的桌子上放着 n 个苹果从左到右排成一列,编号为从 1 到 n。
小苞是小 Y 的好朋友,每天她都会从中拿走一些苹果。
每天在拿的时候,小苞都是从左侧第 1 个苹果开始、每隔 2 个苹果拿走 1 个苹果。随后小苞会将剩下的苹果按原先的顺序重新排成一列。
小苞想知道,多少天能拿完所有的苹果,而编号为 n 的苹果是在第几天被拿走的?
输入格式
输入的第一行包含一个正整数 n,表示苹果的总数。
输出格式
输出一行包含两个正整数,两个整数之间由一个空格隔开,分别表示小苞拿走所有苹果所需的天数以及拿走编号为 n 的苹果是在第几天。
【数据范围】
对于所有测试数据有:1≤n≤10^9。
测试点 | n≤ | 特殊性质 |
---|---|---|
1∼2 | 10 | 无 |
3∼5 | 10^3 | 无 |
6∼7 | 10^6 | 有 |
8∼9 | 10^6 | 无 |
10 | 10^9 | 无 |
特殊性质:小苞第一天就取走编号为 n 的苹果。
本题思路
本题因为数据极大,所以注意暴力推导方法。
因为每三个拿走一个只需要减去第一个再除以三加一就是每天拿走的个数。所以只需要一个while循环就可以完成第一问。而对第n个进行标记,如果n%3==1那么就输出当前天数。
AC代码(目前洛谷)
#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,ans,d,pd;
signed main(){
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>n;
while(n){
ans++;
if(&&pd==0){
d=ans;
pd=1;
}
n-=(n-1)/3+1;
}
cout<<ans<<" "<<d;
}
第二题 公路
总结
1,做题量太少,对题目所考内容没有感觉;
2,考虑问题不全,一开始没有想到整数油量会带来剩余的油。
题目描述
小苞准备开着车沿着公路自驾。
公路上一共有 n 个站点,编号为从 1 到 n。其中站点 i 与站点 i+1 的距离为 vi 公里。
公路上每个站点都可以加油,编号为 i 的站点一升油的价格为 ai 元,且每个站点只出售整数升的油。
小苞想从站点 1, 开车到站点 n,一开始小苞在站点 1 且车的油箱是空的。已知车的油箱足够大,可以装下任意多的油,且每升油可以让车前进 d 公里。问小苞从站点 11 开到站点 n,至少要花多少钱加油?
输入格式
输入的第一行包含两个正整数 n 和 d,分别表示公路上站点的数量和车每升油可以前进的距离。
输入的第二行包含 n−1 个正整数1,2…v1,v2…vn−1,分别表示站点间的距离。
输入的第三行包含 n 个正整数 1,2…a1,a2…an,分别表示在不同站点加油的价格。
输出格式
输出一行,仅包含一个正整数,表示从站点 11 开到站点 n,小苞至少要花多少钱加油。
思路
本题主要考查贪心思想,首先,油箱和每一站的油都是无限多的,就可以排除dp和搜索(可以但没必要),所以只要做到下一个站比当前站的油便宜,就买足够多的油前往。
注意事项
因为必须买整数油,所以就要考虑有剩油的情况。
例:1L油走4km路,但到下一个站距离为10km,所以如果买3L油,就会有2km的油剩余,需要特殊考虑。
AC代码
#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,ans,d,tmp=0x3f3f3f3f,a[1000005],v[1000005],c,s;
signed main(){
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>n>>d;
for(int i=1;i<=n-1;i++){
cin>>v[i];
}
for(int i=1;i<=n;i++){
cin>>a[i];
}
tmp=a[1];//初始化
for(int i=1;i<=n-1;i++) {//因为最后一个站点的油价无用,所以只用考虑n-1次
tmp=min(tmp,a[i]);//比较大小
v[i]-=c;//c用来存储多余的油
s=ceil(1.0*v[i]/d);//ceil()向上取整,floor()向下取整
ans+=s*tmp;
c=s*d-v[i];
}
cout<<ans;
return 0;
}