当前位置: 首页 > article >正文

【Java版oj】day10 井字棋、密码强度等级

目录

 一、井字棋

(1)原题再现

(2)问题分析

(3)完整代码

 二、密码强度等级

(1)原题再现

(2)问题分析

(3)完整代码


 一、井字棋

(1)原题再现

井字棋_牛客题霸_牛客网

描述

        给定一个二维数组board,代表棋盘,其中元素为1的代表是当前玩家的棋子,0表示没有棋子,-1代表是对方玩家的棋子。当一方棋子在横竖斜方向上有连成排的及获胜(及井字棋规则),返回当前玩家是否胜出。

测试样例:

[[1,0,1],[1,-1,-1],[1,-1,0]]

返回:true

(2)问题分析

        这道题很简单,只是到入门题,只需要用for循环把所有情况列出来即可。

(3)完整代码

import java.util.*;
public class Board {
    public boolean checkWon(int[][] board) {
        // write code here
        int cow = board.length;
        int lis = board[0].length;
        int cnt = 0;
        for (int i = 0; i < cow; i++) { //求行符合的情况
            cnt = 0;
            for (int j = 0; j < lis; j++) {
                if (board[i][j] == 1) {
                    cnt++;
                }
            }
            if (cnt == lis) {
                return true;
            }

        }
        for (int i = 0; i < lis; i++) { //求列符合的情况
            cnt = 0;
            for (int j = 0; j < cow; j++) {
                if (board[i][j] == 1) {
                    cnt++;
                }
            }
            if (cnt == cow) {
                return true;
            }

        }
        for (int i = 0; i < cow; i++) { //求对角线符合的情况

            for (int j = 0; j < lis; j++) {
                if (i == j && board[i][j] == 1) {
                    cnt++;
                }
            }
            if (cnt == cow) {
                return true;
            }

        }
        for (int i = 0; i < cow; i++) { //求对角线符合的情况

            for (int j = 0; j < lis; j++) {
                if (i == j + cow - 1 && board[i][j] == 1) {
                    cnt++;
                }
            }
            if (cnt == cow) {
                return true;
            }

        }
        return false;
    }
}

 二、密码强度等级

(1)原题再现

密码强度等级__牛客网


密码按如下规则进行计分,并根据不同的得分为密码进行安全等级划分。

一、密码长度:
5 分: 小于等于4 个字符
10 分: 5 到7 字符
25 分: 大于等于8 个字符

二、字母:
0 分: 没有字母
10 分: 密码里的字母全都是小(大)写字母
20 分: 密码里的字母符合”大小写混合“

三、数字:
0 分: 没有数字
10 分: 1 个数字
20 分: 大于1 个数字

四、符号:
0 分: 没有符号
10 分: 1 个符号
25 分: 大于1 个符号

五、奖励(只能选符合最多的那一种奖励):
2 分: 字母和数字
3 分: 字母、数字和符号

5 分: 大小写字母、数字和符号

最后的评分标准:
>= 90: 非常安全
>= 80: 安全(Secure)
>= 70: 非常强
>= 60: 强(Strong)
>= 50: 一般(Average)
>= 25: 弱(Weak)
>= 0:  非常弱(Very_Weak)

对应输出为:

VERY_SECURE
SECURE
VERY_STRONG
STRONG
AVERAGE
WEAK
VERY_WEAK

请根据输入的密码字符串,进行安全评定。

