Что касается проблемы с Leetcode, вот мое решение на PHP. Большинство найденных примеров - это Python, и они намного короче при использовании наборов.
Сам вопрос не касается целевого пространства или временной сложности, и мой вопрос заключается в том, существует ли более эффективное решение PHP.
class Solution {
/**
* @param String[] $strs
* @return String[][]
*/
function groupAnagrams($strs) {
$result = [];
$alreadyPlaced = [];
$currentPalindromes = [];
$hashed = [];
foreach($strs as $key => $str) {
// create assoc array mapping letter to index of str its from
if ( array_key_exists($key, $alreadyPlaced) ) continue;
// mark this as placed
$alreadyPlaced[$key] = true;
// initiatilize new array and place into new array
$currentPalindromes = array();
array_push($currentPalindromes, $str);
// to be able to determine palindromes, hash each letter in the newly found string
$hashed = array();
foreach (str_split($str) as $c) {
$hashed[$c] = true;
}
//loop thru all strings skipping those of not same length or already accounted for
foreach($strs as $checkKey => $checkVal) {
$breakout = false;
if (mb_strlen($checkVal) != mb_strlen($str)) continue;
if (array_key_exists($checkKey, $alreadyPlaced)) continue;
foreach (str_split($checkVal) as $c) {
if (!$hashed[$c]) {
$breakout = true;
continue;
}
}
if ($breakout) continue;
// if it got here, its a palindrome
array_push($currentPalindromes, $checkVal);
$alreadyPlaced[$checkKey] = true;
}
//add new palindrome array into $result array
array_push($result, $currentPalindromes);
}
return $result;
}
Подробнее здесь: https://stackoverflow.com/questions/792 ... -structure
PHP-решение для Leetcode «групповых анаграмм» без заданной структуры данных ⇐ Php
Кемеровские программисты php общаются здесь
1732928233
Anonymous
Что касается проблемы с Leetcode, вот мое решение на PHP. Большинство найденных примеров - это Python, и они намного короче при использовании наборов.
Сам вопрос не касается целевого пространства или временной сложности, и мой вопрос заключается в том, существует ли более эффективное решение PHP.
class Solution {
/**
* @param String[] $strs
* @return String[][]
*/
function groupAnagrams($strs) {
$result = [];
$alreadyPlaced = [];
$currentPalindromes = [];
$hashed = [];
foreach($strs as $key => $str) {
// create assoc array mapping letter to index of str its from
if ( array_key_exists($key, $alreadyPlaced) ) continue;
// mark this as placed
$alreadyPlaced[$key] = true;
// initiatilize new array and place into new array
$currentPalindromes = array();
array_push($currentPalindromes, $str);
// to be able to determine palindromes, hash each letter in the newly found string
$hashed = array();
foreach (str_split($str) as $c) {
$hashed[$c] = true;
}
//loop thru all strings skipping those of not same length or already accounted for
foreach($strs as $checkKey => $checkVal) {
$breakout = false;
if (mb_strlen($checkVal) != mb_strlen($str)) continue;
if (array_key_exists($checkKey, $alreadyPlaced)) continue;
foreach (str_split($checkVal) as $c) {
if (!$hashed[$c]) {
$breakout = true;
continue;
}
}
if ($breakout) continue;
// if it got here, its a palindrome
array_push($currentPalindromes, $checkVal);
$alreadyPlaced[$checkKey] = true;
}
//add new palindrome array into $result array
array_push($result, $currentPalindromes);
}
return $result;
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79238592/php-solution-to-leetcode-group-anagrams-without-set-data-structure[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия