一.井字棋
题目链接:
题目描述:
给定一个二维数组board,代表棋盘,其中元素为1的代表是当前玩家的棋子,0表示没有棋子,-1代表是对方玩家的棋子。当一方棋子在横竖斜方向上有连成排的及获胜(及井字棋规则),返回当前玩家是否胜出。
示例1:
输入:
[[1,0,1],[1,-1,-1],[1,-1,0]]
输出:
true
个人总结:
测试就行了,没啥好说的。
代码实现:
import java.util.*;
public class Board {
public boolean checkWon(int[][] board) {
// write code here
//行列坐标是相反的 一起判断
for (int i = 0; i < board.length; i++) {
int rowSum = 0;
int colSum = 0;
for (int j = 0; j < board[i].length; j++) {
rowSum += board[i][j];
colSum += board[j][i];
}
if (rowSum == 3 || colSum == 3) {
return true;
}
}
//判断斜线
return (board[0][0] + board[1][1] + board[2][2] == 3) ||
(board[0][2] + board[1][1] + board[2][0] == 3);
}
}
二.密码强度等级
题目链接:
题目描述:
密码按如下规则进行计分,并根据不同的得分为密码进行安全等级划分。
一、密码长度:
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)
提示:
1 <= 字符串的长度<= 300
输入描述:
输入一个string的密码
输出描述:
输出密码等级
示例1:
输入:
38$@NoNoN
输出:
VERY_SECURE
说明:
样例的密码长度大于等于8个字符,得25分;大小写字母都有所以得20分;有两个数字,所以得20分;包含大于1符号,所以得25分;由于该密码包含大小写字母、数字和符号,所以奖励部分得5分,经统计得该密码的密码强度为25+20+20+25+5=95分。
示例2:
输入:
Jl)M:+
输出:
AVERAGE
说明:示例2的密码强度为10+20+0+25+0=55分。
个人总结:
今天也是麻木的一天哇敲,它应该是在考验你的韧性,对,是这样的。
代码实现:
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
int[] map = new int[128];
int score = 0;
int len = s.length();
for (int i = 0; i < len; i++) {
map[s.charAt(i)]++;
}
score += (len >= 8 ? 25 : ((len <= 4) ? 5 : 10));
//字母
int lowLetter = 0;
int upLetter = 0;
//数字
int digit = 0;
//其他
int others = 0;
for (int i = 0; i < 128; i++) {
if (i >= 48 && i <= 57 && map[i] != 0) {
digit += map[i];
} else if (i >= 65 && i <= 90 && map[i] != 0) {
lowLetter += map[i];
} else if (i >= 97 && i <= 122 && map[i] != 0) {
upLetter += map[i];
} else {
others += map[i];
}
}
//统计分数
score += (digit > 1 ? 20 : (digit > 0 ? 10 : 0));
score += (lowLetter > 0 ? 10 : 0);
score += (upLetter > 0 ? 10 : 0);
score += (others > 1 ? 25 : (digit > 0 ? 10 : 0));
if (digit != 0 && others != 0 && (lowLetter != 0 && upLetter != 0)) {
score += 5;
} else if (digit != 0 && others != 0 && (lowLetter != 0 || upLetter != 0)) {
score += 3;
} else if (digit != 0 && (lowLetter != 0 || upLetter != 0)) {
score += 2;
}
//输出
if (score >= 90) {
System.out.println("VERY_SECURE");
} else if (score >= 80) {
System.out.println("SECURE");
} else if (score >= 70) {
System.out.println("VERY_STRONG");
} else if (score >= 60) {
System.out.println("STRONG");
} else if (score >= 50) {
System.out.println("AVERAGE");
} else if (score >= 25) {
System.out.println("WEAK");
} else {
System.out.println("VERY_WEAK");
}
}
}