注:
字母:a-z, A-Z
数字:0-9
符号包含如下: (ASCII码表可以在UltraEdit的菜单view->ASCII Table查看)
!"#$%&'()*+,-./     (ASCII码:0x21~0x2F)
:;<=>?@             (ASCII码:0x3A~0x40)
[\]^_`              (ASCII码:0x5B~0x60)
{|}~                (ASCII码:0x7B~0x7E)

(2)问题分析

        这题看似复杂,其实只要根据要求,一个一个去解决,还是很容易的。注意每种情况不要遗漏。

(3)完整代码

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String str = sc.next();
        int sum = len(str) + letters(str) + nums(str) + signs(str) + rewards(str);
        if (sum >= 90) {
            System.out.println("VERY_SECURE");
        } else if (sum >= 80 && sum < 90) {
            System.out.println("SECURE");
        } else if (sum >= 70 && sum < 80) {
            System.out.println("VERY_STRONG");
        } else if (sum >= 60 && sum < 70) {
            System.out.println("STRONG");
        } else if (sum >= 50 && sum < 60) {
            System.out.println("AVERAGE");
        } else if (sum >= 25 && sum < 50) {
            System.out.println("WEAK");
        } else {
            System.out.println("VERY_WEAK");
        }
    }
    private static int len(String str) {
        int l = str.length();
        if (l <= 4) {
            return 5;
        } else if (l >= 5 && l <= 7) {
            return 10;
        } else {
            return 25;
        }
    }
    private static int letters(String str) {
        int flagUpper = 0;
        int flagLower = 0;
        for (int i = 0; i < str.length(); i++) {
            if (str.charAt(i) <= 'Z' && str.charAt(i) >= 'A') {
                flagUpper = 1;
            }
            if (str.charAt(i) <= 'z' && str.charAt(i) >= 'a') {
                flagLower = 1;
            }
        }
        if (flagUpper == 1 && flagLower == 1) {
            return 20;
        }
        if ((flagUpper == 1 && flagLower == 0) || (flagUpper == 0 && flagLower == 1)) {
            return 10;
        }
        return 0;
    }
    private static int nums(String str) {
        int numCount = 0;
        for (int i = 0; i < str.length(); i++) {
            if (str.charAt(i) <= '9' && str.charAt(i) >= '0') {
                numCount++;
            }

        }
        if (numCount > 1) {
            return 20;
        }
        if (numCount == 1) {
            return 10;
        }
        return 0;
    }
    private static int signs(String str) {
        int signCount = 0;
        for (int i = 0; i < str.length(); i++) {
            if ((str.charAt(i) <= 0x2F && str.charAt(i) >= 0x21) ||
                    (str.charAt(i) <= 0x40 && str.charAt(i) >= 0x3A) || (str.charAt(i) <= 0x60 &&
                            str.charAt(i) >= 0x5B) || (str.charAt(i) <= 0x7E && str.charAt(i) >= 0x7B)) {
                signCount++;
            }

        }
        if (signCount > 1) {
            return 25;
        }
        if (signCount == 1) {
            return 10;
        }
        return 0;
    }
    private static int rewards(String str) {
        int letter = letters(str);
        int num = nums(str);
        int sign = signs(str);

        if (num >= 10 && letter >= 10 && sign == 0) {
            return 2;
        }
        if (num >= 10 && letter == 10 && sign > 0) {
            return 3;
        }
        if (num >= 10 && letter == 20 && sign > 0) {
            return 5;
        }
        return 0;
    }
}


 

​​


http://www.kler.cn/a/886.html

相关文章:

  • FLASK 上传文件
  • ORACLE-表空间和分区控制
  • 蓝牙BT04-A的使用与相关AT指令
  • 20250112面试鸭特训营第20天
  • 基于springboot+vue的 嗨玩-旅游网站
  • Leetcode - 周赛431
  • 【2023-03-10】JS逆向之美团滑块
  • day1 —— 拿捏1~n的求和问题
  • Java中的异常
  • 《Spring Boot 趣味实战课》读书笔记(二)
  • 【webrtc】ICE 到VCMPacket的视频内存分配
  • 基于GPT-4的免费代码生成工具
  • Qt学习_08_用独立的文件存放样式表
  • Web漏洞-命令执行和代码执行漏洞
  • 百度终于要出手了?文心一言
  • 文心一言发布的个人看法
  • react的基础使用
  • 【每日一题】——网购
  • 双指针 -876. 链表的中间结点-leetcode
  • 【面试题系列】K8S常见面试题
  • 【vue.js】在网页中实现一个金属抛光质感的按钮
  • 有关pytorch的一些总结
  • 今年还能学java么?
  • 面试阿里测开岗失败后,被面试官在朋友圈吐槽了......
  • 多线程案例——阻塞队列
  • HTTP详解