• do-exercise-淘宝网店


    问题描述

    NowCoder在淘宝上开了一家网店。他发现在月份为素数的时候,当月每天能赚1元;否则每天能赚2元。
    现在给你一段时间区间,请你帮他计算总收益有多少。

    输入描述

    输入包含多组数据。

    每组数据包含两个日期from和to (2000-01-01 ≤ from ≤ to ≤ 2999-12-31)。

    日期用三个正整数表示,用空格隔开:year month day。

    输出描述

    对应每一组数据,输出在给定的日期范围(包含开始和结束日期)内能赚多少钱。

    题目链接:淘宝网店

    思路分析

    首先关于该问题的输入,主要有这样几种情况:

    1. 起始年份与结束年份在同一年,仅计算相隔的日期数即可;
    2. 起始年份与结束年份不在同一年,需要计算起始年份剩下的日期得到的收益、结束年份与起始年份之间的每一年全年的收益、结束年份至今的收益三部分;

    另外还要注意几个特殊点:

    1. 当遇到闰年时,2月需要多加一天;
    2. 收益包括起始日期和结束日期当天的收益;

    所以,这个问题实际就分成了几个部分,即几个方法,

    1. 闰年的判断;
    2. 素数月份的查找;
    3. 收益计算;

    下面是具体的代码实现:

    代码实现

    
    
    import java.util.Scanner;
    
    public class Main {
        //判断是否为闰年
        private static boolean isLeapYear(int year){
            return year%400==0||(year%4==0&&year%100!=0);
        }
        //计算某一年全年的收益,如果是闰年,需要多加一天
        private static int profitYear(int Year){
            return  2 * 31+
                    1 * 28+
                    1 * 31+
                    2 * 30+
                    1 * 31+
                    2 * 30+
                    1 * 31+
                    2 * 31+
                    2 * 30+
                    2 * 31+
                    1 * 30+
                    2 * 31+
                    (isLeapYear(Year)?1:0);
        }
        //查询月份是否为素数月份;
        private static boolean isPrime(int month){
            return month==2||month==3||month==5||month==7||month==11;
        }
    
        private static int profitOfYear(int year,int month,int day){
            int profit=0;
            //素数月份每天的收益为1,非素数月份每天的收益为2
            if(!isPrime(month)){
                profit=day*2;
            }else{
                profit=day;
            }
            //循环计算每个月的收益
            while (--month>0){
                switch (month){
                    case 1:
                    case 8:
                    case 10:
                    case 12:
                        profit+=(2*31);
                        break;
                    case 4:
                    case 6:
                    case 9:
                        profit+=(2*30);
                        break;
                    case 3:
                    case 5:
                    case 7:
                        profit+=(1*31);
                        break;
                    case 11:
                        profit+=30;
                        break;
                    case 2:
                        profit+=28+(isLeapYear(year)?1:0);
                        break;
                }
            }
            return profit;
        }
        public static void main(String[] args) {
            int year1,month1,day1;
            int year2,month2,day2;
            int profit=0;
            Scanner scanner=new Scanner(System.in);
             while (scanner.hasNextInt()){
                year1=scanner.nextInt();
                month1=scanner.nextInt();
                day1=scanner.nextInt();
                year2=scanner.nextInt();
                month2=scanner.nextInt();
                day2=scanner.nextInt();
                //起始年份到下一年剩下的收益
                profit=profitYear(year1)-profitOfYear(year1,month1,day1-1);
                //结束年份的收益
                profit+=profitOfYear(year2,month2,day2);
                //如果起始年份与结束年份是同一年,需要减去多余计算的一整年的收益
                if (year1==year2){
                    profit-=profitYear(year1);
    
                }
                //起始年份与结束年份不是同一年,循环计算起始年份与结束年份之间每一年的收益
                for (int i=year1+1;i<year2;i++){
                    profit+=profitYear(i);
                }
                System.out.println(profit);
    
            }
    
            
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100

    over!

  • 相关阅读:
    rabbitMQ学习-发布和确认
    Sqli-labs靶场第19关详解[Sqli-labs-less-19]自动化注入-SQLmap工具注入
    elementplus DateTimePicker 日期范围选择器 设置默认时间范围为当前月的起始时间到结束时间
    MQ和redis的内部原理一些总结
    推荐,文本转图像,图像转图像运营再也不用担心配图了
    ChatGPT 提问技巧
    Java 8 新特性 Stream API 介绍与使用
    js中this总结
    InnoDB索引机制
    短视频创作应该注意什么问题?
  • 原文地址:https://blog.csdn.net/weixin_54175406/article/details/127694563