목차
문제 처리
문법
지침
알고리즘
따라야 할 방법
방법 1
示例 2
输出
方法2
结论
백엔드 개발 C++ 주어진 조건에 따라 다음을 중국어로 번역하십시오. 주어진 조건에 따라 빈 문자열의 인덱스 합계를 얻으려면 문자를 제거하십시오.

주어진 조건에 따라 다음을 중국어로 번역하십시오. 주어진 조건에 따라 빈 문자열의 인덱스 합계를 얻으려면 문자를 제거하십시오.

Sep 02, 2023 pm 03:29 PM
성격 삭제 상태

주어진 조건에 따라 다음을 중국어로 번역하십시오. 주어진 조건에 따라 빈 문자열의 인덱스 합계를 얻으려면 문자를 제거하십시오.

빈 문자열을 얻기 위해 제거된 문자 인덱스의 합과 같은 문자열 조작과 관련된 개념은 프로그래밍 과제 및 대회에서 자주 사용됩니다. 그런 다음 제거된 문자 인덱스의 합계를 사용하여 결과가 계산됩니다.

빈 문자열을 얻기 위해 문자의 인덱스 합계를 제거하는 것은 다양한 프로그래밍 어려움과 문제를 해결하는 데 사용할 수 있는 문자열 조작의 실용적인 아이디어입니다.

문제 처리

빈 문자열을 생성하기 위해 제거되는 문자 인덱스의 총 개수를 찾으려면 먼저 문제 설명과 주어진 기준을 이해해야 합니다.

문자열 S가 주어졌을 때, 문자열을 비워둔 채로 S에서 제거할 수 있는 총 문자 수를 결정하는 것이 목표입니다. 예를 들어, S = "code"인 경우 위치 0, 4, 5 및 6의 문자를 제거하여 빈 문자열을 얻을 수 있습니다. 이 지수의 합은 0 + 4 + 5 + 6 = 15입니다.

그러나 스택을 사용하는 것은 이 문제를 해결하기 위한 일반적인 전략입니다. 문자열 S를 반복하여 각 반복에서 각 문자를 제거할 수 있는지 여부를 확인할 수 있습니다. 인덱스를 제거할 수 있으면 스택에 추가할 수 있습니다. 제거할 수 없는 경우 기존 문자와 함께 스택 맨 위에 있는 문자를 제거할 수 있는지 확인할 수 있습니다. 제거할 수 있으면 그렇게 하고 해당 인덱스를 현재 문자의 인덱스에 추가합니다. 이 프로세스는 문자열의 모든 문자가 처리될 때까지 반복될 수 있습니다.

다음 의사코드는 이 전략을 보여줍니다 -

으아아아

이 의사코드에서는 합계 변수와 빈 스택이 모두 0으로 초기화됩니다. 그런 다음 for 루프를 사용하여 문자열 S를 반복적으로 반복합니다. 각 문자를 확인하여 맨 위에 있는 문자와 함께 제거할 수 있는지 확인하세요. 스택(스택이 비어 있지 않은 경우) 가능하다면 캐릭터가 스택에서 제거되고 해당 인덱스와 게임 내 캐릭터의 합이 sum 변수에 추가됩니다. 이 경우 해당 인덱스를 스택에 추가하고 제거하려고 합니다. 그런 다음 합계 변수를 반환합니다.

이 방법의 시간 복잡도와 공간 복잡도는 모두 O(n)입니다. 여기서 n은 문자열 S의 길이이고 n은 S에서 삭제할 수 있는 최대 문자 수입니다.

문법

지정된 조건에 따라 빈 문자열을 생성하여 제거되는 총 문자 인덱스 수를 결정하는 C++ 구문은 다음과 같습니다. -

지침

  • 먼저 사용자가 입력한 문자열을 가져옵니다.

  • n의 시작 값을 문자열 str의 길이로 설정했습니다.

  • 다음으로 cnt를 0으로 초기화하여 문자 "U"의 발생 횟수를 계산합니다.

  • sum의 초기값을 0으로 설정하여 제거된 문자 인덱스의 총 개수를 저장합니다.

  • 그 후 str을 반복하여 아래와 같이 각 문자를 확인합니다. -

    • 문자가 "U"이면 cnt를 올리고 합계를 (n - i - 1) + 2 * cnt만큼 늘립니다.

    • 문자가 "U"가 아닌 경우 i + 2 * cnt를 추가하여 합을 늘립니다.

  • 마지막으로 sum 값을 출력합니다.

NOTE - 이 질문의 구체적인 내용이 명시적으로 명시되어 있지 않으므로 이러한 조건으로 가정합니다.

으아아아

알고리즘

