网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
唯有热爱,可抵岁月漫长,唯有热爱,不畏世间无常!
新的一年祝你大展宏“兔”
新的一年,大家记得不要忘记刷题(⊙o⊙)?
目录
P1424 小鱼的航程(改进版)
题目背景
题目描述
有一只小鱼,它平日每天游泳 250250 公里,周末休息(实行双休日),假设从周 �x 开始算起,过了 �n 天以后,小鱼一共累计游泳了多少公里呢?
输入格式
输入两个正整数 �,�x,n,表示从周 �x 算起,经过 �n 天。
输出格式
输出一个整数,表示小鱼累计游泳了多少公里。
输入输出样例
输入 #1复制
3 10
输出 #1复制
2000
说明/提示
数据保证,1≤�≤71≤x≤7,1≤�≤1061≤n≤106。
关于题目:
首先,上午游泳150公里,下午游泳100公里,晚上和周末休息,这些条件可以合并成一条:除了周末,其他时间每天游泳250公里。(这样一说就很简单明了了吧。)
如何判断是周末呢?假设小鱼从周n开始游,每游一天就是n+1,那如果n是6或者7,那就证明是周末,反之如果不是6或者7,那么就不是周末,那就要加上250。
最后是最重要的一点,如果现在是周7,那明天就不能是周8了,而是周1,所以当n==7的时候,n应该赋值为1。
对照代码好理解:
A.
#include<bits/stdc++.h>
using namespace std;
int main(){
long long int x,n,m,sum=0;
int s[7]={250,250,250,250,250,0,0};
cin >> x >> n;
m=x;
for(int i=1;i<=n;i++){
sum=sum+s[m-1];
if(m==7){
m=1;
}
else{
m++;
}
}
cout << sum << endl;
}
这是一道非常简单的题目,但同时也是一道非常有意思的题目,看上方代码可知我使用了数组。那有没有其它的方式解决此题呢?答案毫无疑问,是有的!!!
B.
#include<bits/stdc++.h>
using namespace std;
int main()
{
unsigned long long n,ans=0;
int x;
cin >> x >> n; //输入星期和天数
for(int i=0;i<n;i++)
{
if((x!=6)&&(x!=7)) //星期不等于6和7
ans += 250; //总长度增加250
if(x==7) //当x等于7的时候
x=1; // x归1
else //其他情况下(x不等于7)
x++;
}
cout << ans; //输出总路程
return 0;
}
可以看到 B. 题解使用的是简单的加减运算,列出当 x!=6&&x!=7 即可,而 A. 示例代码,使用的数组是在 x6&&x7 是为 0 ,当然共同的思路也都是,列出周六周日休息,并且当周日时,即要从周一开始了,不同的思路,不同的求解过程,但是我们的答案都是正确的!!!
不知道这是否能打开你刷题的思路呢?
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
21091727)]
[外链图片转存中…(img-e24z6uXv-1715621091727)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新