633. Sum of Square Numbers
leetcode medium
#csharp#leetcode#math#medium#search#two-pointers
Task
Учитывая целое неотрицательное число c, решите, существуют ли два целых числа a и b такие, что a2 + b2 = c.
Пример:
Input: c = 5
Output: true
C# solution
matched/originalimport kotlin.math.sqrt
class Solution {
fun judgeSquareSum(c: Int): Boolean {
var a = 0
var b = sqrt(c.toDouble()).toInt()
while (a <= b) {
val total = a * a + b * b
if (total == c) {
return true
} else if (total < c) {
a++
} else {
b--
}
}
return false
}
}C++ solution
auto-draft, review before submit#include <bits/stdc++.h>
using namespace std;
// Auto-generated C++ draft from the C# solution. Review containers, LINQ and helper types before submit.
import kotlin.math.sqrt
class Solution {
fun judgeSquareSum(c: Int): Boolean {
var a = 0
var b = sqrt(c.toDouble()).toInt()
while (a <= b) {
val total = a * a + b * b
if (total == c) {
return true
} else if (total < c) {
a++
} else {
b--
}
}
return false
}
}Java solution
auto-draft, review before submitimport java.util.*;
import java.math.*;
// Auto-generated Java draft from the C# solution. Review API differences before LeetCode submit.
import kotlin.math.sqrt
class Solution {
fun judgeSquareSum(c: Int): Boolean {
var a = 0
var b = sqrt(c.toDouble()).toInt()
while (a <= b) {
val total = a * a + b * b
if (total == c) {
return true
} else if (total < c) {
a++
} else {
b--
}
}
return false
}
}Explanation
Algorithm
Проверка границ
Проверьте, если c меньше 0, немедленно верните false, так как сумма квадратов двух целых чисел не может быть отрицательной.
Инициализация указателей
Используйте два указателя a и b. Инициализируйте a на 0 и b на значение квадратного корня из c. Поиск решения: Используйте цикл для поиска a и b, таких что a^2 + b^2 == c: Если a^2 + b^2 равно c, верните true. Если a^2 + b^2 меньше c, увеличьте a на 1. Если a^2 + b^2 больше c, уменьшите b на 1.
Возвращение результата
Если цикл завершится без нахождения подходящих a и b, верните false.
😎