n位二进制数加一的时间复杂度

这是数据结构老师布置的第二道作业题,题目要求如下:

下列算法完成对一个n位二进制数加1的操作(假如无溢出)。显然,该算法在最坏情况下的时间复杂度为O(n),试问平均情况下的时间复杂度是什么?请用数学推导或实验验证的方式证明你的结论。

void Inc(int A[]) {
  int i;
  i=n-1;
  while (A[i]==1) 
     { A[i]=0; i--; }
  A[i]=1;
}

解答:

算法在最好情况下,即二进制数的最后一位为零时,只进行一次判断,未进行循环体,赋值语句也执行了一次,最坏情况即题目假设情况,赋值语句执行n-1次,算法复杂度为O(n),循环体平均执行0.5n次,所以平均时间复杂度为O(n)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值