CodeCrab 2019-12-13 18:10 采纳率: 100%
浏览 204
已结题

明解Java有个题不太懂求大佬解答?

请编写方法set、reset、inverse,分别返回将整数x的第pos位(从最低位开始0,1,2,···)
设为1后的值、设为0后的值、取反后的值。

int set(int x,int pos)
int reset(int x,int pos)
int inverse(int x,int pos)

这是书上给出的三个方法,求大佬解答,我是个刚入门的小白,只会if语句,循环,与、或、异或、取反这一类的,这本书也只看到方法了,请大佬们用我能看的懂的方法做,万分感谢!!!

  • 写回答

1条回答 默认 最新

  • threenewbee 2019-12-13 22:33
    关注
        static int set(int x,int pos)
        {
            int t = 1 << pos;
            return x | t;
        }
        static int reset(int x,int pos)
        {
            int t = 1 << pos;
            t = ~t;
            return x & t;
        }
        static int inverse(int x,int pos)
        {
            if (set(x, pos) != x)
                return set(x, pos);
            else
                return reset(x, pos);
        }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 如何删除这个虚拟音频
  • ¥50 hyper默认的default switch
  • ¥15 网站打不开,提示502 Bad Gateway
  • ¥20 基于MATLAB的绝热压缩空气储能系统代码咨询
  • ¥15 R语言建立随机森林模型出现的问题
  • ¥20 unity内置语言切换的按钮设置
  • ¥15 中级微观经济学,生产可能性边界问题
  • ¥15 TCP传输时不同网卡传输用时差异过大
  • ¥15 请各位看看我写的属于什么算法,或者有更正确的写法?
  • ¥15 html5 qrcode 扫描器