我找到一个比较好的算法,但是运行的时候出现java.lang.ArrayIndexOutOfBoundsException,应该是数组出现的问题但是我不知道如何修改程序还希望大家帮忙。程序如下
package tax;
/*
* 运算24点的工具
*
* Copyleft 2004 戴云杰 xdanger All Rights Reserved.
* http://www.xdanger.com
*
* 使用方式:
* 键入4个1-10的整数,即可显示所有结果等于24的计算方式
*/import java.io.*;
import java.lang.*;
//import java.applet.Applet;
//import java.awt.*;class Do24{
// 目标值
public final short DST_VALUE = ( short ) 24;
// 输入值列表
private short[] List = new short[4];
// 结果列表
private String[] Result = new String[1024];
// 结果总数
private short ResultNumber = 0;
// 构造函数
public Do24( short a, short b, short c, short d ){
this.List[0] = a;
this.List[1] = b;
this.List[2] = c;
this.List[3] = d;
this.Result = this.countIt();
}
// 主函数
public static void main( String[] args ){
short a = Short.parseShort( args[0] );
short b = Short.parseShort( args[1] );
short c = Short.parseShort( args[2] );
short d = Short.parseShort( args[3] );
Do24 o = new Do24( a, b, c, d );
o.printResult(); }
// 开始计算
public String[] countIt(){
for( short l1 = 0; l1 < 4 ; l1++ ){
short A;
A = this.List[l1];
for( short l2 = 0; l2 < 4 ; l2++){
int B = this.List[l2];
for( short l3 = 0; l3 < 4 ; l3++){
int C = this.List[l3];
for( short l4 = 0; l4<4 ; l4++){
int D = this.List[l4];
if( l1 != l2 && l2 != l3 && l3 != l4 && l4 != l1 && l1 != l3 && l2 != l4 ){
if( A + B + C + D == this.DST_VALUE )
this.putResult( A + "+" + B + "+" + C + "+" + D + "=" + this.DST_VALUE );
if( A + B + C - D == this.DST_VALUE )
this.putResult( A + "+" + B + "+" + C + "-" + D + "=" + this.DST_VALUE );
if( A + B - C - D == this.DST_VALUE )
this.putResult( A + "+" + B + "-" + C + "-" + D + "=" + this.DST_VALUE );
if( A - B - C - D == this.DST_VALUE )
this.putResult( A + "-" + B + "-" + C + "-" + D + "=" + this.DST_VALUE );
if( A * B * C * D == this.DST_VALUE )
this.putResult( A + "*" + B + "*" + C + "*" + D + "=" + this.DST_VALUE );
if( A * B * C - D == this.DST_VALUE )
this.putResult( A + "*" + B + "*" + C + "-" + D + "=" + this.DST_VALUE );
if( A * B - C - D == this.DST_VALUE )
this.putResult( A + "*" + B + "-" + C + "-" + D + "=" + this.DST_VALUE );
if( A * B - C * D == this.DST_VALUE )
this.putResult( A + "*" + B + "-" + C + "*" + D + "=" + this.DST_VALUE );
if( A * B * C + D == this.DST_VALUE )
this.putResult( A + "*" + B + "*" + C + "+" + D + "=" + this.DST_VALUE );
if( A * B + C + D == this.DST_VALUE )
this.putResult( A + "*" + B + "+" + C + "+" + D + "=" + this.DST_VALUE );
if( A * B + C * D == this.DST_VALUE )
this.putResult( A + "*" + B + "+" + C + "*" + D + "=" + this.DST_VALUE );
if( A * B + C - D == this.DST_VALUE )
this.putResult( A + "*" + B + "+" + C + "-" + D + "=" + this.DST_VALUE );
if( A - B * C * D == this.DST_VALUE )
this.putResult( A + "-" + B + "*" + C + "*" + D + "=" + this.DST_VALUE );
if( A + B - C * D == this.DST_VALUE )
this.putResult( A + "+" + B + "-" + C + "*" + D + "=" + this.DST_VALUE );
if( A * B * (C + D) == this.DST_VALUE )
this.putResult( A + "*" + B + "*(" + C + "+" + D + ")=" + this.DST_VALUE );
if( A * B * (C - D) == this.DST_VALUE )
this.putResult( A + "*" + B + "*(" + C + "-" + D + ")=" + this.DST_VALUE );
if( A * (B + C + D) == this.DST_VALUE )
this.putResult( A + "*(" + B + "+" + C + "+" + D + ")=" + this.DST_VALUE );
if( A * (B + C - D) == this.DST_VALUE )
this.putResult( A + "*(" + B + "+" + C + "-" + D + ")=" + this.DST_VALUE );
if( A * (B - C - D) == this.DST_VALUE )
this.putResult( A + "*(" + B + "-" + C + "-" + D + ")=" + this.DST_VALUE );
if( A - B * (C + D) == this.DST_VALUE )
this.putResult( A + "-" + B + "*(" + C + "+" + D + ")=" + this.DST_VALUE );
if( A - B * (C - D) == this.DST_VALUE )
this.putResult( A + "-" + B + "*(" + C + "-" + D + ")=" + this.DST_VALUE );
if( A * (B + C) - D == this.DST_VALUE )
this.putResult( A + "*(" + B + "+" + C + ")-" + D + "=" + this.DST_VALUE );
if( A * (B + C) + D == this.DST_VALUE )
this.putResult( A + "*(" + B + "+" + C + ")+" + D + "=" + this.DST_VALUE );
if( A * (B - C) - D == this.DST_VALUE )
this.putResult( A + "*(" + B + "-" + C + ")-" + D + "=" + this.DST_VALUE );
if( A * (B - C) + D == this.DST_VALUE )
this.putResult( A + "*(" + B + "-" + C + ")+" + D + "=" + this.DST_VALUE );
if( (A + B) * (C - D) == this.DST_VALUE )
this.putResult( "(" + A + "+" + B + ")*(" + C + "-" + D + ")=" + this.DST_VALUE );
if( (A + B) * (C + D) == this.DST_VALUE )
this.putResult( "(" + A + "+" + B + ")*(" + C + "+" + D + ")=" + this.DST_VALUE );
if( (A - B) * (C - D) == this.DST_VALUE )
this.putResult( "(" + A + "-" + B + ")*(" + C + "-" + D + ")=" + this.DST_VALUE );
package tax;
/*
* 运算24点的工具
*
* Copyleft 2004 戴云杰 xdanger All Rights Reserved.
* http://www.xdanger.com
*
* 使用方式:
* 键入4个1-10的整数,即可显示所有结果等于24的计算方式
*/import java.io.*;
import java.lang.*;
//import java.applet.Applet;
//import java.awt.*;class Do24{
// 目标值
public final short DST_VALUE = ( short ) 24;
// 输入值列表
private short[] List = new short[4];
// 结果列表
private String[] Result = new String[1024];
// 结果总数
private short ResultNumber = 0;
// 构造函数
public Do24( short a, short b, short c, short d ){
this.List[0] = a;
this.List[1] = b;
this.List[2] = c;
this.List[3] = d;
this.Result = this.countIt();
}
// 主函数
public static void main( String[] args ){
short a = Short.parseShort( args[0] );
short b = Short.parseShort( args[1] );
short c = Short.parseShort( args[2] );
short d = Short.parseShort( args[3] );
Do24 o = new Do24( a, b, c, d );
o.printResult(); }
// 开始计算
public String[] countIt(){
for( short l1 = 0; l1 < 4 ; l1++ ){
short A;
A = this.List[l1];
for( short l2 = 0; l2 < 4 ; l2++){
int B = this.List[l2];
for( short l3 = 0; l3 < 4 ; l3++){
int C = this.List[l3];
for( short l4 = 0; l4<4 ; l4++){
int D = this.List[l4];
if( l1 != l2 && l2 != l3 && l3 != l4 && l4 != l1 && l1 != l3 && l2 != l4 ){
if( A + B + C + D == this.DST_VALUE )
this.putResult( A + "+" + B + "+" + C + "+" + D + "=" + this.DST_VALUE );
if( A + B + C - D == this.DST_VALUE )
this.putResult( A + "+" + B + "+" + C + "-" + D + "=" + this.DST_VALUE );
if( A + B - C - D == this.DST_VALUE )
this.putResult( A + "+" + B + "-" + C + "-" + D + "=" + this.DST_VALUE );
if( A - B - C - D == this.DST_VALUE )
this.putResult( A + "-" + B + "-" + C + "-" + D + "=" + this.DST_VALUE );
if( A * B * C * D == this.DST_VALUE )
this.putResult( A + "*" + B + "*" + C + "*" + D + "=" + this.DST_VALUE );
if( A * B * C - D == this.DST_VALUE )
this.putResult( A + "*" + B + "*" + C + "-" + D + "=" + this.DST_VALUE );
if( A * B - C - D == this.DST_VALUE )
this.putResult( A + "*" + B + "-" + C + "-" + D + "=" + this.DST_VALUE );
if( A * B - C * D == this.DST_VALUE )
this.putResult( A + "*" + B + "-" + C + "*" + D + "=" + this.DST_VALUE );
if( A * B * C + D == this.DST_VALUE )
this.putResult( A + "*" + B + "*" + C + "+" + D + "=" + this.DST_VALUE );
if( A * B + C + D == this.DST_VALUE )
this.putResult( A + "*" + B + "+" + C + "+" + D + "=" + this.DST_VALUE );
if( A * B + C * D == this.DST_VALUE )
this.putResult( A + "*" + B + "+" + C + "*" + D + "=" + this.DST_VALUE );
if( A * B + C - D == this.DST_VALUE )
this.putResult( A + "*" + B + "+" + C + "-" + D + "=" + this.DST_VALUE );
if( A - B * C * D == this.DST_VALUE )
this.putResult( A + "-" + B + "*" + C + "*" + D + "=" + this.DST_VALUE );
if( A + B - C * D == this.DST_VALUE )
this.putResult( A + "+" + B + "-" + C + "*" + D + "=" + this.DST_VALUE );
if( A * B * (C + D) == this.DST_VALUE )
this.putResult( A + "*" + B + "*(" + C + "+" + D + ")=" + this.DST_VALUE );
if( A * B * (C - D) == this.DST_VALUE )
this.putResult( A + "*" + B + "*(" + C + "-" + D + ")=" + this.DST_VALUE );
if( A * (B + C + D) == this.DST_VALUE )
this.putResult( A + "*(" + B + "+" + C + "+" + D + ")=" + this.DST_VALUE );
if( A * (B + C - D) == this.DST_VALUE )
this.putResult( A + "*(" + B + "+" + C + "-" + D + ")=" + this.DST_VALUE );
if( A * (B - C - D) == this.DST_VALUE )
this.putResult( A + "*(" + B + "-" + C + "-" + D + ")=" + this.DST_VALUE );
if( A - B * (C + D) == this.DST_VALUE )
this.putResult( A + "-" + B + "*(" + C + "+" + D + ")=" + this.DST_VALUE );
if( A - B * (C - D) == this.DST_VALUE )
this.putResult( A + "-" + B + "*(" + C + "-" + D + ")=" + this.DST_VALUE );
if( A * (B + C) - D == this.DST_VALUE )
this.putResult( A + "*(" + B + "+" + C + ")-" + D + "=" + this.DST_VALUE );
if( A * (B + C) + D == this.DST_VALUE )
this.putResult( A + "*(" + B + "+" + C + ")+" + D + "=" + this.DST_VALUE );
if( A * (B - C) - D == this.DST_VALUE )
this.putResult( A + "*(" + B + "-" + C + ")-" + D + "=" + this.DST_VALUE );
if( A * (B - C) + D == this.DST_VALUE )
this.putResult( A + "*(" + B + "-" + C + ")+" + D + "=" + this.DST_VALUE );
if( (A + B) * (C - D) == this.DST_VALUE )
this.putResult( "(" + A + "+" + B + ")*(" + C + "-" + D + ")=" + this.DST_VALUE );
if( (A + B) * (C + D) == this.DST_VALUE )
this.putResult( "(" + A + "+" + B + ")*(" + C + "+" + D + ")=" + this.DST_VALUE );
if( (A - B) * (C - D) == this.DST_VALUE )
this.putResult( "(" + A + "-" + B + ")*(" + C + "-" + D + ")=" + this.DST_VALUE );
解决方案 »
- 遇到一个ibatis的问题,需求解决办法
- form提交action无法get到值,没分了请包涵
- 搭ssh框架时遇到一个问题
- 领先的易物网站-舍得网基于J2ee Resin实现的技术内幕
- jspsmartupload求救啊……Files' name is invalid or does not exist (1205)
- 怎么找javax.ejb.*啊
- 请问高手如何学习Java
- 关于JDBC支持SQLServer 2000 和 7.0的问题
- 我听说SUN有一个COM访问EJB的组件CAS可是我在SUN的网站上怎么都找不到呢?郁闷
- why?????
- 前天去面试的题,给大家分享一下
- 紧急啊 我用J2EE自带的DEPLOYTOOL配置的一个WEB程序,但在1.3上可以实现 在1.4上配置完后不能运行?大家帮我看看啊,实在是解决不了啊
if( A / B + C + D == this.DST_VALUE )
this.putResult( A + "/" + B + "+" + C + "+" + D + "=" + this.DST_VALUE );
if( A / B + C - D == this.DST_VALUE )
this.putResult( A + "/" + B + "+" + C + "-" + D + "=" + this.DST_VALUE );
if( A / B - C - D == this.DST_VALUE )
this.putResult( A + "/" + B + "-" + C + "-" + D + "=" + this.DST_VALUE );
if( A / B * C + D == this.DST_VALUE )
this.putResult( A + "/" + B + "*" + C + "+" + D + "=" + this.DST_VALUE );
if( A / B + C * D == this.DST_VALUE )
this.putResult( A + "/" + B + "+" + C + "*" + D + "=" + this.DST_VALUE );
if( A / B - C * D == this.DST_VALUE )
this.putResult( A + "/" + B + "-" + C + "*" + D + "=" + this.DST_VALUE );
if( A / B * C - D == this.DST_VALUE )
this.putResult( A + "/" + B + "*" + C + "-" + D + "=" + this.DST_VALUE );
if( A / B * C * D == this.DST_VALUE )
this.putResult( A + "/" + B + "*" + C + "*" + D + "=" + this.DST_VALUE );
if( C * D - A / B == this.DST_VALUE )
this.putResult( C + "*" + D + "-" + A + "/" + B + "=" + this.DST_VALUE );
if( C - D - A / B == this.DST_VALUE )
this.putResult( C + "-" + D + "-" + A + "/" + B + "=" + this.DST_VALUE );
if( C + D - A / B == this.DST_VALUE )
this.putResult( C + "+" + D + "-" + A + "/" + B + "=" + this.DST_VALUE );
if( C + D + A / B == this.DST_VALUE )
this.putResult( C + "+" + D + "+" + A + "/" + B + "=" + this.DST_VALUE );
if( C * ( D - A / B) == this.DST_VALUE )
this.putResult( C + "*(" + D + "-" + A + "/" + B + ")=" + this.DST_VALUE );
if( C * ( D + A / B) == this.DST_VALUE )
this.putResult( C + "*(" + D + "+" + A + "/" + B + ")=" + this.DST_VALUE );
if( C * ( A / B - D) == this.DST_VALUE )
this.putResult( C + "*(" + A + "/" + B + "-" + D + ")=" + this.DST_VALUE );
if( D != 0 && C > D && C % D == 0 ){
if( (A / B) + (C / D) == this.DST_VALUE )
this.putResult( "(" + A + "/" + B + ")+(" + C + "/" + D + "=" + this.DST_VALUE );
if( (A / B) - (C / D) == this.DST_VALUE )
this.putResult( "(" + A + "/" + B + ")-(" + C + "/" + D + "=" + this.DST_VALUE );
if( (A / B) * (C / D) == this.DST_VALUE )
this.putResult( "(" + A + "/" + B + ")*(" + C + "/" + D + "=" + this.DST_VALUE );
if( A / B / D + C == this.DST_VALUE )
this.putResult( A + "/" + B + "/" + D + "+" + C + "=" + this.DST_VALUE );
if( A / B / D - C == this.DST_VALUE )
this.putResult( A + "/" + B + "/" + D + "-" + C + "=" + this.DST_VALUE );
if( A / B / D * C == this.DST_VALUE )
this.putResult( A + "/" + B + "/" + D + "*" + C + "=" + this.DST_VALUE );
}
}
}
}
}
}
}
return this.Result;
}
// 打印结果
public void printResult(){
for( short i = 0; i < this.getResultNumber(); i++ )
System.out.print( this.Result[i] + '\n' );
}
// 放入结果列表
public void putResult( String result ){
this.Result[this.getResultNumber()] = result;
this.addResultNumber();
}
// 取得结果数目
public short getResultNumber(){
return this.ResultNumber;
}
// 设置结果数目
private void setResultNumber( short number ){
this.ResultNumber = number;
}
// 增加1个结果数目
private void addResultNumber(){
this.ResultNumber ++;
}
}