LeetCode-Number Complement

本文探讨了如何通过异或操作高效地计算正整数的补数,即其二进制表示中所有位的反转。提供了两种解决方案,一种是通过计算二进制长度并创建全1掩码,另一种是直接使用位操作来确定掩码长度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Description:
Given a positive integer, output its complement number. The complement strategy is to flip the bits of its binary representation.

Note:

  • The given integer is guaranteed to fit within the range of a 32-bit signed integer.
  • You could assume no leading zero bit in the integer’s binary representation.
    Example 1:
    
    Input: 5
    Output: 2
    Explanation: The binary representation of 5 is 101 (no leading zero bits), and its complement is 010. So you need to output 2.
    Example 2:
    
    Input: 1
    Output: 0
    Explanation: The binary representation of 1 is 1 (no leading zero bits), and its complement is 0. 

题意:给定一个正整数,输出它的补数;其定义将正整数的无前导0的二进制取反(1变为0,0变为1);

解法一:我们可以考虑异或操作,将这个数的无前导0二进制表示和其全1表示(长度为这个数的无前导0二进制表示)相异或,就可以得到其取反的数;

Java
class Solution {
    public int findComplement(int num) {
        int len = 0;
        int temp = num;
        while (temp > 0) {
            len++;
            temp /= 2;
        } 
        return num == 0 ? 1 : ((1 << len) - 1) ^ num;
    }
}

解法二:同样还是考虑用异或的操作,但是我们不去求这个数的无前导0二进制表示的长度,利用位操作直接得到其最后的表示;定义mask = ~0(全1表示);将mask与num相与直到值为0,这个时候的mask的后n为即为num的无前导0二进制表示的长度,再将mask取反即得到解法一中的无前导0二进制全1表示;

Java
class Solution {
    public int findComplement(int num) {
        int mask = ~0;
        while ((num & mask) > 0) {
            mask <<= 1;
        }
        return num ^ ~mask;
    }
}
资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在C#开发中,Windows Media Player控件是集成音频和视频播放功能的强大工具。本文将介绍如何在C#中实现不同的播放模式,如随机播放、列表循环和单曲循环,这些功能在多媒体应用中十分常见 。 要使用Windows Media Player控件,首先需要将其添加到C#项目中。在Visual Studio中,可以通过在工具箱中搜索“Windows Media Player”,并将其拖放到窗体上完成 。接着,设置控件的基本属性,如URL,以指定要播放的媒体文件 。 随机播放模式会在一首歌曲播放结束后,随机选择播放列表中的下一首歌曲。可以通过创建一个包含所有歌曲URL的数组,并利用Random类生成随机索引来实现。例如: 列表循环模式会在一首歌曲播放结束后,自动从播放列表的开头重新开始播放。实现方法是检测到播放结束后,将URL重置为列表的第一个元素: 单曲循环模式则是在一首歌曲播放结束后,重新播放当前歌曲。可以通过将播放器的当前播放位置重置为0并重新播放来实现: 以上代码均需在windowsMediaPlayer1_PlayStateChange事件处理器中实现,该事件会在播放器的播放状态改变时触发 。需要注意的是,这些示例假设已正确引用了WMPLib命名空间,并且Windows Media Player控件的ID为“windowsMediaPlayer” 。 在实际应用中,除了实现播放模式外,还可能需要考虑错误处理、用户界面更新等因素。为了使播放列表更具动态性,可以考虑从数据库或XML文件加载歌曲信息,而不是硬编码在代码中,从而提升用户体验 。通过这些方法,可以在C#中灵活实现Windows Media Player的各种播放模式,满足不同多媒体应用场景的需求 。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值