实现代码很简单:

 
package com.xiaozan.shopping;
 
import java.util.Arrays;
 
public class ShoppingCart {
    
    public final static int PRODUCT_1_PRICE = 2000;    // 产品编号第一个数字为1的单价,单位(分)
    public final static int PRODUCT_2_PRICE = 1000;    // 其他产品编号的单价,单位 (分)
    public final static int PRODUCT_1_TYPE = 1;    // 产品编号第一个数字为1的商品定义为类型1产品
    
    /**
     * 
     * @方法说明 按从小到大排列数组
     * @param data
     * @return void
     */
    public void sort(int[] data) {
        Arrays.sort(data);
    }
    
    /**
     * 
     * @方法说明 传入已排序的数据,计算数组中产品编号第一个数字为1的个数
     * @param data
     * @return
     * @return int
     */
    public int countProduct1(int[] data) {
        int product1Sum = 0;
        for (int i = 0; i < data.length; i++) {
            int theFirstNumber = data[i]/100;    // 产品编号的第一个数字
            if (theFirstNumber == PRODUCT_1_TYPE) {
                // 产品类型1的数量 +1
                product1Sum++;
            } else {
                // 因为已经排序,如果不是产品类型1,则剩余的都不是产品类型1的产品
                return product1Sum;
            }
        }
        return product1Sum;
    }
    
    /**
     * 
     * @方法说明 计算购物车总金额
     * @param data
     * @return
     * @return int
     */
    public int sum(int[] data) {
        int sum = 0;    // 总金额
        sort(data);    // 按从小到大排列产品编号
        int product1Sum = countProduct1(data);    // 类型1产品的个数
        sum = (product1Sum / 4) * (PRODUCT_1_PRICE * 3)    // 买4件类型1的产品只需付3件的钱 
                + (product1Sum % 4) * PRODUCT_1_PRICE     // 不足4件类型1的产品按类型1的产品单价结算
                + (data.length - product1Sum) * PRODUCT_2_PRICE;    // 其他类型的产品按其他类型单价结算
        // 如果折后金额大于等于50元,则全单八折
        if (sum >= 5000) {
            sum *= 0.8;
        }
        return sum;
    }
    
}

个人对测试仍不是很熟练,对Junit的一次练手:
package com.xiaozanoa.shopping;
 
import static org.junit.Assert.assertArrayEquals;
import static org.junit.Assert.assertEquals;
 
import java.util.Arrays;
import java.util.Collection;
 
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
 
import com.xiaozan.shopping.ShoppingCart;
 
@RunWith(Parameterized.class)
public class TestShoppingCart {
 
    ShoppingCart shoppingCart = null;
    int[] data = null;    // 预设购物车购买下产品编号
    int[] expectedSort = null;    // 预期的排序结果
    int expectedSum = 0;    // 预期产品总金额
    int expectedProduct1Sum = 0;    // 预期产品1总数
    
    @Parameters
    public static Collection<Object[][]> prepareData() {
        Object[][][] objects = {
                // 含产品1和其他产品,产品1多于4件,金额大于50
                { {229, 132, 129, 217, 190, 118, 387, 124}, 
                  {118, 124, 129, 132, 190, 217, 229, 387}, {5}, {8800} },    
                // 没有产品1 ,金额小于50
                { {229}, {229}, {0}, {1000} },    
                // 没有产品1 ,金额等于50
                { {229, 217, 387, 222, 345}, {217, 222, 229, 345, 387}, {0}, {4000} },    
                // 只有产品1 且少于4件,金额小于50
                { {118}, {118}, {1}, {2000} },    
                // 只有产品1 且等于4件,金额大于50
                { {129, 190, 118, 124}, {118, 124, 129, 190}, {4}, {4800} },    
                // 只有产品1 且大于4件,金额大于50
                { {132, 129, 190, 118, 124}, {118, 124, 129, 132, 190}, {5}, {6400} } };    
        return  Arrays.asList(objects); // 将数组转换成集合返回
    }
    
