第二次作业 关于代码中的错误的检查

public int findLast (int[] x, int y) {
//Effects: If x==null throw
NullPointerException
// else return the index of the last element

// in x that equals y.

// If no such element exists, return -1
for (int i=x.length-1; i > 0; i--)
{ if (x[i] == y)
{ return i; } }
return -1; }

// test: x=[2, 3, 5]; y = 2
// Expected = 0

这段代码找出X数组中最后一个等于y的元素下标,不存在等于y的元素返回-1.

for循环从数组中最后一个元素向前检测,但是条件i>0,导致了不会检查第一个元素。

给定一个测试用例,一个空的数组,那么代码不执行for循环,则故障没有执行。

给定一个测试用例,数组[1,2,3],y=3      则返回2.执行了故障但并没有发生错误。

给定一个测试用例,数组[1,2,3],y=4      则返回-1.发生了错误,但没有失效。

 

public static int lastZero (int[] x) 
{
 //Effects: if x==null throw 
NullPointerException
 // else return the index of the LAST 0 in x. 
// Return -1 if 0 does not occur in x 
for (int i = 0; i < x.length; i++)
 { if (x[i] == 0)
 { return i; } }
 return -1; }
// test: x=[0, 1, 0] 
// Expected = 2

这段代码找出X数组中最后一个等于0的元素下标,不存在等于0的元素返回-1.

for循环从数组中第一个元素x检向后测,但是条件i>0,发现为0的元素就返回该元素下标,不会继续向后检测。

给定一个测试用例,一个空的数组,那么代码不执行for循环,则故障没有执行。

给定一个测试用例,数组[1,2,3]      则返回-1.执行了故障但并没有发生错误。

给定一个测试用例,数组[1,0,2]      则返回1.发生了错误,但没有失效。

 

转载于:https://www.cnblogs.com/WentaiLi/p/5267612.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值