2023csp-j第一,二题总结

第一题 小苹果

总结

1,考试时对题目理解不透彻,推导方法错误。

2,耗费时间太多,考场经验不足。

3,代码调试能力有待加强。

4,思路不够清晰。

题目描述

小 Y 的桌子上放着 n 个苹果从左到右排成一列,编号为从 1 到 n。

小苞是小 Y 的好朋友,每天她都会从中拿走一些苹果。

每天在拿的时候,小苞都是从左侧第 1 个苹果开始、每隔 2 个苹果拿走 1 个苹果。随后小苞会将剩下的苹果按原先的顺序重新排成一列。

小苞想知道,多少天能拿完所有的苹果,而编号为 n 的苹果是在第几天被拿走的?

输入格式

输入的第一行包含一个正整数 n,表示苹果的总数。

输出格式

输出一行包含两个正整数,两个整数之间由一个空格隔开,分别表示小苞拿走所有苹果所需的天数以及拿走编号为 n 的苹果是在第几天。

【数据范围】

对于所有测试数据有:1≤n≤10^9。

测试点n≤特殊性质
1∼210
3∼510^3
6∼710^6
8∼910^6
1010^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;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2023 csp-j入门级第一轮试题是中国计算机科学会议(CSP)针对初学者设计的一道题。根据题目的具体要求,试题内容可能涉及算法、编程语言、数据结构等方面的知识。 对于这样的试题,学生们需要运用自己所学的知识和技能,通过编程实现题目要求。例如,可能需要设计一个算法来解决一个具体的问题,或者使用特定的数据结构来组织和处理数据。 为了完成这样的试题,学生们首先需要理解题目的要求和限制条件,确保对题目中涉及的概念和术语有所了解。接下来,他们需要分析问题,确定解决问题的方法和步骤。在实际编程实现时,可以选择合适的编程语言和工具,并按照题目要求进行编码。 在完成编码后,学生们需要进行测试和调试,确保程序能够正确运行并得到正确的结果。在测试过程中,可以使用一些已知的测试用例来验证程序的正确性,并对程序进行优化,以提高其性能。 最后,将代码提交,并等待评审结果。评审过程可能涉及代码质量、算法复杂度、正确性等方面的考量。根据评审结果,学生们可以了解自己的编程水平和不足之处,并进行相应的学习和提高。 总体来说,解答2023 csp-j入门级第一轮试题需要学生在编程基础上运用算法和数据结构的知识,进行问题的分析和解决。通过这样的学习和实践,学生们可以提高自己的编程能力,并逐渐成长为优秀的程序员。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值