    public TestShoppingCart(Object[] _data, Object[] _expectedSort, 
            Object[] _expectedProduct1Sum, Object[] _expectedSum) {
        // 构造方法
        // JUnit会使用准备的测试数据传给构造函数
        data = new int[_data.length];
        expectedSort = new int[_expectedSort.length];
        for (int i = 0; i < _data.length; i++) {
            data[i] = (Integer) _data[i];
        }
        for (int i = 0; i < _expectedSort.length; i++) {
            expectedSort[i] = (Integer) _expectedSort[i];
        }
        this.expectedProduct1Sum = (Integer) _expectedProduct1Sum[0];
        this.expectedSum = (Integer) _expectedSum[0];
    }
    
    @Before
    public void setUp() {
        shoppingCart = new ShoppingCart();
    }
    
    @Test
    public void testCountProduct1() {
        int result = shoppingCart.countProduct1(expectedSort);    //计算产品1的数量是在已排序的数组的基础上计算的
        assertEquals(expectedProduct1Sum, result);
    }
    
    @Test
    public void testSort() {
        shoppingCart.sort(data);
        assertArrayEquals(expectedSort, data);
    }
    
    @Test
    public void testSum() {
        int result = shoppingCart.sum(data);
        assertEquals(expectedSum, result);
    }
    
 
}

测试覆盖率:

测试时主要遇到的问题在参数化测试。
常规一般见的参数化例子都是单个数字,如:
@Parameters
public static Collection prepareData()
{
// 测试数据
Object[][] objects = { { 3, 1, 2 }, { -4, -1, -3 }, { 5, 2, 3 },{ 4, -4, 8 } };
return Arrays.asList(objects);// 将数组转换成集合返回
}
所以我在做的时候就想当然的仿照着做:

错误1:argument type mismatch
public TestShoppingCart(int[] _data, int[] _expectedSort, int[] _expectedProduct1Sum, int[] _expectedSum) {
    ……        
}
原因:<Object[][]> List<Object[][]> java.util.Arrays.asList(Object[][]... a),返回的是对象数组

错误2:

Type mismatch: cannot convert from Object[] to int[]

int[] data = null;    // 预设购物车购买下产品编号
int[] expectedSort = null;    // 预期的排序结果
public TestShoppingCart(Object[] _data, Object[] _expectedSort, 
            Object[] _expectedProduct1Sum, Object[] _expectedSum) {
        ……
}

错误3:java.lang.NullPointerException
int[] data = null;    // 预设购物车购买下产品编号

int[] expectedSort = null;    // 预期的排序结果

原因:没有创建对象

错误4:计算的总额与预期的不一致
int[] data = new int[8];    // 预设购物车购买下产品编号

int[] expectedSort = new int[8];    // 预期的排序结果

错误原因:固定了数组大小为8,不足8位,补0填充,这样放到该代码中就有问题了

一分耕耘一分收获…

