비용이 포함된 최대 포인트 수
1937. 비용 대비 최대 포인트
난이도:중
주제: 배열, 동적 프로그래밍
m x n 정수 행렬 포인트(0-인덱스)가 제공됩니다. 0점부터 시작하여 행렬에서 얻을 수 있는 점수를 최대화하고 싶습니다.
포인트를 얻으려면 각 행에서 하나의 셀을 선택해야 합니다. 좌표(r, c)에서 셀을 선택하면 점수에 추가점[r][c]이 됩니다.
그러나 이전 행에서 선택한 셀에서 너무 멀리 있는 셀을 선택하면 점수를 잃게 됩니다. 인접한 두 행 r 및 r + 1(여기서 0 1) 및 (r + 1, c에서 셀을 선택합니다. 2)은 점수에서 abs(c1 - c2)를 뺍니다.
달성할 수 있는 최대포인트를 반환합니다.
abs(x)는 다음과 같이 정의됩니다.
-
x >= 0.
- -x는 x < 0.
예 1:
- 입력: l1 = [2,4,3], l2 = [5,6,4]
- 출력: 9
- 설명:
- 파란색 셀은 선택할 최적의 셀을 나타내며 좌표가 (0, 2), (1, 1), (2, 0)입니다.
- 점수에 3 + 5 + 3 = 11을 더합니다.
- 단, 점수에서 절대(2 - 1) + 절대(1 - 0) = 2를 빼야 합니다.
- 최종 점수는 11 - 2 = 9입니다.
예 2:
- 입력: 포인트 = [[1,5],[2,3],[4,2]]
- 출력: 11
- 설명:
- 파란색 셀은 선택할 최적의 셀을 나타내며 좌표가 (0, 1), (1, 1), (2, 0)입니다.
- 점수에 5 + 3 + 4 = 12를 더합니다.
- 단, 점수에서 절대(1 - 1) + 절대(1 - 0) = 1을 빼야 합니다.
- 최종 점수는 12 - 1 = 11입니다.
제약조건:
- m == 포인트.길이
- n == 포인트[r].길이
- 1 <= m, n <= 10
- 5 1 <= m * n <= 10
- 5 0 <= 포인트[r][c] <= 10
- 5
힌트:
- 동적 프로그래밍을 사용해 보세요.
- dp[i][j]는 points[i][j]가 선택한 가장 최근 셀인 경우 얻을 수 있는 최대 포인트 수입니다.
해결책:
해결책을 여러 단계로 나눌 수 있습니다.1단계: DP 배열 정의
2D 배열 dp를 사용합니다. 여기서 dp[i][j]는 i행과 j열의 셀을 선택하여 얻을 수 있는 최대 포인트를 나타냅니다.
2단계: DP 어레이 초기화
비용을 뺄 이전 행이 없으므로 dp의 첫 번째 행을 포인트의 첫 번째 행과 동일하게 초기화합니다.
3단계: 각 행의 DP 값 계산
각 후속 행에 대해 이전 행에서 전환하는 데 드는 비용을 고려하여 각 열에 가능한 최대 포인트를 계산합니다.
i-1행에서 i행으로의 전환을 효율적으로 계산하기 위해 왼쪽과 오른쪽에 두 개의 보조 배열을 사용할 수 있습니다.
-
left[j]는 왼쪽으로부터의 전환만을 고려하여 j번째 열에 대해 달성할 수 있는 최대값을 저장합니다.
- right[j]는 오른쪽으로부터의 전환만 고려하여 j번째 열에 대해 달성할 수 있는 최대값을 저장합니다.
i행의 각 열 j에 대해:
- 왼쪽[j] 또는 오른쪽[j]에 포인트[i][j]를 더한 최대값을 사용하여 dp[i][j]를 업데이트합니다.
결과는 dp 배열의 마지막 행에 있는 최대값이 됩니다.
이 솔루션을 PHP로 구현해 보겠습니다:
1937. 비용 대비 최대 포인트
설명:
- 왼쪽 및 오른쪽 배열: 이전 행의 값을 고려하여 각 셀에 대해 얻을 수 있는 최대 점수를 계산하고 열 간 이동으로 인한 페널티를 효율적으로 계산하는 데 도움이 됩니다.
- 동적 프로그래밍 접근 방식: 이 방법을 사용하면 각 행이 이전 행을 기반으로 계산되므로 대규모 행렬에 맞게 솔루션을 확장할 수 있습니다.
연락처 링크
이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!
이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.
- 링크드인
- 깃허브
위 내용은 비용이 포함된 최대 포인트 수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제

