【冲刺蓝桥杯的最后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,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会自动四舍五入

微信扫码订阅
UP更新不错过~
关注
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想要慢慢变得优秀的向阳同学

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值