367. Valid Perfect Square |计算一个数是否是一个数的平方

Given a positive integer num, write a function which returns True if num is a perfect square else False.

Note: Do not use any built-in library function such as sqrt.

Example 1:

Input: 16
Returns: True

Example 2:

Input: 14
Returns: False

Credits:
Special thanks to @elmirap for adding this problem and creating all test cases.

Subscribe to see which companies asked this question.

思路:二分查找。

public class Solution {
    public boolean isPerfectSquare(int num) {
		if (num == 1) {
			return true;
		}
		int l, r, mid;
		l = 1;
		r = num / 2;
		while (l <= r) {
			mid = (l + r) / 2;
			if (num % mid == 0 && num / mid == mid) {
				return true;
			} else if (num / mid < mid) {
				r = mid - 1;
			} else {
				l = mid + 1;
			}
		}
		return false;
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以使用正则表达式来判断一个字符串只包含字和小点。 你可以使用如下的代码来判断: ``` import re def check_string(s): # 利用正则表达式匹配字符串 if re.match(r'^[0-9.]+$', s): return True else: return False ``` 这段代码将会使用正则表达式 `r'^[0-9.]+$'` 匹配字符串,该正则表达式可以匹配一个或多个字或小点。如果字符串能够匹配该正则表达式,则函返回 `True`,否则返回 `False`。 例如: ``` print(check_string('1234.56')) # True print(check_string('12345')) # True print(check_string('123.45.6')) # False print(check_string('123.45.6.7')) # False print(check_string('abc')) # False print(check_string('1234.56.abc')) # False ``` 输出结果如下: ``` True True False False False False ``` ### 回答2: 要判断一个字符串是否只包含字和小点,可以使用以下方法: 1. 遍历字符串的每个字符,判断其是否为字或小点。可以使用isdigit()函判断字符是否为字,使用"=="判断字符是否为小点。 2. 若字符串为空,则它不符合只包含字和小点的条件。 3. 遍历字符串时,若有任何一个字符不符合字或小点的条件,则可以判断该字符串不符合条件。 4. 如果字符串中只包含字和小点,并且没有其他字符,则可以判断该字符串符合条件。 下面是一个示例代码: ```python def is_valid_string(s): if len(s) == 0: #判断字符串长度是否为0 return False for char in s: if not char.isdigit() and char != '.': #判断是否为字或小点 return False return True # 调用示例 print(is_valid_string("123.45")) # 输出True print(is_valid_string("123a45")) # 输出False,包含字母 print(is_valid_string("")) # 输出False,空字符串不符合条件 print(is_valid_string("12.")) # 输出True ``` 通过遍历字符串,判断其中每个字符是否为字或小点,即可判断该字符串是否只包含字和小点。 ### 回答3: 要判断一个字符串只包含字和小点,可以使用以下方法: 1. 遍历字符串的每个字符,判断它是否为字或小点。可以使用ASCII码来判断字符的范围,字的ASCII码范围为48到57,小点的ASCII码为46。 2. 如果字符不是字或小点,则字符串不满足要求。可以使用条件语句进行判断,如果字符的ASCII码不在字或小点的范围内,表示字符串中包含其他字符,即不满足要求。 3. 如果字符串中只包含字和小点,可以继续判断点的个一个合法的值字符串中小点的个只能为1个,如果小点的个大于1个,则字符串也不满足要求。 4. 如果字符串中只包含字和1个小点,同时满足以上条件,即可判断该字符串是只有字和小点的字字符串。 以下为一个示例代码: ```python def is_number_string(string): dot_count = 0 # 记录小点的个 for char in string: if ord(char) < 48 or ord(char) > 57: # 判断字符是否为字的ASCII码范围 if char != '.': # 判断字符是否为小点 return False # 字符串中包含其他字符,不满足要求 else: dot_count += 1 # 统计小点的个 if dot_count > 1: return False # 小点的个大于1,不满足要求 return True # 字符串只包含字和1个小点,满足要求 # 测试示例 print(is_number_string("123.456")) # True print(is_number_string("12.34.56")) # False print(is_number_string("abc123")) # False ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值