既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
二.max和min
1.例题ABC
【题目描述】
三个整数分别为 A,B,CA,B,C。这三个数字不会按照这样的顺序给你,但它们始终满足条件:A < B < CA<B<C。为了看起来更加简洁明了,我们希望你可以按照给定的顺序重新排列它们。
【输入格式】
第一行包含三个正整数 A,B,CA,B,C,不一定是按这个顺序。这三个数字都小于或等于 100100。第二行包含三个大写字母 AA、BB 和 CC(它们之间没有空格)表示所需的顺序。
【输出格式】
在一行中输出 AA,BB 和 CC,用一个 (空格)隔开。
输入输出样例
输入
1 5 3
ABC
输出
1 3 5
输入 #2
6 4 2
CAB
输出 #2
6 2 4
(1)题目解析
第一行:输入三个数x、y、z,这三个数不一定有序,我们设A为当中(x,y,z中)最小的,C为最大的,B为剩下的那个(非最小非最大)。)
现在你手里有ABC三个数了
第二行:输入ABC三个字母(任意顺序),输出对应的ABC(就是上一行那三个数)
//感谢 Lucaster_ 的翻译
(2)参考答案
#include<iostream>
using namespace std;
int a,b,c,i,x,y,z,sum;
char ch;
int main()
{
cin>>x>>y>>z;
sum=x+y+z;
a=min(min(x,y),z);
c=max(max(x,y),z);
b=sum-a-c;
for(i=1;i<=3;i++)
{
cin>>ch;
if(ch=='A') cout<<a<<' ';
if(ch=='B') cout<<b<<' ';
if(ch=='C') cout<<c<<' ';
}
return 0;
}
2.用法解释
我们上一《难题》用了一个很难的方法—— max and min
a=min(min(x,y),z);
c=max(max(x,y),z);
我们看一下这两条代码,再分解以下
int aa,cc,a,c;
int x,y,z;
aa=min(x,y);
a=min(aa,z);
cc=max(x,y)
c=max(cc,z);
首先解释以下min
比如aa=min(x,y),意思就是aa=x和y中小的一个
若x=10,y=8,aa=min(x,y),则aa=y //8
反之,max就是取大的
若x=10,y=8,aa=max(x,y),则aa=x //10
然后我们把新的知识联系到老知识里边
aa=min(x,y);
就等于
if(x>y) aa=y;
else aa=x;
aa=max(x,y);
就等于
if(x>y) aa=x;
else aa=y;
而第三题的那段代码就不用我解释了吧?
3.拓展用法
刚刚讲述了max 和 min 的基本用法,而max 和 min可以用以下函数解释(新手可以忽略)
int max(int a, int b)
{
return (a > b ? a : b);
}
int min(int a, int b)
{
return (a < b ? a : b);
}
(据有些博主说,使用max函数首先需要有algorithm的头文件,可是我是用iostream也能通过编译???)
接着就是要讲一讲JYqwq博主评论的
“事实上C++11中max(max(a,b),c)可以直接写成max({a,b,c})”
即传入多个参数,必须要用{}包起来
#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
cout << max({ 1, 2, 3, 4, 5 }) << endl; //判断1 2 3 4 5哪个大
return 0;
}
我想大家都应该知道1 2 3 4 5哪个大(6更大)
则再看看大佬的评论中 max(max(a,b),c)可以直接写成max({a,b,c})
前者是先判断a,b哪个大,大的再和c比较
而max({a,b,c}),则是直接判断a,b,c哪个大,结果相同
三.switch语句
标switch的结构题
1.switch和if语句的区别
在一些程序编写中绝对少不了判断语句。
如下面这个用if的简单的判断结构:
#include<iostream>
using namespace std;
int main()
{
int sum;
cin>>sum;
if(sum==1)
{
cout << "关注" << endl;
}
else if (sum==2)
{
cout << "关注+收藏" << endl;
}
else
{
cout << "关注+收藏+点赞" << endl;
}
return 0;
}
这种表达比较复杂(复杂?),我们还有一种更为简单的表达方式(简单?)
这个结构就是switch,仍然是大佬JYqwq
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-qYLnk2je-1715798505398)]
[外链图片转存中…(img-vwe8Zu0G-1715798505398)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!