주어진 문자열의 순열이 다른 주어진 문자열보다 사전순으로 큰지 확인합니다.
두 개의 문자열이 주어졌고 i번째 인덱스에서 한 순열이 다른 순열보다 더 큰 문자를 가질 수 있도록 주어진 문자열의 순열이 존재하는지 확인해야 합니다.
문자열을 정렬하고 문자열의 각 문자를 하나씩 비교하여 문제를 해결할 수 있습니다. 또는 두 문자열의 문자 빈도를 사용하여 문제를 해결할 수 있습니다.
문제 설명 - 길이가 N인 문자열 str1과 str2가 제공됩니다. 하나가 사전순으로 다른 것보다 큰 문자열 순열이 있는지 확인해야 합니다. 이는 모든 순열이 다른 문자열 순열의 i 번째 인덱스에 있는 문자보다 큰 i 번째 인덱스의 문자를 가져야 함을 의미합니다.
예
Input - str1 = "aef"; str2 = "fgh";
출력–예
설명 – 'fgh'는 이미 'aef'보다 큽니다. 여기서, a > f, g > e, h > f.
Input – str1 = "adsm"; str2 = "obpc";
출력–아니요
설명 – 한 문자열의 모든 문자가 다른 문자열보다 큰 순열을 찾을 수 없습니다.
방법 1
이 방법에서는 두 개의 문자열을 사전순으로 정렬합니다. 그런 다음 문자열의 각 문자를 비교합니다. str1의 모든 문자가 str2보다 작거나 str2의 모든 문자가 str1보다 작은 경우 true를 반환합니다. 그렇지 않으면 false를 반환합니다.
알고리즘
문자열을 정렬하려면 sort() 메서드를 사용하세요.
isStr1Greater 부울 변수를 정의하고 true로 초기화하세요.
문자열을 탐색하고 str1의 i번째 인덱스 위치에 있는 문자가 str2보다 작으면 isStr1Greater 값을 false로 업데이트하고 break 키워드를 사용하여 루프를 중단합니다
isStr1Greater가 true이면 루프가 성공적으로 완료되고 true를 반환합니다.
이제 문자열을 반복하여 str2가 str1보다 큰지 확인하세요. str1의 문자가 str2보다 크다면 false가 반환됩니다.
루프가 성공적으로 완료되면 true를 반환합니다.
예
으아아아출력
으아아아시간 복잡도 - O(N*logN) 왜냐하면 문자열을 정렬하기 때문입니다.
공간 복잡성 - 문자열을 정렬하려면 O(N)이 필요합니다.
방법 2
이 방법에서는 두 문자열 모두에 각 문자의 총 빈도를 저장합니다. 그런 다음 누적 빈도를 사용하여 하나가 다른 것보다 큰 문자열 순열을 찾을 수 있는지 결정합니다.
알고리즘
길이가 26인 map1 및 map2 배열을 정의하고 0으로 초기화합니다.
str1의 문자 빈도를 map1에 저장하고, str2의 문자 빈도를 map2에 저장합니다.
isStr1 및 isStr2 부울 변수를 정의하고 false로 초기화하여 str1이 str2보다 큰지 추적합니다.
문자열 문자의 누적 빈도를 저장하려면 cnt1 및 cnt2 변수를 정의하세요.
지도1과 지도2를 횡단하세요. cnt1에 map1[i]를 추가하고 cnt2에 map2[i]를 추가합니다.
cnt1이 cnt2보다 크면 str1부터 i번째 인덱스까지 문자의 누적 빈도가 더 큽니다. 그렇다면 str2가 이미 더 크면 false를 반환합니다. 그렇지 않으면 isStr1을 true
로 변경하세요.
cnt2가 cnt1보다 크면 str2의 i번째 인덱스에 있는 문자의 누적 빈도가 더 큽니다. 그렇다면 str1이 이미 더 크면 false를 반환합니다. 그렇지 않으면 isStr2를 true
로 변경하세요.
마침내 true를 반환합니다.
예
으아아아출력
으아아아시간 복잡도 - 문자의 빈도를 계산하므로 O(N)입니다.
공간 복잡성 - 배열에 문자의 빈도를 저장하기 때문에 O(26)입니다.
한 문자열의 모든 문자가 다른 문자열보다 클 수 있도록 두 문자열의 순열이 있는지 확인하는 방법을 배웠습니다. 첫 번째 방법은 정렬 방법을 사용하고 두 번째 방법은 문자의 누적 빈도를 사용합니다.
위 내용은 주어진 문자열의 순열이 다른 주어진 문자열보다 사전순으로 큰지 확인합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











