이 질문은 다음과 같은 의미를 지닌 간단한 질문입니다.
두 개의 문자열 s와 t가 주어지면 s의 각 문자는 최대 한 번 나타나고 t는 s의 순열입니다.
s와 t 사이의 순열 차이는 s에서 각 문자의 발생 인덱스와 t에서 해당 문자의 발생 인덱스 간의 절대 차이의 합으로 정의됩니다.
s와 t의 순열 차이를 반환합니다.
예 1:
입력: s = "abc", t = "bac"
출력: 2
설명:
s = "abc" 및 t = "bac"의 경우 s와 t의 순열 차이는 다음의 합과 같습니다.
의 "a" 발생 지수와 t의 "a" 발생 지수 간의 절대 차이입니다.
의 "b" 발생 지수와 t의 "b" 발생 지수 간의 절대 차이입니다.
s에서 "c" 발생 지수와 t에서 "c" 발생 지수 간의 절대 차이입니다.
즉, s와 t의 순열 차이는 |0 - 1|1 - 0 |2 - 2|입니다.
예 2:
입력: s = "abcde", t = "edbac"
출력: 12
설명: s와 t의 순열 차이는 |0 - 3| |1 - 2| |3 - 1 |4 - 0|입니다.
제약조건:
1 ≤ s.길이 ≤ 100
의 각 문자는 최대 한 번 나타납니다.
t는 s의 순열입니다.
에는 영문 소문자만 포함됩니다.
제목 설명이 길지만 예시를 보시면 제목의 목적을 더 쉽게 이해하실 수 있습니다.
순열 차이 계산 방법에 따라 다음 단계를 수행해야 합니다.
- 문자열 탐색
- 색인을 기준으로 문자 검색
- 두 번째 문자열에서 문자의 인덱스를 찾습니다.
- 첫 번째 색인에서 두 번째 색인을 뺍니다.
- 이 뺄셈의 절대값을 구하고 모든 결과를 하나의 출력으로 누적합니다.
이제 이 아이디어를 Java 코드로 변환해 보겠습니다.
class Solution { public int findPermutationDifference(String s, String t) { int output = 0; for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); int j = t.indexOf(c); output += Math.abs(i - j); } return output; } }
실행 시간: 1ms, Java 온라인 제출의 100%보다 빠릅니다.
메모리 사용량: 42.67MB, Java 온라인 제출물의 57.64%보다 낮습니다.
성능이 좋은 솔루션입니다. 좀 더 우아하게 만들고 싶다면 스트리밍 처리를 사용하세요. 해결 방법은 다음과 같습니다.
class Solution { public int findPermutationDifference(String s, String t) { return IntStream.range(0, s.length()) .map(i -> findCharPermutationDifference(s,t,i)) .sum(); } public int findCharPermutationDifference(final String s, final String t, final int i) { final char c = s.charAt(i); final int j = t.indexOf(c); return Math.abs(i - j); } }
런타임: 5ms, Java 온라인 제출의 2.31%보다 빠릅니다.
메모리 사용량: 43.02MB, Java 온라인 제출물의 23.05% 미만입니다.
성능과 메모리 측면에서 첫 번째 솔루션만큼 좋지는 않지만 더 우아합니다.
—
그렇습니다! 다른 질문이 있으면 언제든지 댓글을 남겨주시고, 제가 놓친 부분이 있으면 알려주시기 바랍니다. 그러면 그에 따라 업데이트할 수 있습니다.
다음 글에서 만나요! :)
위 내용은 Leetcode — 두 문자열 간의 순열 차이의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

JVM은 JNI (JavanativeInterface) 및 Java 표준 라이브러리를 통한 운영 체제 API 차이를 처리합니다. 1. JNI는 Java 코드가 로컬 코드를 호출하고 운영 체제 API와 직접 상호 작용할 수 있습니다. 2. Java Standard Library는 통합 API를 제공하며,이 API는 내부적으로 다른 운영 체제 API에 매핑되어 코드가 플랫폼에서 실행되도록합니다.

modularityDoesNotDirectHeftJava'splatformincendence.java'splatformincendenceIngeasted whejvm, butModularItyInfluencesApplicationStructureAndmanagement, deploymentandDuffictionBecomeMoreferficaliticiboliticalWI

bytecodeinjavaistheintermediaterepresentation attenablesplatformincendence.1) javacodeiscompiledintobytecodestoredin.2) thejvminterpretsorcompilesthisbytecodeintomachinecodeartruntime, theCodeTorUnanynanynovice를 허용합니다

javaachievesplatformincendenceThoughthegroughthejavavirtualMachine (JVM), theexecutesByTecodeonAnyDeviceWitHajvm.1) javacodeiscompiledintobytecode.2) thejvm-mmectretsandexecutesThisteCodeIntomachineCificinStructions, 허용

Javagui 개발의 플랫폼 독립성은 과제에 직면하지만 Swing, Javafx, Unifying Locance, Performance Optimization, 타사 라이브러리 및 크로스 플랫폼 테스트를 사용하여 처리 할 수 있습니다. Javagui Development는 교차 플랫폼 일관성을 제공하는 것을 목표로하는 AWT 및 Swing에 의존하지만 실제 효과는 운영 체제마다 다릅니다. 솔루션은 다음과 같습니다. 1) Swing 및 Javafx 사용 GUI 툴킷으로 사용; 2) UIMANAGER.SETLOOKANDFEEL ()을 통해 외관을 통합합니다. 3) 다른 플랫폼에 맞게 성능을 최적화합니다. 4) apachepivot 또는 SWT와 같은 타사 라이브러리 사용; 5) 일관성을 보장하기 위해 크로스 플랫폼 테스트를 수행하십시오.

javadevelopmentisnotentirelyplatform-IndectionentDuetoSeveralFactors.1) JVMVARIATIONSAFFERFFERFORMANDBEHAVIORACROSSDIFFERENTOS.2) nativelibrariesViajniintrictionPlatform-specificiss.3) filepathsandsystempropertiesdifferbetweenplatectry. 4)

Java 코드는 다른 플랫폼에서 실행할 때 성능 차이가 있습니다. 1) JVM의 구현 및 최적화 전략은 OracleJDK 및 OpenJDK와 같이 다릅니다. 2) 메모리 관리 및 스레드 스케줄링과 같은 운영 체제의 특성도 성능에 영향을 미칩니다. 3) 적절한 JVM을 선택하여 JVM 매개 변수 및 코드 최적화를 조정하여 성능을 향상시킬 수 있습니다.

Java'SplatformIndenceHASLIMITATIONSINTERFORMANTOWORHEAD, 버전 컴포팅 가능성, 도전 과제, 플랫폼-특이 적 식품, 및 JVMINSTALLATION/MAYMENDENT.ThesefacteThe "WriteOnce, Runanywhere"


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.