정의된 조건에서 빈 문자열을 생성하여 제거된 문자 인덱스의 총 개수를 계산하는 C++ 알고리즘 -

  • 1단계 - 먼저 문자열 변수를 정의하고 사용자가 제공한 문자열을 입력합니다.

  • 2단계 - 문자열의 문자를 담을 스택을 만듭니다.

  • 3단계 - 문자열 루프를 문자별로 입력합니다.

  • 4단계 - 현재 문자가 비어 있으면 스택에 밀어 넣습니다.

  • 5단계 - 현재 문자와 스택의 최상위 문자가 동일하면 스택에서 최상위 문자를 팝합니다.

  • 6단계 - 현재 문자가 스택 맨 위에 있는 문자와 다른 경우 해당 문자를 스택에 밀어 넣습니다.

  • 7단계 - 루프 후에는 지울 수 없는 문자만 스택에 남게 됩니다.

  • 8단계 - 아직 스택에 있는 문자 인덱스를 추가합니다.

  • 9단계 - 총 인덱스 수를 표시합니다.

따라야 할 방법

방법 1

다음 조건을 사용하여 문자 제거 인덱스의 합을 계산하여 빈 문자열을 생성합니다. -

이 예에서는 "abacbdc" 문자열이 입력으로 사용되었습니다. 이 코드는 두 개의 인덱스 i와 j를 사용하여 문자열을 처음부터 끝까지 순회합니다. 문자열에서 문자를 제거하는 조건은 다음과 같습니다.

s[i]와 s[j]가 같으면 두 인덱스를 모두 문자열 중앙으로 이동합니다.

  • s[i]가 s[j]보다 작으면 인덱스 j의 문자를 삭제하고 인덱스 i+1만큼 인덱스 합을 늘립니다.

  • s[i]가 s[j]보다 큰 경우 인덱스 i의 문자를 삭제하고 인덱스 j+1만큼 인덱스 합을 늘립니다.

모든 캐릭터가 제거된 후 인덱스 합계를 콘솔에 보고합니다.

단 예시일 뿐이며, 문제의 성격에 따라 캐릭터 삭제 요구사항이 변경될 수 있다는 점 참고해주세요.

示例 1

#include <iostream>
#include <string>

using namespace std;

int main() {
   string s = "abacbdc";
   int sum = 0;
   int i = 0;
   int j = s.length() - 1;
   while (i < j) {
      if (s[i] == s[j]) {
         i++;
         j--;
      } else if (s[i] < s[j]) {
         sum += i + 1;
         i++;
         s.erase(j, 1);
         j--;
      } else {
         sum += j + 1;
         j--;
         s.erase(i, 1);
         i++;
      }
   }
   cout << "Sum of indices of characters removed: " << sum << endl;
   return 0;
}
로그인 후 복사

输出

Sum of indices of characters removed: 6
로그인 후 복사

方法2

str 字符串和字符是 sum_of_indices 函数的输入。然后,迭代字符串,确定每个字符是否等于 c。如果是这样,函数会递减循环索引以考虑删除的字符,并将字符的索引添加到运行总数中,然后使用擦除技术从字符串中删除字符。然后该函数返回已消除的字符索引的总数。

示例字符串 str 和字符 c 在 main 函数中定义,这两个输入用于调用 sum_of_indices 函数。总数作为结果打印到控制台。

示例 2

#include <iostream>
#include <string>
using namespace std;
int sum_of_indices(string str, char c) {
   int sum = 0;
   for (int i = 0; i < str.length(); i++) {
      if (str[i] == c) {
         sum += i;
         str.erase(i, 1);
         i--;
      }
   }
   return sum;
}
int main() {
   string str = "abcbcdc";
   char c = 'c';
   int sum = sum_of_indices(str, c);
   cout << "Sum of indices of characters removed to obtain empty string: " << sum << endl;
   return 0;
}
로그인 후 복사

输出

Sum of indices of characters removed to obtain empty string: 9
로그인 후 복사

结论

需要操作字符串及其索引来解决根据提供的条件计算消除的字符索引之和以获得空字符串的问题。为了解决这个问题,循环遍历字符串,如果两个连续字符相同,则在更新索引之前删除它们。一旦我们有了一个空字符串,我们就可以添加被删除的字符的索引以产生一个空字符串。

有许多解决方案需要解决,例如利用堆栈或队列来跟踪要删除的字符,或者使用递归来迭代地从字符串中删除字符。

위 내용은 주어진 조건에 따라 다음을 중국어로 번역하십시오. 주어진 조건에 따라 빈 문자열의 인덱스 합계를 얻으려면 문자를 제거하십시오.의 상세 내용입니다. 자세한 내용은 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 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

