zoukankan      html  css  js  c++  java
  • 软件工程概论

    |=小学生四则运算=|

    设计思想:

      1 程序生成数据,并存到数据库Mysql;

      2用户输入数据

      3程序接收数据,并判断数据

      4返回信息。

    源程序代码:

    java文件

    package pers.sun.operateion;
    //产生一个算式,及相应的结果
    public class Operated {

       private int resultx;
       private String formulax;
     
     public int getResultx() {
        return resultx;
     }
     
     public void setResultx(int resultx) {
        this.resultx = resultx;
     }
     public String getFormulax() {
        return formulax;
     }
     public void setFormulax(String formula) {
        this.formulax=formula;
     }
     public String calculation() {
      
        int first=(int) (Math.random()*10+1);
        int second=(int) (Math.random()*10+1);
        int op=(int) (Math.random()*4+1);
        char operator = 0;
        switch(op) {
        case 1:operator='+';resultx=first+second;break;
        case 2:operator='-';resultx=first-second;break;
        case 3:operator='*';resultx=first*second;break;
        case 4:operator='/';break;
        }
      //是除
      if(op==4) {
       //分母不为0 且能除尽
       if(second!=0) {
        int res=first%second;
        if(res==0) {
           formulax=first+" "+operator+" "+second+" =";
           resultx=first/second;
        }
        else
           formulax=null;
       }
       else
          formulax=null;
      }
      //不是除
      else {
         formulax=first+" "+operator+" "+second+" =";
      }
        return formulax;
     }
    }

    package pers.sun.operateion;

    import pers.sun.operateion.Operated;
    //产生N个算式,及结果
    public class ApplyIt {

     private int[] result;
     
     public String[] make(int n) {
      //接收的容器
               
      String formulas[]=new String[n];
      result=new int[n];
      
      //产生算式
      Operated opera=new Operated();
      for(int i=0;i<n;) {
       String temp=opera.calculation();
       //判断算式是否为null
       if(temp!=null) {
              
        formulas[i]=temp;
        result[i]=opera.getResultx();
        i++;
       }
      }
      return formulas;
     }
     
     
     public int[] getResult() {
      return result;
     }
     public void setResult(int[] result) {
      this.result = result;
     }
    }

    package pers.sun.sql;

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;

    public class DB {

     public static Connection getConnection() {
      try {
       Class.forName("com.mysql.jdbc.Driver");
      } catch (ClassNotFoundException e) {
       // TODO Auto-generated catch block
       e.printStackTrace();
      }
      String root="root";
      String password="sunyu";
      String url="jdbc:mysql://localhost:3306/user_message";
      
      Connection con=null;
      try {
       con=DriverManager.getConnection(url,root,password);
      } catch (SQLException e) {
       // TODO Auto-generated catch block
       e.printStackTrace();
      }
      
      return con;
     }
     
     public static void close(Connection con) {
      try {
       if(con!=null)
        con.close();
      } catch (SQLException e) {
       // TODO Auto-generated catch block
       e.printStackTrace();
      }
      
     }
     public static void close(PreparedStatement pre) {
      try {
       if(pre!=null)
        pre.close();
      } catch (SQLException e) {
       // TODO Auto-generated catch block
       e.printStackTrace();
      }
     }
     public static void close(ResultSet result) {
      try {
       if(result!=null)
        result.close();
      } catch (SQLException e) {
       // TODO Auto-generated catch block
       e.printStackTrace();
      }
     }
    }

    package pers.sun.sql;

    import java.sql.Connection;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.util.ArrayList;
    import java.util.List;

    import pers.sun.operateion.Operated;

    public class SqlTool {
     
     public static void add(String formula,int result) {
      if(formula!=null) {
       String sql="insert into math(formula,result) value(?,?)";
       Connection connection=DB.getConnection();
       PreparedStatement preparedstatement=null;
       try {
        preparedstatement=connection.prepareStatement(sql);
        preparedstatement.setString(1,formula);
        preparedstatement.setInt(2,result);
        preparedstatement.executeUpdate();
        
       } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
       }finally {
        DB.close(preparedstatement);
        DB.close(connection);
       }
       
      }
     }
     public static void deleted() {
      
     }
     public static List<Operated> search() {
      
      Connection connection=DB.getConnection();
      String sql="select * from math";
      PreparedStatement pre=null;
      ResultSet result=null;
      
      List<Operated> op= new ArrayList<Operated>();
      
      try {
       pre = connection.prepareStatement(sql);
       result=pre.executeQuery();
       while(result.next()) {
        Operated temp=new Operated();
        temp.setResultx(result.getInt("result"));
        temp.setFormulax(result.getString("formula"));
        op.add(temp);
       }
       
      } catch (SQLException e) {
       // TODO Auto-generated catch block
       e.printStackTrace();
      }
      return op;
      
     }
     public static void updata() {
      
     }
    }

    JSP文件

    <%@ page language="java" contentType="text/html; UTF-8"
        pageEncoding="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>计算准备</title>
    </head>
    <body>
     <form action="outputbegin.jsp" method="post">
      <table align="center" border="1" width="100">
       <tr>
       <!-- 没有判断输入的是否为整数 或 不为空 -->
        <td>输入你要做的题</td>
       </tr>
       <tr>
        <td>
         <input type="text" name="number" />
        </td>
       </tr>
       <tr>
        <td>
         <input type="submit" value="确定" name="submit" />
         <input type="reset" value="重置" name="reset" />
        </td>
       </tr>
      </table>
      
     </form>
    </body>
    </html>

    <%@page import="pers.sun.sql.SqlTool"%>
    <%@ page language="java" contentType="text/html; UTF-8"
        pageEncoding="UTF-8"%>
    <%@page import="pers.sun.util.*" %>
    <%@page import="pers.sun.operateion.*" %>
    <%@page import="java.util.*" %>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <!-- 接收用户数字-->
    <html>
    <head>
     <title>算式表格</title>
    </head>
    <body>
    <%
     //接收信息
     int num=Integer.parseInt(request.getParameter("number"));
     ApplyIt apply =new ApplyIt();
     //生成算式+结果
     String[] suanshi=apply.make(num);
     int rightresults[]=apply.getResult();
     
     //写入数据库
     for(int i=0;i<num;i++){
      SqlTool.add(suanshi[i], rightresults[i]);
     }
    %>
     <form action="handle.jsp" method="post">
     <table align="center" border="1" width="500">
      <tr>
       <td>算式</td>
       <td>结果</td>
      </tr>
      <%
       for(String stemp:suanshi){
      %> 
      <tr>
       <td><%=stemp %></td>
       <td><input type="text" value="" name="peoresult" /></td>
      </tr>
      <%
       }
      %>
      <tr>
        <td><input type="submit" value="提交" name="submit" /></td>
      </tr>
      </table>
     </form>

    </body>

    <%@page import="pers.sun.sql.SqlTool"%>
    <%@page import="pers.sun.operateion.Operated"%>
    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <%@page import="java.util.*"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>判断结果</title>
    </head>
    <body>
      
      <ul>
       <li> <a href="begin.jsp" >重来</a>&nbsp;&nbsp;</li>
       <li> <a href="ending.jsp">结束</a></li>
      </ul>
      <hr>
      <table align="center" border="1" width="500">
       <tr>
        <td>算式</td>
        <td>你的答案</td>
        <td>对错</td>
        <td>正确答案</td>
       </tr>
    <%
      List<Operated> operation=new ArrayList<Operated>();
      int length=operation.size();
      //String[] peoresult=new String[length];
      //peoresult=request.getParameterValues("peoresult");
      operation=SqlTool.search();
      int count=0;
      System.out.print(request.getParameter("peoresult"));
      for(Operated temp:operation){
       int i=0;
       String peoresultx=request.getParameter("peoresult");
    %>
      <tr>
       <td><%=temp.getFormulax() %></td>
       <td><%=peoresultx %></td>
       <%
       String correct=null;
       if(peoresultx!=null&&!"".equals(peoresultx.trim())){
        if(Integer.parseInt(peoresultx)==temp.getResultx()){
         correct="对";
         count++;
        }
        else
         correct="错";
       }
       %>
       <td><%=correct %></td>
       <td><%=temp.getResultx() %></td>
      </tr>
    <%  
      }
    %> 
       <tr><td>你的得分:<%=count %></td></tr>
      </table>

    </body>
    </ht

    运行结果截图:

    此处不正确:“你的答案” 出问题。

    学习进度:loading............

    ...................................................
  • 相关阅读:
    树套树
    Luogu P2839 [国家集训队]middle
    苟随笔
    BJOI2014 大融合
    轻量树上问题选做
    sb的斜率优化笔记
    CDialogEx::OnPaint()的问题,或者为什么在对话框程序的OnPaint中绘图无效的问题
    VC6的工程转到VC2010或更高版本出现fatal error C1189编译错误的解决方法
    C语言实现的反转字符串
    在终端输入npm run serve时出现npm ERR! code ELIFECYCLE npm ERR! errno 1 npm ERR! test_vue_0613@1.0.0 dev: 错误的解决方法
  • 原文地址:https://www.cnblogs.com/floakss/p/7956173.html
Copyright © 2011-2022 走看看