>백엔드 개발 >Golang >데이터 변환: 세 번째 최대값 및 뒤죽박죽된 문자

데이터 변환: 세 번째 최대값 및 뒤죽박죽된 문자

Susan Sarandon
Susan Sarandon원래의
2024-10-05 10:32:29402검색

Data Transformations: Third Maximum and Jumbled Letters

이 기사에서는 Perl Weekly Challenge #289의 두 가지 흥미로운 작업에 대해 설명합니다. 즉, 배열에서 세 번째 고유한 최대값을 찾는 것과 텍스트의 단어 글자를 뒤섞는 것입니다. 첫 글자와 마지막 글자가 제자리에 있습니다. Perl과 Go 모두에서 솔루션을 구현하겠습니다.

목차

  1. 3번째 최대치
  2. 뒤섞인 글자
  3. 결론

세 번째 최대값

첫 번째 작업은 주어진 정수 배열에서 세 번째 고유한 최대값을 찾는 것입니다. 세 번째 최대값이 존재하지 않으면 함수는 최대값을 반환해야 합니다.

작업 설명

입력: 정수 배열, @ints.

출력: 세 번째 고유 최대값 또는 세 번째 최대값이 존재하지 않는 경우 최대값입니다.

  • 입력: @ints = (5, 6, 4, 1)
    출력: 4
    (고유한 최대값은 6, 5, 4입니다.)

  • 입력: @ints = (4, 5)
    출력: 5
    (세 번째 최대값은 존재하지 않습니다.)

  • 입력: @ints = (1, 2, 2, 3)
    출력: 1
    (고유한 최대값은 3, 2, 1입니다.)

해결책

펄 구현

이 구현에서는 고유한 값 세트를 생성한 다음 세 번째 최대값을 쉽게 찾을 수 있도록 내림차순으로 정렬합니다.


sub third_maximum {
    my @ints = @_;

    my %unique = map { $_ => 1 } @ints;
    my @distinct = sort { $b <=> $a } keys %unique;

    return @distinct >= 3 ? $distinct[2] : $distinct[0];
}


구현으로 이동

Go 구현은 맵을 사용하여 고유한 정수를 캡처한 다음 정렬하는 유사한 논리를 따릅니다.


func thirdMax(ints []int) (int, error) {
    if len(ints) == 0 {
        return 0, errors.New("input slice is empty")
    }

    unique := make(map[int]struct{})
    for _, num := range ints {
        unique[num] = struct{}{}
    }

    numsSorted := make([]int, 0, len(unique))
    for num := range unique {
        numsSorted = append(numsSorted, num)
    }

    sort.Slice(numsSorted, func(i, j int) bool {
        return numsSorted[i] > numsSorted[j]
    })

    if len(numsSorted) >= 3 {
        return numsSorted[2], nil
    }
    return numsSorted[0], nil
}


.

뒤죽박죽된 편지

두 번째 작업은 첫 글자와 마지막 글자가 그대로 유지되도록 하면서 주어진 텍스트에서 각 단어의 글자를 뒤섞는 것입니다. 공백과 구두점도 유지해야 합니다.

작업 설명

입력: 텍스트 문자열

출력: 입력 텍스트의 뒤죽박죽 버전입니다.

  • 입력: "케임브리지 대학의 연구에 따르면 단어의 문자 순서는 중요하지 않습니다."
  • 해결책

펄 구현

이 작업을 위해 두 가지 기능을 정의합니다.

jumble_word: 이 함수는 단어를 입력으로 받아 첫 글자와 마지막 글자는 그대로 유지하면서 가운데 ​​글자를 뒤섞습니다. 단어가 3글자 이하이면 변경되지 않고 반환됩니다. 문자를 섞기 위해 Perl의 List::Util 모듈을 사용합니다.
  1. jumble_text: 이 함수는 전체 텍스트 문자열을 처리하여 공백과 구두점을 유지하면서 단어로 분할합니다. 각 단어에 jumble_word 기능을 적용하여 단어만 뒤섞이도록 합니다.
.

use List::Util 'shuffle';

sub jumble_word {
    my ($word) = @_;

    return $word if length($word) <= 3;

    my $middle  = substr($word, 1, -1);
    my @m_chars = split('', $middle);
    @m_chars    = shuffle(@m_chars);

    my $subst = join('', @m_chars);
    substr($word, 1, -1, $subst);

    return $word;
}

sub jumble_text {
    my ($text) = @_;

    my @tokens = split(/(\W+|_)/, $text);

    for my $token (@tokens) {
        if ($token =~ /^[A-Za-z]+$/) {
            $token = jumble_word($token);
        }
    }

    return join('', @tokens);
}


구현으로 이동

Go 구현에서는 문자를 섞기 위해 math/rand 패키지를 활용하는 유사한 접근 방식을 채택합니다.

.

package main

import (
    "math/rand"
    "regexp"
    "strings"
    "time"
)

func jumbleWord(word string) string {
    if len(word) <= 3 {
        return word
    }

    middle := word[1 : len(word)-1]
    chars := []rune(middle)

    rand.Seed(time.Now().UnixNano())
    rand.Shuffle(len(chars), func(i, j int) {
        chars[i], chars[j] = chars[j], chars[i]
    })

    return string(word[0]) + string(chars) + string(word[len(word)-1])
}

func jumbleText(text string) string {
    re := regexp.MustCompile(`(\W+|_)`)
    tokens := re.Split(text, -1)
    nonWordTokens := re.FindAllString(text, -1)

    var result []string

    for i, token := range tokens {
        if isAlpha(token) {
            result = append(result, jumbleWord(token))
        }
        if i < len(nonWordTokens) {
            result = append(result, nonWordTokens[i])
        }
    }

    return strings.Join(result, "")
}

func isAlpha(s string) bool {
    re := regexp.MustCompile(`^[A-Za-z]+$`)
    return re.MatchString(s)
}


결론

이 기사에서는 두 가지 재미있는 코딩 문제, 즉 배열에서 세 번째 고유 최대값을 찾는 것과 텍스트에서 글자를 뒤섞는 방법을 살펴보았습니다. 이러한 작업은 서로 다른 프로그래밍 언어가 각각 고유한 장점과 방법론을 가지고 유사한 문제에 접근하는 방법을 보여줍니다. 이러한 사례를 통해 유사한 문제를 해결하고 Perl 및 Go의 기능을 탐색하는 데 영감을 얻으실 수 있기를 바랍니다.

GitHub에서 테스트를 포함한 전체 코드를 찾을 수 있습니다.

위 내용은 데이터 변환: 세 번째 최대값 및 뒤죽박죽된 문자의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.