码迷,mamicode.com
首页 > 编程语言 > 详细

Java第二次考试

时间:2018-11-15 18:29:45      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:try   string   generate   ret   缓冲流   stack   stream   private   ber   

代码

package sizeyunsuan;
import java.io.FileNotFoundException;
import java.io.PrintStream;
import java.util.Random;
import java.util.Scanner;
public class SiZe {
    @SuppressWarnings("unused")
      public static void main(String[] args) throws FileNotFoundException {
          String[] operate = new String[] { "+", "-", "*", "/" };//定义运算符数组
          int[] numbers = new int[100];//定义数字部分数组
          for (int i = 1; i <= 100; i++) {
             numbers[i - 1] = i;
          }
         Random rand = new Random();//定义随机数
         @SuppressWarnings("resource")
         Scanner in = new Scanner( System.in );
         String fiilename ="d:/shuchu.txt";
         int operand1 = 0 ;
         int operand2 = 0;
         int operator;
         int result;
         int count=0;                                //统计正确的题目数量
         int i;
         duqu[] cal = new duqu[100];    //30道题目
         
         //随机题目并显示序号与题目
         for( i=0; i<100; i++ ){
             operator = rand.nextInt(4)+1;
             
             switch( operator ){
                 case 1:
                     operand1 = rand.nextInt(100);
                     operand2 = rand.nextInt(100);
                     break;
                 case 2:                                //减法不出现负数
                     operand1 = rand.nextInt(100);
                     operand2 = rand.nextInt( operand1 );
                     break;
                 case 3:                                //乘除范围更小
                     operand1 = rand.nextInt(10);
                     operand2 = rand.nextInt(10);
                     break;
                 case 4:
                     operand2 = rand.nextInt(9)+1;
                     operand1 = rand.nextInt(81-operand2)+operand2;
                     break;
             }
             
             System.out.print( (i+1) +"  ");
             cal[i] = new duqu( operand1, operator, operand2);
             cal[i].manager();
             if(i==0)
                 duqu.flushFile(fiilename);
             duqu.OutputFile(fiilename,cal[i]);
             PrintStream out=System.out;
         
             
            
     }
    }
}
package sizeyunsuan;

import java.io.*;
public class duqu {
    
    private int operator;            //操作数
    private int operand1;            //操作数前面的数
    private int operand2;            //操作数后面的书
    private int result;                //运算结果,除法结果取整数部分
    private int statistics;            //统计正误
    private String str;                //记录题目
    
    public int getResult(){
        return result;
    }
    
    public int getStatistics(){        
        return statistics;
    }
    
    public duqu( int operand1 , int operator , int operand2 ){
        this.operand1 = operand1;
        this.operator = operator;
        this.operand2 = operand2;
    }
    
    public void manager(){
        switch(operator){
            case 1:
                str = operand1 +" + " + operand2 +" = ";
                result = operand1 + operand2;
                break;
            case 2:
                str = operand1 +" - " + operand2 +" = ";
                result = operand1 - operand2;
                break;
            case 3:
                str = operand1 +" * " + operand2 +" = ";
                result = operand1 * operand2;
                break;
            case 4:
                str = operand1 +" / " + operand2 +" = ";
                result = operand1 / operand2;
                break;
        }
        System.out.println(str);
    }
    
    public void judge( int result ){        //判断正误
        if( this.result == result){
            statistics = 1;                    //正确为1
        }
        else
            statistics = 0;                    //错误为0
    }
    
    public static void OutputFile(String filename,duqu cal){
        @SuppressWarnings("unused")
        File file = new File(filename);
        FileWriter fw = null;
        try {
            fw = new FileWriter(filename,true);
        } catch (IOException e) {
            e.printStackTrace();
        }
        PrintWriter p = new PrintWriter(fw);
        p.println(cal.str);
        p.close();
        try {
            fw.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    
    public static void flushFile(String filename){
        File file = new File(filename);
        FileWriter fw;
        try {
            fw = new FileWriter(file);
            fw.write("");
            fw.flush();
            fw.close();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}

于下午四点四十完成

总结:主要自己对于缓冲流导入文本文件夹,输出文本文件夹,不太理解,一直困于此处,对于四则运算的正误判断也有些许的疑问,然后通过百度查阅,以及询问同学弄懂了自己不是很会的地方,感觉自己在这次课堂测验上学到了很多

Java第二次考试

标签:try   string   generate   ret   缓冲流   stack   stream   private   ber   

原文地址:https://www.cnblogs.com/love-nan/p/9964919.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!