java面向对象和常用类练习题(StringBuffer、Data、GregorianCalendar、SimpleDateFormat等练习)

1、在控制台输入一个字符串,判断该字符串是否对称。

import java.util.Scanner;

public class JiaoHuan {
    public static void main(String[] args) {

        System.out.println("输入:");
        Scanner scanner = new Scanner(System.in);
        String s = scanner.nextLine();
        StringBuffer sd = new StringBuffer(s);
        String s1 = sd.reverse().toString();
        System.out.println(s1.equals(s));
    }
}

在这里插入图片描述

2、编写一个程序,将下面的一段文本中的各个单词的字母顺序翻转, “To be or not to be”,将变成"oT eb ro ton ot eb"。


public class Nizhuana {
    public static void main(String[] args) {

        String s = "To see sf fs asdsa";
        String[] s1 = s.split(" ");
        StringBuffer sd = new StringBuffer();
        for (int i = 0; i < s1.length; i++) {
            String sdf = new StringBuffer(s1[i]).reverse().toString();
            sd.append(sdf);
            sd.append(" ");

        }
        System.out.println(sd);
    }
}

在这里插入图片描述

3、设计一个数组工具类,其中有两个方法,第一个方法用以随机生成一个长度为10的整型数组,数组中的元素是1~100之间的随机整数,且不允许重复。第二个方法用以对给定整型数组从小到大排序。在main方法中生成数组,并给数组排序。

import java.util.Arrays;
import java.util.Random;

public class Suiji {
    public static void main(String[] args) {

        int[] asd = new int[10];
        Random ran = new Random();
        for (int i = 0; i < asd.length; i++) {
            int a = ran.nextInt(101);
            boolean f = false;
            for (int j = 0; j < asd.length; j++) {
                if(a == asd[j]){
                    f = true;
                    break;
                }
            }
            if(f){
                continue;
            }
            asd[i] = a;

        }
        System.out.println(Arrays.toString(asd));

        //排序
        for (int i = 0; i < asd.length-1; i++) {
            for (int j = 0; j < asd.length-1-i; j++) {
                if (asd[j]>asd[j+1]){
                    int temp = asd[j];
                    asd[j] = asd[j+1];
                    asd[j+1] = temp;
                }
            }

        }
        System.out.println(Arrays.toString(asd));
    }
}

在这里插入图片描述

4、设计一个时间工具类,提供时间转特定格式字符[2042-1-23 10:8:30 上午 星期四]的方法。

方法一:

 public static void main(String[] args) {
        GregorianCalendar gre = new GregorianCalendar();
        //日期
        int i = gre.get(Calendar.YEAR);//年
        int i2 = gre.get(Calendar.MONTH);//月
        int i1 = gre.get(Calendar.DAY_OF_MONTH);//日

        //时间:
        int i3 = gre.get(Calendar.HOUR_OF_DAY);//24小时制
        int i4 = gre.get(Calendar.MINUTE);//分
        int i5 = gre.get(Calendar.SECOND);//秒
        int i6 = gre.get(Calendar.AM_PM);//上午下午

        //星期
        int i7 = gre.get((Calendar.DAY_OF_WEEK));//星期
        String[] aps = {"上午:  ","下午:  "};
        String[] weeks = {"星期日","星期一","星期二","星期三","星期四","星期五","星期六"};
        //日期
        String time = i + "年" + (i2+1)+ "月" + i1 +"日  ";//日期
        String time_1 = i3+"时"+i4+"分"+i5+"秒  ";//时间

        String date_1 = time+aps[i6]+time_1+weeks[i7];
        System.out.println(date_1);
    }

方法二:

import java.text.SimpleDateFormat;
import java.util.Date;
public class Shijian {
    public static void main(String[] args) {
        Date date = new Date();
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss E");
        String format = sdf.format(date);
        System.out.println(format);
    }
}

在这里插入图片描述

5、设计一个字符串工具类,其中有两个方法,第一个方法用以随机生成一个长度为100的字符串,字符串只包含大写或小写字母。第二个方法用以打印出给定字符串中各个大写字母的个数。在main方法中生成字符串,并统计各个大写字母的个数。

import java.util.Arrays;
import java.util.Random;

public class SuijiLetter {
    public static void main(String[] args) {

        Random random = new Random();
        char[] ad = new char[100];
        int i =0;
        for(;;){
            int r = random.nextInt(128);
            if(Character.isLetter(r)){
                ad[i] = (char)r;
                i++;
                if(i>=ad.length){
                    break;
                }
            }
        }
        System.out.println(Arrays.toString(ad));

        for (int j = 0; j < ad.length; j++) {
            boolean sa = false;
            for (int k = 0; k < j; k++) {
                if (ad[j] == ad[k] ) {
                    sa = true;
                    break;
                }
            }

            if(sa){
                continue;
            }
            int sum = 0;
            if(Character.isUpperCase(ad[j])){
                for (int k = j; k < ad.length; k++) {
                    if (ad[j] == ad[k]) {
                        sum++;
                    }
                }
                System.out.println("字符:"+ad[j]+"  个数:"+sum);
            }
        }
    }
}

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

黎明之道

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

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值