요즘 휴대폰의 성능과 기능은 점점 더 강력해지고 있습니다. 거의 모든 휴대폰에는 사용자의 모바일 결제 및 신원 인증을 용이하게 하는 편리한 NFC 기능이 탑재되어 있습니다. 그러나 일부 Xiaomi 14Pro 사용자는 NFC 기능을 활성화하는 방법을 모를 수 있습니다. 다음으로 자세히 소개해드리겠습니다. Xiaomi 14Pro에서 NFC 기능을 활성화하는 방법은 무엇입니까? 1단계: 휴대폰의 설정 메뉴를 엽니다. 2단계: "연결 및 공유" 또는 "무선 및 네트워크" 옵션을 찾아 클릭합니다. 3단계: 연결 및 공유 또는 무선 및 네트워크 메뉴에서 "NFC 및 결제"를 찾아 클릭합니다. 4단계: "NFC 스위치"를 찾아서 클릭하세요. 일반적으로 기본값은 꺼짐입니다. 5단계: NFC 스위치 페이지에서 스위치 버튼을 클릭하여 켜세요.

WPS는 당사에서 흔히 사용하는 사무용 소프트웨어입니다. 긴 글을 편집할 때 글꼴이 너무 작아서 선명하게 보이지 않는 경우가 많아 글꼴과 전체 문서가 조정됩니다. 예를 들어 문서의 줄 간격을 조정하면 문서 전체가 매우 명확해집니다. 오늘은 구체적인 작업 단계를 알려드리겠습니다. 와서 살펴보세요. 조정하려는 WPS 텍스트 파일을 열고 [시작] 메뉴에서 단락 설정 툴바를 찾으면 작은 줄 간격 설정 아이콘(그림에서 빨간색 원으로 표시)이 표시됩니다. 2. 줄 간격 설정 오른쪽 하단에 있는 작은 역삼각형을 클릭하면 해당 줄 간격 값이 나타납니다. 줄 간격의 1~3배를 선택할 수 있습니다(그림의 화살표 참조). 3. 또는 해당 단락을 마우스 오른쪽 버튼으로 클릭하면 나타납니다.

화면을 공중으로 밀어내는 것은 화웨이 메이트60 시리즈에서 높은 평가를 받는 화웨이의 기능이다. 이 기능은 휴대폰의 레이저 센서와 전면 카메라의 3D 깊이 카메라를 활용해 화면이 필요 없는 일련의 기능을 완성한다. 공중에서 TikTok을 스와이프하는 등 화면을 터치하는 기능이 있는데, Huawei Pocket 2를 사용하여 공중에서 TikTok을 스와이프하는 방법은 무엇인가요? Huawei Pocket2로 공중에서 스크린샷을 찍는 방법은 무엇입니까? 1. Huawei Pocket2의 설정을 엽니다. 2. 그런 다음 [접근성]을 선택합니다. 3. 클릭하여 [스마트 인식]을 엽니다. 4. [에어 스와이프 스크린], [에어 스크린샷], [에어 프레스] 스위치를 켜기만 하면 됩니다. 5. 사용 시 화면에서 20~40CM 거리를 두고 손바닥을 펴고 화면에 손바닥 아이콘이 나타날 때까지 기다려야 합니다.

