Java--学习第三天

一.计算日期相差天数

1.中国人民共和国成立是1949年10月1日中午12时,我们现在是2022年3月28日12时;
我们需要使用编程来计算它们中间相差的天数。
2.分析:
①可以利用Java的Date类
②首先创建格式对象
③分别创建两个日期,以指定时间格式
④date.getTime()得到的时毫秒
⑤最后做差相减即可转化为分钟
3.代码如下:

public class Main {
    public static void main(String[] args) throws ParseException {
        SimpleDateFormat s=new SimpleDateFormat("yyyy-mm-dd");
        Date date1=s.parse("1949-10-1");
        Date date2=s.parse("2022-3-28");
        int a=(int)((date2.getTime()-date1.getTime())/(1000*60));
        System.out.println(a);
    }
}
  

4.结果如下:

38433593

二.求斐波那契数列最大公约数

1.斐波那契数列满足 F1 = F2 = 1,从 F3 开始有 Fn = Fn 1 + Fn 2。请你计算
GCD(F2020, F520),其中 GCD(A, B) 表示 A 和 B 的最大公约数。
2.

首先求出两个斐波那契数
可以利用递归求,但是在试验时,采用递归花费时间较长,不建议
两个结果用BigInteger存取,因为使用long会溢出
求最大公约数可以利用欧几里得算法,BigInteger已经包装好,可以直接调用

3.代码如下:

public class Main02 {
    public static void main(String[] args) {
        BigInteger num1 = fib(2020);
        System.out.println(num1);
        BigInteger num2 = fib(520);
        System.out.println(num2);
        System.out.println(num1.gcd(num2));
    }
    public static BigInteger fib(int n){
        BigInteger a=BigInteger.ONE;
        BigInteger b=BigInteger.ONE;
        BigInteger c=BigInteger.ONE;
        if(n<=2){
            return a;
        }
        for(int i=3;i<=n;i++){
            c=a.add(b);
            a=b;
            b=c;
        }
        return c;
    }
}

三.分类计数

输入一个字符串,请输出这个字符串包含多少个大写字母,多少个小写字母,多少个数字。
【输入格式】
输入一行包含一个字符串。
【输出格式】
输出三行,每行一个整数,分别表示大写字母、小写字母和数字的个数。
【样例输入】
1+a=Aab
【样例输出】
1
3
1
2.代码如下:

/**
 * 功能:分类计数(输入一个字符串,请输出字符串包含多少个大写字母,小写字母,数字,并分行表示)
 * 作者:彼得潘
 * 日期:2022年03月28日
 */
public class Main03 {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        String string=sc.nextLine();
        int a=0,b=0,c=0;
        for(int i=0;i<string.length();i++){
            if(Character.isDigit(string.charAt(i))){
                c++;
            }
            else if(Character.isUpperCase(string.charAt(i))){
                a++;
            }
            else if(Character.isLowerCase(string.charAt(i))){
                b++;
            }
        }
        System.out.println(a);
        System.out.println(b);
        System.out.println(c);
    }
}

3.结果如下:

2+bbb=ASb
2
4
1
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值