大家好😃,我是想要慢慢变得优秀的向阳🌞同学👨💻,断更了整整一年,又开始恢复CSDN更新,从今天开始更新备战蓝桥30天系列,一共30天,如果对你有帮助或者正在备战蓝桥杯的小伙伴可以支持一下哦!~不能说肯定是干货,但会让你有所收获!💓💓💓
一个普普通通的人,生在一个普普通通的家庭,上了一个普普通通的大学,却发现想要普普通通过完一辈子是一件非常不普通的事情 🥺 🥺 🥺
🍭 🍭 我们总是在生活扮演各种角色,却唯独很少扮演自己 🍭 🍭
数的分解 - 蓝桥云课 (lanqiao.cn)
思路1:这道题完全可以暴力解决,暴力就是三个从1到2019循环,循环出三个数,用一个函数来判断这三个数是否含有2,4,并且不相等,满足就让答案+1,最后因为有重复的问题,需要乘以3个数的全排列的情况就是3的阶乘,3!=6,很简单不懂可以搜一搜,一搜全都是这种解法。
思路2:有一个简单的数学角度可以极大的优化这道题,首先题目告诉我们要分解成 3个各不相同的正整数,正整数是不含0的,各不相同说明他们一定要有顺序
最简单的就是要让每次循环的i,j,k满足i<j<k,而且因为答案求的数是死的,完全可以用变量2019-i-j得出k,少一次循环。
而且因为i最小所以最大只能2019/3-1,2019/3的时候同时要满足条件是不可能的,因为大家都是j和k也要是2019/3三个数都相等了,所以i极限情况就是2019/3-1。
当i最小取1的时候,j最大只能取2019/2-1,举个例子如果把2019换成50那么就是1+24+25这样排列才可以,j最大就是取50/2-1=24,这些东西第一次不知道很正常,以后记住就行了,会用就行
public static void main(String[] args){
int ans = 0;
for (int i = 1; i <= 2019/3-1; i++) {
for (int j = i+1; j <= 2019/2-1; j++) {
int k = 2019 - i - j;
//由于前面j=i+1已经决定i和j的有先后顺序了,但k不能保证,就需要再单独判断协议
if(k <= j) continue;
if(check(i) && check(j) && check(k)) ans++;
}
}
System.out.println(ans);//40785
}
//这个是非常经典的一个取余再除得到一个整数每个位的位数
public static boolean check(int n){
while(n > 0){
if(n % 10 == 2 || n % 10 == 4) return false;
n/=10;
}
return true;
}
猜生日 - 蓝桥云课 (lanqiao.cn)
思路:暴力模拟就行了,没啥好说的,根据题目的条件一个一个特判,最后得到的就是答案
public static void main(String[] args) {
for (int i = 19000000; i <= 20120312; i++) {
String month = String.valueOf(i).substring(4,6);//substring这个是左闭右开区间[4,6)其实就只能取到4和5,而且这个函数是认为字符串初始位置从0开始的
int day = Integer.parseInt((i+"").substring(6));//i+""空字符串会会发生自动类型提升,最后得到的是字符串类型,substring也可以只给个开始位置,后面不写就是到字符串最后停止,这里就是取到了6,7
if(i % 2012 == 0 && i % 3 == 0 && i % 12 == 0 && month.equals("06") && day <=30){
System.out.println(i);
break;
}
}
}
成绩统计 - 蓝桥云课 (lanqiao.cn)
思路:没什么难的,主要考察你输出形式和对四舍五入的理解,这种简单但不常注意的地方,一定要留心,不要到了考场不会了就完蛋了
static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
public static void main(String[] args) throws IOException {
int n = Integer.parseInt(br.readLine());
int sum = 0;
int yx = 0;
int jg = 0;
for (int i = 0; i < n; i++) {
int tmp = Integer.parseInt(br.readLine());
if(tmp >=60 && tmp < 85) jg++;
if(tmp >= 85) yx++;
sum++;
}
//在printf中两个%%代表一个%,%.0f表示保留0位小数的浮点数,乘以100.0是为了把整型给自动转换为浮点数类型
System.out.printf("%.0f%%\n%.0f%%",100.0*(jg+yx)/sum,100.0*yx/sum);
}
在printf中%.0f会自动四舍五入