.任务四:

程序设计思想:利用Math.random()产生一个char类型的字符,再利用for循环是他们相加,最后将他们放在一个消息框中输出。

 

程序流程图:

 

源程序:           package test1;

import java.awt.Color;

import java.awt.Container;

import java.awt.Dimension;

import java.awt.Toolkit;

import java.awt.event.ActionEvent;

import java.awt.event.ActionListener;

import javax.swing.JButton;

import javax.swing.JFrame;

import javax.swing.JLabel;

import javax.swing.JOptionPane;

import javax.swing.JPasswordField;

import javax.swing.JTextField;

//产生一位的字符

public class Test26 extends JFrame

{

public static char Getrandomchar(char a1,char a2)

{

return (char)(a1+Math.random()*(a2-a1+1));

}

//产生6位的验证码;

public static String test()

{

String s="";

char a;

for(int i=0;i<6;i++)

{

a=Getrandomchar('a','z');

s=s+a;

}

return s;

}

public static void main(String[] args) {

//创建登录界面

final String userName = "abc";

final String passwrod = "123";

JFrame jFrame = new JFrame("登陆界面");

Dimension dimension = Toolkit.getDefaultToolkit().getScreenSize();

jFrame.setBounds(((int)dimension.getWidth() - 200) / 2, ((int)dimension.getHeight() - 300) / 2, 400, 200);

jFrame.setResizable(true);

jFrame.setLayout(null);

//jFrame.setForeground(Color.blue);//是背景颜色变为蓝色;

jFrame.getContentPane().setBackground(Color.blue);

//jFrame.getContentPane().setVisible(false);

jFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

//添加标签,内容为“姓名”

JLabel label1 = new JLabel("姓名");

label1.setBounds(10, 10, 100, 30);

jFrame.add(label1);

//添加标签,内容为“密码”

JLabel label2 = new JLabel("密码");

label2.setBounds(10, 40, 100, 30);

jFrame.add(label2);

//添加标签,内容为“验证码”;

JLabel label3 = new JLabel("验证码:");

label3.setBounds(10, 70, 100, 30);

//label3.setForeground(Color.red);

jFrame.add(label3);

//添加标签,并调用产生验证码的函数,并将其作为标签的内容

JLabel label4 = new JLabel(test());

String s;

s=label4.getText();

label4.setBounds(70, 75, 130, 20);

label4.setForeground(Color.red);

jFrame.add(label4);

//输入用户名;

final JTextField text1 = new JTextField();

text1.setBounds(50, 15, 130, 20);

jFrame.add(text1);

//输入密码;

final JPasswordField text2 = new JPasswordField();

text2.setBounds(50, 45, 130, 20);

jFrame.add(text2);

//输入验证码;

final JTextField text3 = new JTextField();

text3.setBounds(150, 75, 130, 20);

jFrame.add(text3);

JButton button1 = new JButton("取消");

button1.setBounds(160, 105, 150, 30);

button1.addActionListener(new ActionListener()

{

public void actionPerformed(ActionEvent e)

{

jFrame.dispose();//关闭程序;

}

});

jFrame.add(button1);

JButton button2 = new JButton("看不清,换一张");

button2.setBounds(300, 75, 150, 20);

button2.addActionListener(new ActionListener()

{

public void actionPerformed(ActionEvent e)

{

text3.setText("");

label4.setText(s);

}

});

jFrame.add(button2);

//检验是否登陆成功;

JButton button = new JButton("登录");

button.setBounds(10, 105, 150, 30);

button.addActionListener(new ActionListener() {

public void actionPerformed(ActionEvent e) {

if(userName.equals(text1.getText()) && passwrod.equals(text2.getText())&&s.equals(text3.getText())) {

JOptionPane.showMessageDialog(null, "登陆成功", "提示", JOptionPane.INFORMATION_MESSAGE);

} else {

JOptionPane.showMessageDialog(null, "错误", "提示", JOptionPane.ERROR_MESSAGE);

text1.setText("");

text2.setText("");

text3.setText("");

label4.setText(test());

}

}

});

jFrame.add(button);

jFrame.setVisible(true);

}

}

程序结果截图:

总结分析:1.在登录时,无法判断验证码是否正确。

          解决方案:直接将产生验证码的程序定义为一个函数,也方便后边的调用。

          2.鼠标单击“取消”是无法关闭程序

          解决方案:在取消的按钮上加了一个动作监听器,如果单击“取消”,便会关闭程序。

任务五:

程序设计思想:利用Math.Random产生一个随机数(1-100),用户在从键盘输入猜的数,再利用while循环,判断是否猜的正确并给出提示信息,每次的输出结果都放在一个消息框中,直到用户猜出正确答案。

 

程序流程图:

 

程序源代码:

             import java.util.Random;

import javax.swing.JOptionPane;

