黑盒测试实验报告 下载本文

} catch (Exception e) { System.out.println(\输入无效\\n黑盒测试结束\

}

}

}

3.2 找零钱最佳组合

一、分析输入的情形。

R P

15

R>100 P>100 0

二、分析输出情形。

N50 N10 N5 N1 N50=1 4>=N10N50=0 >=1 N10=0

N5=1 4>=N1>N5=0 =1 N1=0 三、分析规格中每一决策点之情形,以RR1,RR2,RR3表示计算要找50,10,5元货币数时之剩余金额。

R>100 R<=0 P>100 P=50 RR2>=10 RR3>=5

四、由上述之输入/输出条件组合出可能的情形。(RR=P-R) R>100 R<=0

0100 0

16

0

五、为满足以上之各种情形,测试资料设计如下:1.货品价格=101 2.货品价格=0 3.货品价格=-1

4.货品价格=100,付款金额=101 5.货品价格=100,付款金额=99 6.货品价格=50,付款金额=100 7.货品价格=51,付款金额=100 8.货品价格=90,付款金额=100 9.货品价格=91,付款金额=100 10.货品价格=95,付款金额=100 11.货品价格=96,付款金额=100 12.货品价格=99,付款金额=100

17

13.货品价格=100,付款金额=100 测试源代码

package com.xu.ceshi;

import java.util.Scanner;

public class Price { public static void main(String[] args) { System.out.println(\请输入您购买的东西价格:\ Scanner scanner=new Scanner(System.in); int value=scanner.nextInt(); if(value>100||value<0){ System.out.println(\无效货品价格\

System.out.println(\请输入您购买的东西价格:\ value=scanner.nextInt();

}

System.out.println(\请输入您支付的金额:\ int value2=scanner.nextInt();

if(value>value2||value2>100){

System.out.println(\无效付款\ }else if(value==value2){

System.out.println(\不找零\

}else{

int value3=value2-value;

if(value3>100||value3<0){ System.out.println(\输入的价钱不在本店范围内\ value=scanner.nextInt();

}

Price price=new Price();

18

}

price.process(value3); }

public void process(int money){ System.out.println(\将\元找零需要\ int[] value={100,50,10,5,1}; int[] count=new int[value.length]; for(int i=0;i=value[i]){ money-=value[i]; count[i]++;

}

if(count[i] !=0){ System.out.print(\应找回\张\元 \ }

}

}

}

19