交替位二进制数 和寻找比目标字母大的最小字母

本文解析了两种算法问题:一是判断一个正整数的二进制表示是否具有交替位特性;二是从有序字符数组中找出大于指定目标字符的最小元素。通过具体示例和代码实现,深入浅出地介绍了这两种算法的实现原理。

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

今天的两个题比较简单,直接看代码就ok。

给定一个正整数,检查他是否为交替位二进制数:换句话说,就是他的二进制数相邻的两个位数永不相等。

示例 1:
输入: 5
输出: True
解释:
5的二进制数是: 101

示例 2:
输入: 7
输出: False
解释:
7的二进制数是: 111

示例 3:
输入: 11
输出: False
解释:
11的二进制数是: 1011

 示例 4:
输入: 10
输出: True
解释:
10的二进制数是: 1010

public class test0221 {
	public static void main(String[] args) {
		int n = 5;
		Solution S = new Solution();
		boolean a = S.hasAlternatingBits(n);
		System.out.println(a);
		}

}

class Solution {
    public boolean hasAlternatingBits(int n) {
        int a = n&1;
        n>>=1;
        while(n>0)
        {
            if((n&1)==a)
            {
                return false;
            }
            a=n&1;
            n>>=1;
        }
        return true;
    }
}


 

给定一个只包含小写字母的有序数组letters 和一个目标字母 target,寻找有序数组里面比目标字母大的最小字母。
数组里字母的顺序是循环的。举个例子,如果目标字母target = 'z' 并且有序数组为 letters = ['a', 'b'],则答案返回 'a'。

示例:
输入:
letters = ["c", "f", "j"]
target = "a"
输出: "c"

输入:
letters = ["c", "f", "j"]
target = "c"
输出: "f"

输入:
letters = ["c", "f", "j"]
target = "d"
输出: "f"

输入:
letters = ["c", "f", "j"]
target = "g"
输出: "j"

输入:
letters = ["c", "f", "j"]
target = "j"
输出: "c"

输入:
letters = ["c", "f", "j"]
target = "k"
输出: "c"

 

public class test0221 {
	public static void main(String[] args) {
		Solution S = new Solution();
		/*int n = 5;
		boolean a = S.hasAlternatingBits(n);
		System.out.println(a);*/
		char[] letters = new char[] {'c', 'f', 'j'};
		char target = 'd';
		char a = S.nextGreatestLetter(letters, target);
		System.out.println(a);
		}

}

class Solution {
    public char nextGreatestLetter(char[] letters, char target) {
        for(int i = 0;i < letters.length; i++)
        {
            if(target<letters[i])
            {
                return letters[i];
            }
        }
        return letters[0];
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值