1081. 检查密码 (15) (Java实现,满分通过)

本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能。该网站要求用户设置的密码必须由不少于6个字符组成,并且只能有英文字母、数字和小数点".",还必须既有字母也有数字。

输入格式:

输入第一行给出一个正整数 N(<=100),随后 N 行,每行给出一个用户设置的密码,为不超过80个字符的非空字符串,以回车结束。

输出格式:

对每个用户的密码,在一行中输出系统反馈信息,分以下5种:

  • 如果密码合法,输出“Your password is wan mei.”;
  • 如果密码太短,不论合法与否,都输出“Your password is tai duan le.”;
  • 如果密码长度合法,但存在不合法字符,则输出“Your password is tai luan le.”;
  • 如果密码长度合法,但只有字母没有数字,则输出“Your password needs shu zi.”;
  • 如果密码长度合法,但只有数字没有字母,则输出“Your password needs zi mu.”。
输入样例:
5
123s
zheshi.wodepw
1234.5678
WanMei23333
pass*word.6 
输出样例:
Your password is tai duan le.
Your password needs shu zi.
Your password needs zi mu.
Your password is wan mei.
Your password is tai luan le.
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
		int n = input.nextInt();
		input.nextLine();
		for (int i = 0; i < n; i++) {
			boolean neednum = true, needletter = true, luan = false;
			String password = input.nextLine();
			if (password.length() < 6) {
				System.out.println("Your password is tai duan le.");
				continue;
			} else {
				for (int j = 0; j < password.length(); j++) {
					if (!Character.isLetterOrDigit(password.charAt(j)) && password.charAt(j) != '.') {
						luan = true;
						break;
					} else if (Character.isDigit(password.charAt(j))) {
						neednum = false;
					} else if (Character.isLetter(password.charAt(j))) {
						needletter = false;
					}

				}
				if (luan) {
					System.out.println("Your password is tai luan le.");
					continue;

				} else if (neednum) {
					System.out.println("Your password needs shu zi.");
					continue;
				} else if (needletter) {
					System.out.println("Your password needs zi mu.");
					continue;
				} else {
				}
				System.out.println("Your password is wan mei.");
			}

		}

		input.close();

	}

}
这题有坑,输入n后,缓冲区会有一个换行符,所以这里必须把它处理掉,采用录入但不接收的方式!
再有就是条件判断有点多哈这里采用的是,满足条件就修改其布尔值,不满足就继续执行,到最后一直没有不合理的情况那么就输出完美!一定要注意条件的判断,和布尔值的改变,刚开始做的时候,出现好多次,意料之外的情况,多次调试才解决,这就说明了逻辑严密的重要性!

.JSP内置对象的应用 题量: 1 满分: 100 作答时间:04-10 14:43至04-25 14:43 . 简答题(共1题,100分) 1. (简答题) 实验目的: 1.加深内置对象request,response进行请求响应的处理的理解。 2.掌握使用内置对象session,application实现会话跟踪。 3.掌握JSP的的指令元素,脚本元素,动作元素的使用 实验内容: 项目: 创建6个jsp页面,使用session实现个简单的注册登录的示例。 页面命名如下:reg.jsp, reg-check.jsp, login.jsp, login-check.jsp, success.jsp, failure.jsp。 reg.jsp为注册页面,让用户输入用户名和密码,提交到reg-check.jsp。 reg-check.jsp为注册信息存储页面,将用户的注册信息存储到session对象中。并添加到login.jsp页面的链接。 login.jsp为登录页面,让用户输入用户名和密码,提交到login-check.jsp。 login-check.jsp为登录检查页面,使用request对象获取login.jsp中的用户名和密码,取出注册时session中存储的用户名和密码进行比较,当全部相同时,使用response的sendRedirect()方法转到success.jsp,否则转到failure.jsp。 success.jsp显示登录成功文字。 failure.jsp显示登录失败文字。 项目二: 创建个jspForward.jsp跳转页面,使用Math类的方法生成随机数,编不同跳转情况跳转页面:随机数大于0.5跳转页面forward1.jsp,反之跳转至forward2.jsp。 创建2个跳转页面forward1.jsp和forward2.jsp。 通过浏览器访问jspForward.jsp,查看页面信息。
最新发布
04-25
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值