表驱动法——直接访问表示例1

Posted tzzt01

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了表驱动法——直接访问表示例1相关的知识,希望对你有一定的参考价值。

《代码大全》看到“表驱动法”一章,以下是表驱动法的第一个方法——直接访问表

 

import java.util.Scanner;
import java.util.Calendar;

class DaysPerMonth {
    public static void main(String[] args) {
        
        System.out.println("输入年份:");
        Scanner scan = new Scanner(System.in);
        String input_year = scan.nextLine();
        int year = Integer.parseInt(input_year);

        System.out.println("输入月份:");
        String input_month = scan.nextLine();
        int month = Integer.parseInt(input_month);

        int days = daysPerMonth(year, month);
        System.out.println( year + " 年 " + month + " 月有 " + days + "天");
    }

    public static int daysPerMonth(int year, int month) {
        
        boolean flag = LeapYearIndex(year);
        System.out.println("是否是闰年?" + flag);

        if(flag) {
            int[] days = {31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
            return days[month-1];
        } else {
            int[] days = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
            return days[month-1];
        }

    }

    public static boolean LeapYearIndex(int year) {
        if ( ( year % 4 == 0 && year % 100 != 0 ) || year % 400 == 0 ) {
            return true;
        } else {
            return false;
        }
    }

}

 

以上是关于表驱动法——直接访问表示例1的主要内容,如果未能解决你的问题,请参考以下文章

C语言精华知识:表驱动法编程实践

C语言表驱动法编程实践(精华帖,建议收藏并实践)

表驱动法

黑盒测试——nextDate函数测试(等价类划分法边界值分析法判定表驱动法)

排序02-直接插入排序法

判定表法测试用例设计