아이폰16 프로의 CAD 파일이 노출됐는데, 디자인은 기존 루머와 일치한다. 지난해 가을 아이폰 15 프로에는 액션 버튼이 추가됐고, 올 가을 애플은 하드웨어 크기를 소폭 조정할 계획인 것으로 보인다. 캡처 버튼 추가 소문에 따르면 아이폰 16 프로는 두 번째 새 버튼을 추가할 수도 있는데, 이는 지난해에 이어 2년 연속 새 버튼이 추가되는 셈이다. 아이폰 16 프로에서는 새로운 캡처 버튼이 오른쪽 하단에 배치될 것이라는 소문이 돌고 있다. 이 디자인은 카메라 제어를 더욱 편리하게 하고 액션 버튼을 다른 기능에도 사용할 수 있게 할 것으로 예상된다. 이 버튼은 더 이상 일반 셔터 버튼이 아닙니다. 카메라에 관해서는 현재 iP에서

Redmi K70E는 가격이 2,000위안이 조금 넘는 휴대폰으로서 의심할 여지 없이 우수합니다. Redmi K70E는 동급 휴대폰 중 가장 비용 효율적인 휴대폰 중 하나라고 할 수 있습니다. 가성비를 추구하는 많은 사용자들이 Redmi K70E의 다양한 기능을 경험하기 위해 이 휴대폰을 구입했습니다. 그렇다면 Redmi K70E에 대한 사용자 정의 벨소리를 설정하는 방법은 무엇입니까? Redmi K70E에 대한 사용자 정의 벨소리를 설정하는 방법은 무엇입니까? Redmi K70E에 대한 사용자 정의 수신 전화 벨소리를 설정하려면 다음 단계를 따르십시오. 휴대폰의 설정 애플리케이션을 열고 설정 애플리케이션에서 "소리 및 진동" 또는 "소리" 옵션을 찾은 다음 "수신 전화 벨소리"를 클릭하십시오. 또는 "전화 벨소리" "옵션. 벨소리 설정에서

Microsoft Teams에서는 선택할 수 있는 언어가 많은데 언어를 전환하는 방법은 무엇입니까? 사용자는 메뉴를 클릭한 다음 설정을 찾아 일반을 선택한 다음 언어를 클릭하고 언어를 선택하고 저장해야 합니다. 언어 전환 방법에 대한 소개는 다음과 같습니다. 자세한 내용을 살펴보세요. 술집! Microsoft Teams에서 언어를 전환하는 방법 답변: 설정-일반-언어에서 특정 프로세스를 선택합니다. 1. 먼저 아바타 옆에 있는 세 개의 점을 클릭하여 설정으로 들어갑니다. 2. 그런 다음 내부의 일반 옵션을 클릭하십시오. 3. 그런 다음 언어를 클릭하고 아래로 스크롤하여 더 많은 언어를 확인하세요. 4. 마지막으로 저장하고 다시 시작을 클릭합니다.

C 언어와 PHP의 차이점 및 비교 분석 C 언어와 PHP는 모두 일반적인 프로그래밍 언어이지만 여러 측면에서 분명한 차이점이 있습니다. 이 기사에서는 C 언어와 PHP를 비교 분석하고 구체적인 코드 예제를 통해 이들 간의 차이점을 설명합니다. 1. 구문 및 사용법: C 언어: C 언어는 프로세스 지향 프로그래밍 언어로 주로 시스템 수준 프로그래밍 및 임베디드 개발에 사용됩니다. C 언어의 구문은 상대적으로 간단하고 저수준이며, 메모리를 직접 조작할 수 있고 효율적이고 유연합니다. C 언어는 프로그래머의 프로그램 완성도를 강조합니다.

PHP7.2와 5의 장단점 비교 및 분석. PHP는 매우 널리 사용되는 서버 측 스크립팅 언어이며 웹 개발에 널리 사용됩니다. 그러나 PHP는 변화하는 요구 사항을 충족하기 위해 다양한 버전으로 지속적으로 업데이트되고 개선되고 있습니다. 현재 PHP7.2는 최신 버전으로, 이전 PHP5 버전과 비교하여 주목할 만한 많은 차이점과 개선 사항이 있습니다. 이 기사에서는 PHP7.2와 PHP5 버전을 비교하고, 장점과 단점을 분석하고, 구체적인 코드 예제를 제공합니다. 1. 성능 PH