inetpub 폴더를 삭제할 수 있나요? C 드라이브의 inetpub 폴더를 빠르게 삭제하는 방법 inetpub 폴더를 삭제할 수 있나요? C 드라이브의 inetpub 폴더를 빠르게 삭제하는 방법 Mar 13, 2024 pm 02:00 PM

컴퓨터의 C 드라이브에 메모리를 많이 차지하는 inetpub 폴더가 있는 것으로 나타났습니다. 이 inetpub 폴더는 무엇인가요? 바로 삭제가 가능한가요? 실제로 inetpub는 IIS 서버의 폴더입니다. IIS의 전체 이름은 인터넷 정보 서비스(Internet Information Services)입니다. 웹 사이트를 구축하고 디버깅하는 데 사용할 수 있으며, 필요하지 않으면 제거할 수 있습니다. 구체적인 방법은 다음과 같습니다. 1. 시작 메뉴를 마우스 오른쪽 버튼으로 클릭하고 "프로그램 및 기능"을 선택합니다. 2. 실행 후 "Windows 기능 켜기/끄기"를 클릭합니다. 3. Windows 기능 목록에서 II를 선택 취소합니다.

Xiaohongshu 메모를 삭제하는 방법 Xiaohongshu 메모를 삭제하는 방법 Mar 21, 2024 pm 08:12 PM

Xiaohongshu 메모를 삭제하는 방법 Xiaohongshu 앱에서 메모를 편집할 수 있습니다. 다음으로 편집기는 Xiaohongshu 메모 삭제 방법에 대한 사용자 사진과 텍스트를 가져옵니다. 보세요! Xiaohongshu 사용 튜토리얼 Xiaohongshu 메모 삭제 방법 1. 먼저 Xiaohongshu 앱을 열고 메인 페이지로 들어가서 오른쪽 하단에 있는 [Me]를 선택하여 특별 영역으로 들어갑니다. 2. 그런 다음 내 영역에서 다음과 같이 메모 페이지를 클릭합니다. 3. 노트 페이지에 들어가서 오른쪽 상단에 있는 [점 3개]를 클릭합니다. 4. 마지막으로 기능 표시줄이 하단에 확장되고 [삭제]를 클릭하여 완료합니다.

WeChat에서 차단 및 삭제되어 영구적으로 추가될 수 없다는 것이 사실인가요? WeChat에서 차단 및 삭제되어 영구적으로 추가될 수 없다는 것이 사실인가요? Apr 08, 2024 am 11:41 AM

1. 우선, 누군가를 영구 차단 및 삭제하고 영구 추가하지 않는 것은 허위입니다. 상대방을 차단하고 삭제한 후 추가하려면 상대방의 동의만 있으면 됩니다. 2. 사용자가 누군가를 차단하면 상대방은 해당 사용자에게 메시지를 보낼 수 없고, 사용자의 친구 서클을 볼 수 없으며, 사용자와 통화할 수 없습니다. 3. 차단은 사용자의 WeChat 연락처 목록에서 상대방을 삭제하는 것을 의미하지 않습니다. 4. 상대방을 차단한 후 자신의 위챗 연락처 목록에서 상대방을 삭제한 경우, 삭제 후 복구할 수 있는 방법이 없습니다. 5. 상대방을 다시 친구로 추가하려면 상대방이 동의한 후 다시 친구를 추가해야 합니다.

어떤 폴더가 발견되었나요.000? found.000 폴더를 삭제할 수 있나요? 어떤 폴더가 발견되었나요.000? found.000 폴더를 삭제할 수 있나요? Mar 13, 2024 pm 08:52 PM

컴퓨터를 매일 사용하는 과정에서found.000 파일이 누락되어 손상되었다는 오류 메시지가 나타날 수 있습니다. 이found.000은 어떤 폴더입니까? 더 이상 쓸모가 없으면 삭제할 수 있나요? 이 파일을 모르는 분들이 너무 많아서found.000 폴더에 대해 자세히 알려드릴게요~ 1.found.000 폴더는 무엇인가요? 불법 종료로 인해 컴퓨터가 일부 또는 완전히 분실된 경우, 찾을 수 있습니다. "found.000"이라는 특수 폴더와 그 안에 포함된 ".chk" 확장자를 가진 파일은 시스템 파티션에 있는 지정된 디렉터리에 있습니다. 이 "fo

Xiaohongshu 릴리스를 삭제하는 방법은 무엇입니까? 삭제 후 복구하는 방법은 무엇입니까? Xiaohongshu 릴리스를 삭제하는 방법은 무엇입니까? 삭제 후 복구하는 방법은 무엇입니까? Mar 21, 2024 pm 05:10 PM