TosetupaPHPdevelopmentenvironmentonLinux,installPHPandrequiredextensions,setupawebserverlikeApacheorNginx,testwithaPHPfile,andoptionallyinstallMySQLandComposer.1.InstallPHPandextensionsviapackagemanager(e.g.,sudoaptinstallphpphp-mysqlphp-curlphp-mbst

두 개의 PHP 배열을 병합하고 고유 한 값을 유지하려면 두 가지 주요 방법이 있습니다. 1. 인덱스 어레이 또는 중복 제거의 경우 Array_Merge 및 Array_unique 조합을 사용하십시오. 먼저 Array_Merge ($ array1, $ array2)를 병합 한 다음 Array_Unique ()를 사용하여 모든 고유 한 값을 포함하는 새 배열을 가져옵니다. 2. 연관 배열 및 첫 번째 배열에서 키 값 쌍을 유지하려면 연산자를 사용하십시오. $ result = $ array1 $ array2는 첫 번째 배열의 키가 두 번째 배열에 의해 덮어 쓰지 않도록합니다. 이 두 가지 방법은 키 이름이 유지되는지 아니면 초점 만

비밀번호의 강도를 결정하려면 정기적이고 논리적 처리를 결합해야합니다. 기본 요구 사항은 다음과 같습니다. 1. 길이는 8 자리 이상입니다. 2. 적어도 소문자, 대문자 및 숫자를 포함합니다. 3. 특수 문자 제한을 추가 할 수 있습니다. 고급 측면의 관점에서, 문자의 지속적인 복제 및 증분/감소 시퀀스는 피해야하며, 이는 PHP 함수 감지가 필요합니다. 동시에, 블랙리스트를 소개하여 암호 및 123456과 같은 일반적인 약한 암호를 필터링해야합니다. 마지막으로 평가 정확도를 향상시키기 위해 ZXCVBN 라이브러리를 결합하는 것이 좋습니다.

PHP 파일 업로드를 안전하게 처리하려면 소스 및 유형을 확인하고 파일 이름 및 경로를 제어하고 서버 제한을 설정하고 미디어 파일을 두 번 처리해야합니다. 1. 토큰을 통한 CSRF를 방지하기 위해 업로드 소스를 확인하고 화이트리스트 제어를 사용하여 FINFO_FILE을 통해 실제 MIME 유형을 감지합니다. 2. 파일의 이름을 임의의 문자열로 바꾸고 감지 유형에 따라 비 WEB 디렉토리에 저장할 확장자를 결정하십시오. 3. PHP 구성 업로드 크기 및 임시 디렉토리 NGINX/APACHE는 업로드 디렉토리에 대한 액세스를 금지합니다. 4. GD 라이브러리는 잠재적 인 악성 데이터를 지우기 위해 그림을 다시 찾습니다.

PHP 변수 범위에 대한 일반적인 문제 및 솔루션에는 다음이 포함됩니다. 1. 기능 내에서 글로벌 변수에 액세스 할 수 없으며 글로벌 키워드 또는 매개 변수를 사용하여 전달해야합니다. 2. 정적 변수는 정적으로 선언되며 한 번만 초기화되며 값은 여러 통화 사이에 유지됩니다. 3. $ _get 및 $ _post와 같은 Hyperglobal 변수는 모든 범위에서 직접 사용할 수 있지만 안전한 필터링에주의를 기울여야합니다. 4. 익명 함수 사용 키워드를 통해 상위 범위 변수를 도입해야하며 외부 변수를 수정할 때는 참조를 전달해야합니다. 이러한 규칙을 마스터하면 오류를 피하고 코드 안정성을 향상시키는 데 도움이 될 수 있습니다.

PHP 주석 코드에는 세 가지 일반적인 방법이 있습니다. 1. // 또는 #을 사용하여 한 줄의 코드를 차단하며 // 사용하는 것이 좋습니다. 2. 사용 /.../ 여러 줄로 코드 블록을 랩핑하려면 중첩 할 수는 없지만 교차 할 수 있습니다. 3. 복합 기술 사용 / if () {} /와 같은 논리 블록을 제어하거나 편집기 바로 가기 키를 사용한 효율성을 향상시키기 위해서는 기호를 닫는 데주의를 기울이고 사용할 때 중첩을 피해야합니다.

PHP 의견을 작성하는 열쇠는 목적과 사양을 명확히하는 것입니다. 의견은 중복성이나 너무 단순성을 피하고 "수행 된 것"보다는 "왜"를 설명해야합니다. 1. 클래스 및 메소드 설명에 DocBlock (/*/)과 같은 통합 형식을 사용하여 가독성 및 도구 호환성을 향상시킵니다. 2. JS 점프가 수동으로 출력 해야하는 이유와 같은 논리의 이유를 강조합니다. 3. 복잡한 코드 전에 개요 설명을 추가하고 프로세스를 단계적으로 설명하고 전체 아이디어를 이해하는 데 도움이됩니다. 4. Todo 및 Fixme를 합리적으로 사용하여 할 일 항목과 문제를 표시하여 후속 추적 및 협업을 용이하게합니다. 주석이 양호하면 통신 비용을 줄이고 코드 유지 보수 효율성을 향상시킬 수 있습니다.

Ageneratorinphpisamemory- 효율적인 Way-Erate-Overgedatasetsetsbaluesoneatimeatimeatimeatimallatonce.1.generatorsuseTheyieldKeywordTocroadtOpvaluesondemand, RetingMemoryUsage.2
