249. Group Shifted Strings

LeetCode medium original: C# #array #csharp #graph #hash-table #leetcode #medium #string
선택한 UI 언어에 맞게 문제 텍스트를 러시아어에서 번역합니다. 코드는 변경하지 않습니다.

Выполните следующие операции сдвига на строке:

Правый сдвиг: замените каждую букву следующей буквой английского алфавита, где 'z' заменяется на 'a'. На예제, "abc" можно сдвинуть вправо на "bcd" или "xyz" можно сдвинуть вправо на "yza".

Левый сдвиг: замените каждую букву предыдущей буквой английского алфавита, где 'a' заменяется на 'z'. На예제, "bcd" можно сдвинуть влево на "abc" или "yza" можно сдвинуть влево на "xyz".

Мы можем продолжать сдвигать строку в обоих направлениях, чтобы сформировать бесконечную последовательность сдвигов.

На예제, сдвиньте "abc", чтобы сформировать последовательность: ... <-> "abc" <-> "bcd" <-> ... <-> "xyz" <-> "yza" <-> .... <-> "zab" <-> "abc" <-> ...

Вам дан 배열 строк strings, сгруппируйте все strings[i], которые принадлежат одной и той же последовательности сдвигов. Ответ можно вернуть в любом порядке.

예제

Input: strings = ["abc","bcd","acef","xyz","az","ba","a","z"]

Output: [["acef"],["a","z"],["abc","bcd","xyz"],["az","ba"]]

C# 해법

매칭됨/원본
using System;
using System.Collections.Generic;
using System.Text;
public class Solution {
    private char ShiftLetter(char letter, int shift) {
        return (char) ((letter - shift + 26) % 26 + 'a');
    }
    
    private string GetHash(string s) {
        int shift = s[0];
        StringBuilder hashKey = new StringBuilder();
        
        foreach (char letter in s) {
            hashKey.Append(ShiftLetter(letter, shift));
        }
        
        return hashKey.ToString();
    }
    
    public IList<IList<string>> GroupStrings(IList<string> strings) {
        var mapHashToList = new Dictionary<string, IList<string>>();
        
        foreach (string str in strings) {
            string hashKey = GetHash(str);
            if (!mapHashToList.ContainsKey(hashKey)) {
                mapHashToList[hashKey] = new List<string>();
            }
            mapHashToList[hashKey].Add(str);
        }
        
        var groups = new List<IList<string>>();
        foreach (var pair in mapHashToList) {
            groups.Add(pair.Value);
        }
        
        return groups;
    }
}

C++ 해법

자동 초안, 제출 전 검토
#include <bits/stdc++.h>
using namespace std;

// Auto-generated C++ draft from the C# solution. Review containers, LINQ and helper types before submit.
class Solution {
public:
    private char ShiftLetter(char letter, int shift) {
        return (char) ((letter - shift + 26) % 26 + 'a');
    }
    
    private string GetHash(string s) {
        int shift = s[0];
        StringBuilder hashKey = new StringBuilder();
        
        foreach (char letter in s) {
            hashKey.Append(ShiftLetter(letter, shift));
        }
        
        return hashKey.ToString();
    }
    
    public IList<vector<string>> GroupStrings(vector<string> strings) {
        var mapHashToList = new unordered_map<string, vector<string>>();
        
        foreach (string str in strings) {
            string hashKey = GetHash(str);
            if (!mapHashToList.count(hashKey)) {
                mapHashToList[hashKey] = new List<string>();
            }
            mapHashToList[hashKey].push_back(str);
        }
        
        var groups = new List<vector<string>>();
        foreach (var pair in mapHashToList) {
            groups.push_back(pair.Value);
        }
        
        return groups;
    }
}

Java 해법

매칭됨/원본
class Solution {
    private char shiftLetter(char letter, int shift) {
        return (char) ((letter - shift + 26) % 26 + 'a');
    }
    
    private String getHash(String s) {
        int shift = s.charAt(0);
        StringBuilder hashKey = new StringBuilder();
        
        for (char letter : s.toCharArray()) {
            hashKey.append(shiftLetter(letter, shift));
        }
        
        return hashKey.toString();
    }
    
    public List<List<String>> groupStrings(String[] strings) {
        Map<String, List<String>> mapHashToList = new HashMap<>();
        
        for (String str : strings) {
            String hashKey = getHash(str);
            mapHashToList.computeIfAbsent(hashKey, k -> new ArrayList<>()).add(str);
        }
        
        return new ArrayList<>(mapHashToList.values());
    }
}

JavaScript 해법

매칭됨/원본
class Solution {
    shiftLetter(letter, shift) {
        return String.fromCharCode((letter.charCodeAt(0) - shift + 26) % 26 + 'a'.charCodeAt(0));
    }

    getHash(s) {
        const shift = s.charCodeAt(0);
        return Array.from(s, letter => this.shiftLetter(letter, shift)).join('');
    }

    groupStrings(strings) {
        const mapHashToList = new Map();

        for (const str of strings) {
            const hashKey = this.getHash(str);
            if (!mapHashToList.has(hashKey)) {
                mapHashToList.set(hashKey, []);
            }
            mapHashToList.get(hashKey).push(str);
        }

        return Array.from(mapHashToList.values());
    }
}

Python 해법

매칭됨/원본
class Solution:
    def shiftLetter(self, letter, shift):
        return chr((ord(letter) - shift + 26) % 26 + ord('a'))
    
    def getHash(self, s):
        shift = ord(s[0])
        hashKey = ''.join(self.shiftLetter(letter, shift) for letter in s)
        return hashKey
    
    def groupStrings(self, strings):
        mapHashToList = defaultdict(list)
        
        for str in strings:
            hashKey = self.getHash(str)
            mapHashToList[hashKey].append(str)
        
        return list(mapHashToList.values())

Go 해법

매칭됨/원본
package main

import (
    "fmt"
    "strings"
)

func shiftLetter(letter byte, shift int) byte {
    return (letter - byte(shift) + 26) % 26 + 'a'
}

func getHash(s string) string {
    shift := s[0] - 'a'
    var hashKey strings.Builder
    
    for i := 0; i < len(s); i++ {
        hashKey.WriteByte(shiftLetter(s[i], int(shift)))
    }
    
    return hashKey.String()
}

func groupStrings(strings []string) [][]string {
    mapHashToList := make(map[string][]string)
    
    for _, str := range strings {
        hashKey := getHash(str)
        mapHashToList[hashKey] = append(mapHashToList[hashKey], str)
    }
    
    groups := [][]string{}
    for _, v := range mapHashToList {
        groups = append(groups, v)
    }
    
    return groups
}

func main() {
    strings := []string{"abc", "bcd", "acef", "xyz", "az", "ba", "a", "z"}
    result := groupStrings(strings)
    fmt.Println(result)
}

Algorithm

1️⃣

Переберите строки, и для каждой строки find ее хэш-значение, сдвигая все символы так, чтобы 문자열 начиналась с 'a'. Значение сдвига равно позиции первого символа строки, и каждый символ сдвигается на это значение с учетом модуля 26.

2️⃣

Сопоставьте оригинальную строку с найденным хэш-значением в карте mapHashToList, добавляя оригинальную строку в список, соответствующий ее хэш-значению.

3️⃣

Переберите mapHashToList и сохраните список для каждого ключа в карте в 배열 ответа groups.

😎

Vacancies for this task

활성 채용 with overlapping task tags are 표시됨.

전체 채용
아직 활성 채용이 없습니다.