백엔드 개발 파이썬 튜토리얼 린트 코드 질문 기록 3

린트 코드 질문 기록 3

Jun 23, 2017 pm 03:49 PM
기록

Expression Expand Word Break II Partition Equal Subset Sum

Expression Expand

문자열 확장 문제, [] 앞의 숫자에 따라 문자열을 확장하고, 주로 두 개의 스택을 유지하는데, 하나는 숫자 스택을 확장하는 것이고 다른 하나는 콘텐츠 스택 확장, 콘텐츠 스택 추가 [확장할 콘텐츠를 모두 밀어낼지 여부를 결정하는 데 사용되며 숫자는 두 자리 이상일 수 있으므로 중요하지 않습니다.

class Solution:# @param {string} s  an expression includes numbers, letters and brackets# @return {string} a stringdef expressionExpand(self, s):# Write your code herenl=[]
        sl=[]
        sc=''res=''lstr=''for i in s:if i.isdigit():if not lstr.isdigit():
                    sl.append(sc)
                    sc=''sc = sc + ielse:if i=='[':
                    nl.append(int(sc))
                    sc = ''sl.append('[')elif i==']':
                    n=nl.pop()while len(sl)>0:
                        k=sl.pop()if k== '[':breaksc = k+ sc
                    ts=''for j in range(n):ts= ts + sc
                    sc=''if len(nl) > 0:sl.append(ts)else:
                        res = res + tselse:if len(nl)>0:
                        sc = sc + ielse:
                        res = res + i
            lstr=ireturn res
로그인 후 복사

Word Break. II

단어 분할 문제, 배열에서 처음부터 문자열 검색을 시작하고, 발견되면 스택에 추가하고, 팝된 문자열이 완전한지 확인하기 위해 매번 pop을 반복하고, 완성되면 결과를 추가합니다. 완료되지 않은 경우 후속 조치를 찾으십시오. 후속 조치를 찾으면 스택에 추가하고 다음 루프는 계속되지 않습니다. wordDict에 문자열이 있을 수 있습니다. 재사용될까?

문자열이 매우 길고 그 뒤에 사전 배열이 많으면 속도가 매우 느려질 것입니다. 현재로서는 어떤 최적화 알고리즘도 생각해 본 적이 없습니다. lintcode.특수한 경우가 하나 있어서 앞에 필터를 추가했는데 통과됐는데, 파이썬의 startwith 함수도 주의해야 합니다.

매개변수가 ''이면 항상 True를 반환하는데 좀 까다롭습니다. .. , 조건은 많은 숫자가 100을 초과하지 않는 정수이고 배열의 길이가 200을 초과하지 않아야 한다는 것입니다. 이것은 배낭 문제의 단순화된 버전입니다. 모든 숫자의 합이며, 짝수이면 두 그룹으로 나눌 수 있으며, 그렇지 않으면 바로 false를 반환한 후 그룹의 최종 합을 구합니다. 배낭 문제의 용량은 배낭에 넣을 물건과 비슷합니다. 배낭 문제와 다른 점은 배낭 문제에서는 그리드 값만 있으면 충분하다는 것입니다. 이 합계와 같습니다. 마지막 그리드까지 이동할 필요는 없습니다

class Solution:# @param {string} s a string# @param {set[str]} wordDict a set of wordsdef wordBreak(self, s, wordDict):# Write your code herehead=[]
        ss=''for i in s:if ss=='':
                ss=ielse:if i not in ss:
                    ss = ss + ifor i in ss:
            flag=Falsefor di in wordDict:if i in di:
                    flag=Truebreak;if not flag:return []for di in wordDict:if di !='' and  s.startswith(di):
                head.append(di)if len(head)<1:return []
        cur=s
        res=[]while len(head)>0:
            h=head.pop()
            le=len(h.replace(' ',''))
            cur=s[le:]if cur == '': 
                res.append(h)continuefor di in wordDict:if cur.startswith(di):
                    head.append(h+' '+di)                    return res
로그인 후 복사

위 내용은 린트 코드 질문 기록 3의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

핀둬둬에서 구매한 내역은 어디서 확인할 수 있나요? 구매한 내역은 어떻게 확인하나요? 핀둬둬에서 구매한 내역은 어디서 확인할 수 있나요? 구매한 내역은 어떻게 확인하나요? Mar 12, 2024 pm 07:20 PM

Pinduoduo 소프트웨어는 좋은 제품을 많이 제공하고 언제 어디서나 구입할 수 있으며 각 제품의 품질은 엄격하게 통제되고 모든 제품은 정품이며 우대 쇼핑 할인이 많아 누구나 온라인 쇼핑을 할 수 있습니다. 온라인으로 로그인하려면 휴대폰 번호를 입력하고, 온라인으로 여러 배송 주소와 연락처 정보를 추가하고, 다양한 카테고리의 제품 섹션을 언제든지 확인하고 구매하고 주문하세요. 집을 떠나지 않고도 편리함을 경험할 수 있습니다. 온라인 쇼핑 서비스를 이용하면 구매한 상품을 포함한 모든 구매 기록을 볼 수 있으며, 수십 개의 쇼핑 빨간 봉투와 쿠폰을 무료로 받을 수 있습니다. 이제 편집자가 자세한 온라인 정보를 제공합니다. Pinduoduo 사용자는 구매한 제품 기록을 볼 수 있습니다. 1. 휴대폰을 열고 핀둬둬 아이콘을 클릭하세요.

Linux 명령 기록을 보고 관리하는 방법 Linux 명령 기록을 보고 관리하는 방법 Aug 01, 2023 pm 09:17 PM

Linux에서 명령 기록을 보는 방법 Linux에서는 이전에 실행된 모든 명령 목록을 보려면 History 명령을 사용합니다. 이것은 매우 간단한 구문을 가지고 있습니다:historyhistory 명령과 쌍을 이루는 일부 옵션은 다음과 같습니다. 옵션 설명 -c는 현재 세션에 대한 명령 기록을 지웁니다. -w는 명령 기록을 파일에 기록합니다. -r은 기록 파일에서 명령 기록을 다시 로드합니다. n 최근 명령의 출력 수 제한 Linux 터미널에서 이전에 실행된 모든 명령 목록을 보려면 간단히 History 명령을 실행하십시오. 명령 기록을 보는 것 외에도 명령 기록을 관리하고 이전에 실행한 명령에 대한 수정을 수행할 수도 있습니다. 명령 기록을 검색하거나 기록을 완전히 삭제할 수도 있습니다.

iPhone에서 통화 기록을 확인하고 내보내는 방법은 무엇입니까? iPhone에서 통화 기록을 확인하고 내보내는 방법은 무엇입니까? Jul 05, 2023 pm 12:54 PM

iPhone의 통화 녹음은 종종 과소평가되며 iPhone의 가장 중요한 기능 중 하나입니다. 단순하기 때문에 이 기능은 매우 중요하며 장치에서 걸거나 받은 통화에 대한 중요한 통찰력을 제공할 수 있습니다. 업무 목적이든 법적 절차이든 통화 기록에 액세스하는 기능은 매우 중요할 수 있습니다. 간단히 말해서 통화 기록은 전화를 걸거나 받을 때마다 iPhone에 생성된 항목을 의미합니다. 이러한 로그에는 연락처 이름(또는 연락처로 저장되지 않은 경우 번호), 타임스탬프, 통화 시간, 통화 상태(전화 걸기, 부재중 또는 응답하지 않음)를 포함한 주요 정보가 포함됩니다. 이는 귀하의 의사소통 이력에 대한 간결한 기록입니다. 통화 기록에는 iPhone에 저장된 통화 기록 스트립이 포함됩니다.

iPhone의 건강 앱에서 약물 복용 기록을 보는 방법 iPhone의 건강 앱에서 약물 복용 기록을 보는 방법 Nov 29, 2023 pm 08:46 PM

iPhone을 사용하면 건강 앱에 약을 추가하여 매일 복용하는 약, 비타민, 보충제를 추적하고 관리할 수 있습니다. 그러면 장치에서 알림을 받을 때 복용했거나 건너뛴 약을 기록할 수 있습니다. 약을 기록한 후에는 건강을 추적하는 데 도움이 되도록 약을 복용하거나 건너뛴 빈도를 확인할 수 있습니다. 이번 포스팅에서는 iPhone의 건강 앱에서 선택한 약물의 로그 기록을 보는 방법을 안내하겠습니다. 건강 앱에서 약물 기록 기록을 보는 방법에 대한 간단한 가이드: 건강 앱> 찾아보기> 약품> 약품> 약품 선택> 옵션&a로 이동하세요.

C# 개발 조언: 로깅 및 모니터링 시스템 C# 개발 조언: 로깅 및 모니터링 시스템 Nov 22, 2023 pm 08:30 PM

C# 개발 제안: 로깅 및 모니터링 시스템 요약: 소프트웨어 개발 프로세스에서 로깅 및 모니터링 시스템은 중요한 도구입니다. 이 문서에서는 C# 개발에서 로깅 및 모니터링 시스템의 역할과 구현 제안을 소개합니다. 소개: 로깅 및 모니터링은 대규모 소프트웨어 개발 프로젝트에 필수적인 도구입니다. 이를 통해 프로그램의 실행 상태를 실시간으로 이해하고 문제를 신속하게 발견하고 해결할 수 있습니다. 이 문서에서는 C# 개발에서 로깅 및 모니터링 시스템을 사용하여 소프트웨어 품질과 개발 효율성을 향상시키는 방법에 대해 설명합니다. 로깅 시스템의 역할

Java 개발 프로젝트를 기록하고 모니터링하는 방법 Java 개발 프로젝트를 기록하고 모니터링하는 방법 Nov 03, 2023 am 10:09 AM

Java 개발 프로젝트를 기록하고 모니터링하는 방법 1. 배경 소개 인터넷의 급속한 발전으로 인해 점점 더 많은 회사에서 Java를 개발하고 다양한 유형의 애플리케이션을 구축하기 시작했습니다. 개발 과정에서 로깅과 모니터링은 무시할 수 없는 중요한 연결고리입니다. 로깅 및 모니터링을 통해 개발자는 적시에 문제를 발견하고 해결하여 애플리케이션의 안정성과 보안을 보장할 수 있습니다. 2. 로깅의 중요성 1. 문제 추적: 애플리케이션 오류가 발생할 경우 로깅을 통해 문제를 빠르게 찾을 수 있습니다.

iPhone에서 기록을 지우는 방법 iPhone에서 기록을 지우는 방법 Jun 29, 2023 pm 01:13 PM

Safari에서 iPhone 기록을 지우는 방법은 무엇입니까? Apple Safari에서 탐색 및 검색 기록을 삭제하려면 기기에서 설정 앱을 열어야 합니다. 설정을 선택한 후 아래로 스크롤하여 Safari를 선택해야 합니다. 그러면 다른 메뉴가 나타나고 기록 및 웹 사이트 데이터 지우기를 선택해야 합니다. 이제 메뉴에서 기록 및 데이터 지우기를 선택해야 합니다. 그러면 Apple의 Safari 브라우저에서 모든 검색 기록, 인터넷 사용 기록, 쿠키 및 데이터가 삭제됩니다. 이제 모든 이전 검색 기록과 검색 기록이 Safari에서 삭제됩니다. Safari에서 모든 검색 기록을 삭제하고 싶지 않은 경우

달리기 킬로미터를 기록하는 방법 달리기 트랙은 어디에 기록됩니까? 달리기 킬로미터를 기록하는 방법 달리기 트랙은 어디에 기록됩니까? Mar 12, 2024 am 11:10 AM

우리는 위의 내용이 사용자가 실시간으로 다양한 스포츠를 완료하는 데 도움이 될 수 있는 매우 좋은 스포츠 유형 소프트웨어라는 것을 알고 있으며 일부 실행 프로세스 중에 위의 궤적 중 일부를 볼 수도 있습니다. 사용자는 위의 기능 정보 중 일부에 대해 모르므로 오늘은 모든 사람이 다양한 기능을 더 잘 수행할 수 있도록 일부 내용과 경험에 대해 설명하겠습니다. 나만의 달리기에 대한 추적과 기록을 놓치지 마세요. 더 많은 고품질 콘텐츠가 여러분을 기다리고 있습니다. 또한 알고 싶다면 많은 흥미로운 전략 정보가 여러분을 기다리고 있습니다. 지금 편집자와 함께 살펴보세요.​

See all articles