import java.util.Scanner;

public class Yunsuan {
	public static void main(String[] args){
		Scanner sc=new Scanner(System.in); 
		int t=1,n=0;
		while(t!=0)
		{
			System.out.println("请选择:  1.整数运算    2.分数运算    0.退出");
			t=sc.nextInt();
			switch(t)
			{
			case 1:{zhengshu();
				break;
			}
			case 2:{fenshu();
			break;
			}
			
		}
		
	}
	}
	//化简分数;求最大公约数
	public static int simple(int a,int b)
	{
		int c=0;
		if(a>b)
		{		
			while(a!=b)
			{
				c=a-b;
				if(b>=c)
				{
					a=b;
					b=c;
				}
				if(c>b)
				{
					a=c;
				}
			}
			return a;
		}
		else
		{
			while(a!=b)
			{
				c=b-a;
				if(a>=c)
				{
					b=a;
					a=c;
				}
				if(c>a)
				{
					b=c;
				}
				
			}
			return a;
		}
	}
	
	//求最小公倍数
	public static int gongbei(int a,int b)
	{
		int t=simple(a,b);
		return a*b/t;
	}
	
	//整数运算
	public static void zhengshu()
	{
		Scanner sc=new Scanner(System.in);
		System.out.println("请输入题目数量:");
		int n=sc.nextInt();
		String a[]={"+","-","*","/"};
		int b[]=new int [n]; 
		int c[]=new int [n];
		int d[]=new int [n];
		for(int i=0;i<n;i++)
		{
			b[i]=(int) (Math.random()*100);    //产生随机数
			c[i]=(int) (Math.random()*100);
			d[i]=(int) (Math.random()*4);
			boolean f = false;
			for(int j=i-1;j>=0;j--)
			{
				if(b[i]==b[j]&&c[i]==c[j]&&d[i]==d[j])
				{
					f = true;
					break;			
				}
			}
			if(f == true||(d[i]==1&&b[i]<c[i])||(d[i]==3&&c[i]==0))  //限制不能重复,当为减法的时候,被减数大于减数,当为除法,被除数不为0
				i--;
			else
				{
				   System.out.print("第"+(i+1)+"题"+": "+b[i]+" "+a[d[i]]+" "+c[i]+" =");
				   String q=sc.next();      
				   String w1=""+(b[i]+c[i]);    //将数化为String类型
				   String w2=""+(b[i]-c[i]);
				   String w3=""+(b[i]*c[i]);
				   String w4=""+(b[i]/c[i]);
				   
				   if(d[i]==0&&q.equals(w1))
					   System.out.println("恭喜你,回答正确!");
				   else if(d[i]==0&&!(q.equals(w1)))
					   System.out.println("回答错误! 正确结果为:"+w1);
				   
				   if(d[i]==1&&q.equals(w2))
					   System.out.println("恭喜你,回答正确!");
				   else if(d[i]==1&&!(q.equals(w2)))
					   System.out.println("回答错误! 正确结果为:"+w2);
				   
				   if(d[i]==2&&q.equals(w3))
					   System.out.println("恭喜你,回答正确!");
				   else if(d[i]==2&&!(q.equals(w3)))
					   System.out.println("回答错误! 正确结果为:"+w3);
				  
				   if(d[i]==3)
				   {
					   if((b[i]%c[i]==0&&q.equals(w4)))
					   {
						   System.out.println("恭喜你,回答正确!");
					   }
					   else if(b[i]%c[i]!=0)
					   {
						   int t=simple(b[i],c[i]);
						   b[i]/=t;c[i]/=t;
						   w4=""+b[i]+"/"+c[i];
						   if(q.equals(w4))
						   {
							   System.out.println("恭喜你,回答正确!");
						   }
					   }
				   }
				   else if(d[i]==3)
					   System.out.println("回答错误! 正确结果为:"+w4);
				   
				}
			
		}
	}
	public static void fenshu()
	{
		Scanner sc=new Scanner(System.in);
		System.out.println("请输入题目数量:");
		int n=sc.nextInt();
		String a[]={"+","-","*","/"};
		int b1[]=new int [n]; 
		int b2[]=new int [n];
		int c1[]=new int [n];
		int c2[]=new int [n];
		int d[]=new int [n];
		for(int i=0;i<n;i++)
		{
			b1[i]=(int) (Math.random()*100);  //产生随机数
	        b2[i]=(int) (Math.random()*100);
			c1[i]=(int) (Math.random()*100);
			c2[i]=(int) (Math.random()*100);
			
			d[i]=(int) (Math.random()*4);
			boolean f = false;
			for(int j=i-1;j>=0;j--)
			{
				if(b1[i]==b1[j]&&b2[i]==b2[j]&&c1[i]==c1[j]&&c2[i]==c2[j]&&d[i]==d[j])//查重
				{
					f=true;
		            break;
				}		
			}
			if(f==true||(b1[i]>=b2[i])||(c1[i]>=c2[i])||(b2[i]==0)||(c2[i]==0)||(b1[i]==0)||(c1[i]==0))//分子大于分母,都不为0
			{
				i--;
			}
			else
			{
				int t1=simple(b1[i],b2[i]);
				int t2=simple(c1[i],c2[i]);
				b1[i] /= t1;               //都化为最简
				b2[i] /= t1;
				c1[i] /= t2;
				c2[i] /= t2;
				
				
				int t=gongbei(b2[i],c2[i]);   //最小公倍数
				int y1=t/b2[i];             //最小公倍数除以分母
				int y2=t/c2[i];
				b1[i]*=y1;   //同分后的分子
				c1[i]*=y2;   //同分后的分子
				
				int p1=b1[i]+c1[i];
				int p2=b1[i]-c1[i];
				if(d[i]==0&&p1>=t)
				{
					i--;
					continue;
				}
				else if(d[i]==1&&p2<=0)
				{
					i--;
					continue;
				}
				else if(d[i]==2&&((b1[i]/y1)*(c1[i]/y2)>=b2[i]*c2[i]))   //乘除的时候按同分前的分子,分母计算
				{
					i--;
					continue;
				}	
				else if(d[i]==3&&((b1[i]/y1*c2[i])>=(b2[i]*c1[i]/y2)))
				{
					i--;
					continue;
				}	
				else
				{
					System.out.print("第"+(i+1)+"题:   "+"("+(b1[i]/y1)+"/"+b2[i]+")"+" "+a[d[i]]+" "+"("+(c1[i]/y2)+"/"+c2[i]+")"+" "+"=");
					String q=sc.next();         
					if(d[i]==0)
					{
						int t3=simple(p1,t);
						p1 /=t3;
						t /=t3;
						String w1=""+p1+"/"+t;
						if(q.equals(w1))
							System.out.println("恭喜你,回答正确!");
						else
							System.out.println("回答错误! 正确结果为:"+w1);
					}
					else if(d[i]==1)
					{
						int t3=simple(p2,t);
						p2 /=t3;
						t /=t3;
						String w1=""+p2+"/"+t;
						if(q.equals(w1))
							System.out.println("恭喜你,回答正确!");
						else
							System.out.println("回答错误! 正确结果为:"+w1);
					}
					else if(d[i]==2)
					{
						b1[i] /=y1;
						b1[i] *=(c1[i]/y2);
						b2[i] *=c2[i];
						int t3=simple(b1[i],b2[i]);
						b1[i] /=t3;
						b2[i] /=t3;
						String w1=""+b1[i]+"/"+b2[i];
						if(q.equals(w1))
							System.out.println("恭喜你,回答正确!");
						else
							System.out.println("回答错误! 正确结果为:"+w1);
					}
					else if(d[i]==3)
					{
						b1[i] /=y1;
						b1[i] *=c2[i];
						b2[i] *=c1[i];
						int t3=simple(b1[i],b2[i]);
						b1[i] /=t3;
						b2[i] /=t3;
						String w1=""+b1[i]+"/"+b2[i];
						if(q.equals(w1))
							System.out.println("恭喜你,回答正确!");
						else
							System.out.println("回答错误! 正确结果为:"+w1);
					}
				}
			}
		}
	}

}

设计思想

1.设置几个数组,将随机产生的100以内数存入其中,在一个数组里分别存入加减乘除,利用产生的三以内的整数,确定运算符号;

2.添加限制,将产生负数,和上面的算式相同的排除掉,重新产生随机数。

3.计算出结果,与输入的结果进行比较。

4.在计算真分数的时候,先计算出分子和分母的最大公约数,将式子化简,进行加法运算的时候,先求出两个数的分母的最小公倍数,

进行同分,让分子进行加减,由于不能有假分数,将两个分子相加大于最小公倍数的排除,重新产生随机数,由于结果也是分数形式,只能用String类型的,

将计算的结果转化成String类型,String q=“”+分子+"/"+分母;再将结果与之比较

 

运行截图

  

没按预期时间完成的主要原因是不能清楚地理解题目的意思,老是改,是不是真分数包括带分数,来回的改。

基础还是不太扎实,有时还会对逻辑关系分不清。

posted on 2017-03-02 19:46  账号你好  阅读(507)  评论(0编辑  收藏  举报