인기 있는 소셜 전자상거래 플랫폼인 Xiaohongshu는 일상생활과 쇼핑 경험을 공유하기 위해 많은 사용자를 끌어 모았습니다. 때때로 당사는 개인 이미지를 더 잘 유지하거나 플랫폼 규정을 준수하기 위해 적시에 삭제해야 하는 일부 부적절한 콘텐츠를 실수로 게시할 수 있습니다. 1. Xiaohongshu 릴리스를 삭제하는 방법은 무엇입니까? 1. Xiaohongshu 계정에 로그인하고 개인 홈페이지에 들어갑니다. 2. 개인 홈페이지 하단의 '내 창작물' 옵션을 찾아 클릭하여 입장합니다. 3. "내 창작물" 페이지에서는 노트, 동영상 등 게시된 모든 콘텐츠를 볼 수 있습니다. 4. 삭제가 필요한 콘텐츠를 찾아 오른쪽에 있는 "..." 버튼을 클릭하세요. 5. 팝업 메뉴에서 "삭제" 옵션을 선택하세요. 6. 삭제 확인 후 해당 콘텐츠는 개인 홈페이지 및 공개 페이지에서 사라집니다.

Xiaohongshu에서 다른 사람이 삭제한 댓글을 어떻게 검색할 수 있나요? 다른 사람의 댓글이 삭제되면 표시되나요? Xiaohongshu에서 다른 사람이 삭제한 댓글을 어떻게 검색할 수 있나요? 다른 사람의 댓글이 삭제되면 표시되나요? Mar 21, 2024 pm 10:46 PM

Xiaohongshu는 인기 있는 소셜 전자상거래 플랫폼으로, 사용자 간의 쌍방향 댓글은 플랫폼에서 없어서는 안될 커뮤니케이션 방법입니다. 때때로 우리의 댓글이 다른 사람에 의해 삭제되어 혼란스러울 수 있습니다. 1. Xiaohongshu에서 다른 사람이 삭제한 댓글을 어떻게 검색할 수 있나요? 댓글이 삭제된 것을 발견하면 먼저 플랫폼에서 관련 게시물이나 제품을 직접 검색하여 해당 댓글을 찾을 수 있는지 확인할 수 있습니다. 삭제 후에도 댓글이 계속 표시된다면 원래 게시물 소유자가 삭제했을 수 있습니다. 이때 원래 게시물 소유자에게 연락하여 댓글 삭제 이유를 문의하고 댓글 복원을 요청할 수 있습니다. 댓글이 완전히 삭제되어 원래 게시물에서 찾을 수 없는 경우, 해당 댓글이 플랫폼에 복원될 가능성은 상대적으로 희박합니다. 다른 방법을 시도해 볼 수 있습니다.

TikTok 채팅 기록을 완전히 삭제하는 방법 TikTok 채팅 기록을 완전히 삭제하는 방법 May 07, 2024 am 11:14 AM

1. Douyin 앱을 열고 인터페이스 하단의 [메시지]를 클릭한 후 삭제해야 하는 채팅 대화 항목을 클릭합니다. 2. 채팅 기록 중 하나를 길게 누른 후 [복수 선택]을 클릭하고 삭제하려는 채팅 기록을 선택하세요. 3. 해당 기록을 영구 삭제하려면 오른쪽 하단의 [삭제] 버튼을 클릭한 후 팝업창에서 [삭제 확인]을 선택하세요.

hiberfil.sys 파일이란 무엇입니까? hiberfil.sys를 삭제할 수 있나요? hiberfil.sys 파일이란 무엇입니까? hiberfil.sys를 삭제할 수 있나요? Mar 15, 2024 am 09:49 AM

최근 많은 네티즌들이 편집자에게 hiberfil.sys 파일이 무엇인지 문의했습니다. hiberfil.sys가 C 드라이브 공간을 많이 차지하고 삭제될 수 있나요? 편집자는 hiberfil.sys 파일을 삭제할 수 있음을 알려줄 수 있습니다. 아래에서 자세한 내용을 살펴보겠습니다. hiberfil.sys는 Windows 시스템의 숨겨진 파일이자 시스템 최대 절전 모드 파일입니다. 일반적으로 C 드라이브의 루트 디렉터리에 저장되며 크기는 시스템에 설치된 메모리 크기와 동일합니다. 이 파일은 컴퓨터가 최대 절전 모드일 때 사용되며, 복구 시 빠르게 이전 상태로 복원할 수 있도록 현재 시스템의 메모리 데이터를 담고 있습니다. 크기가 메모리 용량과 동일하므로 하드 드라이브 공간을 더 많이 차지할 수 있습니다. 동면

See all articles