public class Guess {

public static void main(String[] args)

{

String q="猜大了!";

String w="猜小了";

String e="恭喜你,答对了!";

String b;

int z;

int a=new Random().nextInt(100) +1;//产生1-100的随机数;

b=JOptionPane.showInputDialog(null,"输入自己猜的数:",a);//用户输入自己猜的数字;

z = Integer.parseInt(b);//将b转化为int类型;

while(z!=a)//判断输入的数是否与产生的数相同;

{

if(z>a)

{

JOptionPane.showMessageDialog(null,q);

b=JOptionPane.showInputDialog(null,"输入自己猜的数:");//用户输入自己猜的数字;

z = Integer.parseInt(b);//将b转化为int类型;

}

else

{

JOptionPane.showMessageDialog(null,w);

b=JOptionPane.showInputDialog(null,"输入自己猜的数:");//用户输入自己猜的数字;

z = Integer.parseInt(b);//将b转化为int类型;

}

}

JOptionPane.showMessageDialog(null,e);

}

}

程序截图验证:

 

Tutorial 01 4,5题的更多相关文章

  1. [Usaco2008 Dec]Hay For Sale 购买干草[01背包水题]

    Description     约翰遭受了重大的损失:蟑螂吃掉了他所有的干草,留下一群饥饿的牛.他乘着容量为C(1≤C≤50000)个单位的马车,去顿因家买一些干草.  顿因有H(1≤H≤5000)包 ...

  2. hihoCoder #1038 : 01背包(板子题)

    #1038 : 01背包 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励 ...

  3. POJ 3624 Charm Bracelet(01背包裸题)

    Charm Bracelet Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 38909   Accepted: 16862 ...

  4. HDU 2602 Bone Collector(01背包裸题)

    Bone Collector Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

  5. HDU 2602 - Bone Collector - [01背包模板题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 Many years ago , in Teddy’s hometown there was a ...

  6. hdu 2955 Robberies (01背包好题)

    Robberies Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  7. Jam's balance HDU - 5616 (01背包基础题)

    Jim has a balance and N weights. (1≤N≤20) The balance can only tell whether things on different side ...

  8. HDU 2546 饭卡(01背包裸题)

    饭卡 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submiss ...

  9. P1048 采药(洛谷,动态规划递推,01背包原题)

    题目直接放链接 P1048 采药 这题只是01背包+背景故事而已 原题来的 PS:我写了一篇很详细的01背包说明,如果下面ac代码有看不懂的地方可以去看看 对01背包的分析与理解(图文) 下面上ac代 ...

随机推荐

  1. Docker CE部署

    一.概述 Docker 在1.13版本之后,从2017年的3月1日开始,版本命名规则变为如下: 项目 说明 版本格式 YY.MM Stable 每个季度发行 Edge版本 每个月发行 同时Docker ...

  2. Java 8特性

    1. Java8的新特性 1.1. Lambda表达式和函数式接口 最简单的Lambda表达式可以用逗号分隔的参数列表.->符号和功能语句块来表示.示例如下: Arrays.asList( &q ...

  3. Openssl base64命令

    一.简介 对文件件进行base64的编码与解码 二.语法 openssl base64 [-in filename] [-out filename] 三.实例 1.二进制文件与base64编码互转 o ...

  4. Zedboard学习(二):zedboard的Linux下交叉编译环境搭建 标签: 交叉编译linuxzedboard 2017-07-04 23:49 19人阅读

    环境准备 首先肯定是要下载xilinx-2011.09-50-arm-xilinx-linux-gnueabi.bin文件,这是官方提供的linux下交叉编译链安装文件,下载地址为:https://p ...

  5. 最大公约数(gcd)和 最小公倍数(lcm)——辗转相除法

    辗转相除法(又称欧几里得算法)是求最大公因数的算法 要求a,b的最大公约数(a>b),我们可以递归地求b,a%b的最大公约数,直到其中一个数变成0,这时另一个数就是a,b的最大公约数. C++实 ...

  6. Webstorm 10.0.4 配置

    1. 更换为sublime text的keymaps: https://github.com/ekaragodin/idea-sublime-keymap  (idea-sublime-keymap- ...

  7. mvc中图片的保存和显示

    图片保存到网站根目录(例如 D:\www\Web)下 Web 应用程序根目录运算符用“~”表示.注意不是网站根目录(网站根目录是指针对域名计算的) 即便是网站部署在其他网站下(例如IIS中,在A站下( ...

  8. zrender源码分析3--初始化Painter绘图模块

    接上次分析到初始化ZRender的源码,这次关注绘图模块Painter的初始化 入口1:new Painter(dom, this.storage); // zrender.js /** * ZRen ...

  9. UT源码162

    (3)设计佣金问题的程序 commission方法是用来计算销售佣金的需求,手机配件的销售商,手机配件有耳机(headphone).手机壳(Mobile phone shell).手机贴膜(Cellp ...

  10. Servlet 学习总结-1

    JavaWeb应用程序中所有的请求-响应都是由Servlet来完成的.Servlet是Java Web的核心程序,所有的网址(请求-响应)都交给Servlet来处理. Servlet在Web应用中被映 ...