JAVA面试题——JAVA编程题1(2015.07.22——湛耀)的更多相关文章

  1. Eclipse创建Maven Web项目 + 测试覆盖率 + 常见问题(2015.07.14——湛耀)

    Eclipse创建Maven web项目: 到此,并没有创建好,接下来一步步解决问题: 问题:无法创建src/main/java目录 解决: 右键项目选择[properties] 点击[OK] 问题: ...

  2. 面向对象程序设计--Java语言第二周编程题:有秒计时的数字时钟

    有秒计时的数字时钟 题目内容: 这一周的编程题是需要你在课程所给的时钟程序的基础上修改而成.但是我们并不直接给你时钟程序的代码,请根据视频自己输入时钟程序的Display和Clock类的代码,然后来做 ...

  3. [ Java面试题 ]Java 开发岗面试知识点解析

    如背景中介绍,作者在一年之内参加过多场面试,应聘岗位均为 Java 开发方向. 在不断的面试中,分类总结了 Java 开发岗位面试中的一些知识点. 主要包括以下几个部分: Java 基础知识点 Jav ...

  4. C/C++笔试题(编程题)

    面试过程中遇到的编程题整理,于此备录.分享,共勉.(持续更新中......欢迎补充) (1)用户输入M, N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出.写出C程序. 程序代码如下: ...

  5. JAVA面试题——JAVA编程题1(2015.07.22)

    实现代码很简单:   package com.xiaozan.shopping;   import java.util.Arrays;   public class ShoppingCart {    ...

  6. Java笔试题解析(二)——2015届唯品会校招

    曾经总是看别人写的笔经面经.今天自己最终能够写自己亲身经历的一篇了 T-T. 前阵子去了唯品会的秋招宣讲会,华工场(如今才知道原来找家互联网公司工作的人好多).副总裁介绍了VIP的商业模式是逛街式的购 ...

  7. java基础50道编程题

    50道JAVA基础编程练习题 [程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子对数为多少? 程序分析 ...

  8. java面试之常见编程题

    1.编程实现:二分搜索算法 解答: public class SearchTest { /** 被搜索数据的大小 */ private static final int size = 5000000; ...

  9. Java笔试题-线程编程方面

      Ja 线程编程方面 60.java中有几种方法可以实现一个线程?用什么关键字修饰同步方法?stop()和suspend()方法为何不推荐使用? 答:有两种实现方法,分别是继承Thread类与实现R ...

随机推荐

  1. 使用pdb调试python

    python pdb调试 python -m pdb myscript.py #注意这会重启myscript.py,这样启动的话,代码每一行都是一个节点 也可以在程序中这么设置断点: import p ...

  2. 【JPA】query新对象 需要 构造函数

    构造函数 @Query("select g from Note g where id=?1" ) Note findById(Long id); @Query("sele ...

  3. hdu 1255 覆盖的面积 (线段树处理面积覆盖问题(模板))

    http://acm.hdu.edu.cn/showproblem.php?pid=1255 覆盖的面积 Time Limit: 10000/5000 MS (Java/Others)    Memo ...

  4. 在asp.net中如何自己编写highcharts图表导出到自己的服务器上来

    1.准备工作:网上下载highcharts导出的关键dll.      1).Svg.dll:因为highcharts的格式其实就是一个xml,采用svg的方式画图:      2).itextsha ...

  5. selenium各种场景下的启动Firefox

    开始学习selenium时为了启动Firefox可谓费尽周折,在大神的帮助下才堪堪搞定,走出了selenium的第一步:jdk1.8 + selenium_2.46 + Firefox国际版40.0. ...

  6. [BZOJ 3774] 最优选择 【最小割】

    题目链接:BZOJ - 3774 题目分析 此题与“文理分科”那道题目有些类似.都是使用最小割来求解,先加上可能获得的权值,在减掉必须舍弃的权值(最小割). 文理分科是规定每个人和 S 连就是选文,和 ...

  7. 递归解析XML

    package com.app.test; import java.io.InputStream; import java.util.List; import org.dom4j.Attribute; ...

  8. python:UnicodeDecodeError: ‘ascii’ codec can’t decode byte 0xef in position xxx: ordinal not in range(128)

    执行sql_cmd = "select * from item_base where item_id in " + item_ids_str时报错 solve: import sy ...

  9. eclipse, Log4j配置(真心的详细~)

    转自: http://www.cnblogs.com/alipayhutu/archive/2012/06/21/2558249.html a). 新建Java Project>>新建pa ...

  10. 配置Pycharm3.4.1调试edX Devstack

    前提: 1.安装好Ubuntu 2.在Ubuntn上利用vagrant+VirtualBox 搭建好了edX Developer Stack,并能成功访问 3.在Ubuntu下安装好了Pycharm- ...