当前位置: 首页 > news >正文

【冲刺蓝桥杯的最后30天】day5

大家好😃,我是想要慢慢变得优秀的向阳🌞同学👨‍💻,断更了整整一年,又开始恢复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,7if(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会自动四舍五入

http://www.lryc.cn/news/34389.html

相关文章:

  • 大厂与小厂招人的区别,看完多少有点不敢相信
  • 前端ES5对象特性
  • Linux入门介绍及Linux文件与目录结构
  • 超赞,用python实现流媒体服务器功能,寥寥几句搞定。
  • 冥想第七百二十一天
  • 06-Oracle表空间与用户管理
  • Mysql 索引特点
  • 读书笔记-终身学习
  • 了解栈Stack一篇文章就够了
  • CNStack 助推龙源电力扛起“双碳”大旗
  • ruoyi-vue-plus1(控制台相关的输出日志)(p6spy插件)(jackson全局配置)(StopWatch)
  • 【Mybatis】| 如何创建MyBatis的工具类
  • 【Java】DT怎么写?
  • xcode14安装swift package设置github账户token
  • css面试题1
  • Hive基础
  • 信息收集-
  • 【sdx12】sdx12获取Serial Number操作方法及源码分享Serial Number的寄存器地址
  • 23种设计模式-工厂模式(安卓应用场景介绍)
  • sheng的学习笔记-服务熔断与降级组件Hystrix
  • 简单给WordPress怎么添加自定义字段面板
  • 大数据框架之Hive:第6章 查询
  • CentOS 8搭建EMQX集群
  • 基于神经网络的自监督学习方法音频分离器(Matlab代码实现)
  • yocto 如何添加python module
  • [深入理解SSD系列综述 2.1.2] SLC、MLC、TLC、QLC、PLC NAND_固态硬盘闪存颗粒类型
  • Matlab实现FFT变换
  • JVM调优面试题——垃圾回收专题
  • java启动命令中-D和--的区别
  • QML Popup详解