• 手机版

    扫码体验手机版

  • 微信公众号

    扫码关注公众号

国内首家协议开发

软芯音视解码保护平台

在线
客服

发布
需求

在线
聊天

天盟
APP

天盟APP下载

关注
微信

微信扫一扫访问
顶部

有一个正整数n,a:可以除2, b:可以+1,可以减1。如何以最少步骤让n变

有一个正整数n。a:可以除2,b:可以+1,可以-1,如何以最少步骤让n变成1

免责声明:本内容仅代表回答会员见解不代表天盟观点,请谨慎对待。

版权声明:作者保留权利,不代表天盟立场。

使用道具 举报

全部参与2

是不是问了2道一样的问题..
n=((n+1)/2)-((n-1)/2)

使用道具 举报

如果等于1,直接结束。否则,正整数n先除去2取余数,如果余数=1,那么将n-1。然后不断的除以2,最后就会得到1
if(n==1){returnfalse;}if(n%2==1){n=n-1;while(n!=1){n=n/2;}}else{while(n!=1){n=n/2;}}

使用道具 举报

发新帖

发布任务需求已有1031167位用户正在使用天盟网服务

发布分类: *
任务预算: *
需求内容: *
手机号码: *
任务商家报价为
  • 预算价 :
  • 成交价 :
  • 完工期 :
  • 质保期 :

* 最终任务项目以服务商报价、双方协商为准!