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

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

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

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

문제 처리

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

문자열 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 tutorialspoint에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
C : 죽어 가거나 단순히 진화하고 있습니까?C : 죽어 가거나 단순히 진화하고 있습니까?Apr 24, 2025 am 12:13 AM

c is nontdying; it'sevolving.1) c COMINGDUETOITSTIONTIVENICICICICINICE INPERFORMICALEPPLICATION.2) thelugageIscontinuousUllyUpdated, witcentfeatureslikemodulesandCoroutinestoimproveusActionalance.3) despitechallen

C 현대 세계에서 : 응용 및 산업C 현대 세계에서 : 응용 및 산업Apr 23, 2025 am 12:10 AM

C는 현대 세계에서 널리 사용되고 중요합니다. 1) 게임 개발에서 C는 Unrealengine 및 Unity와 같은 고성능 및 다형성에 널리 사용됩니다. 2) 금융 거래 시스템에서 C의 낮은 대기 시간과 높은 처리량은 고주파 거래 및 실시간 데이터 분석에 적합한 첫 번째 선택입니다.

C XML 라이브러리 : 옵션 비교 및 ​​대조C XML 라이브러리 : 옵션 비교 및 ​​대조Apr 22, 2025 am 12:05 AM

C : Tinyxml-2, Pugixml, XERCES-C 및 RapidXML에는 4 개의 일반적으로 사용되는 XML 라이브러리가 있습니다. 1. TINYXML-2는 자원이 제한적이고 경량이지만 제한된 기능을 가진 환경에 적합합니다. 2. PugixML은 빠르며 복잡한 XML 구조에 적합한 XPath 쿼리를 지원합니다. 3.xerces-c는 강력하고 DOM 및 SAX 해상도를 지원하며 복잡한 처리에 적합합니다. 4. RapidXML은 성능에 중점을두고 매우 빠르게 구문 분석하지만 XPath 쿼리를 지원하지는 않습니다.

C 및 XML : 관계와 지원 탐색C 및 XML : 관계와 지원 탐색Apr 21, 2025 am 12:02 AM

C는 XML과 타사 라이브러리 (예 : TinyXML, Pugixml, Xerces-C)와 상호 작용합니다. 1) 라이브러리를 사용하여 XML 파일을 구문 분석하고 C- 처리 가능한 데이터 구조로 변환하십시오. 2) XML을 생성 할 때 C 데이터 구조를 XML 형식으로 변환하십시오. 3) 실제 애플리케이션에서 XML은 종종 구성 파일 및 데이터 교환에 사용되어 개발 효율성을 향상시킵니다.

C# vs. C : 주요 차이점과 유사성 이해C# vs. C : 주요 차이점과 유사성 이해Apr 20, 2025 am 12:03 AM

C#과 C의 주요 차이점은 구문, 성능 및 응용 프로그램 시나리오입니다. 1) C# 구문은 더 간결하고 쓰레기 수집을 지원하며 .NET 프레임 워크 개발에 적합합니다. 2) C는 성능이 높고 시스템 프로그래밍 및 게임 개발에 종종 사용되는 수동 메모리 관리가 필요합니다.

C# vs. C : 역사, 진화 및 미래 전망C# vs. C : 역사, 진화 및 미래 전망Apr 19, 2025 am 12:07 AM

C#과 C의 역사와 진화는 독특하며 미래의 전망도 다릅니다. 1.C는 1983 년 Bjarnestroustrup에 의해 발명되어 객체 지향 프로그래밍을 C 언어에 소개했습니다. Evolution 프로세스에는 자동 키워드 소개 및 Lambda Expressions 소개 C 11, C 20 도입 개념 및 코 루틴과 같은 여러 표준화가 포함되며 향후 성능 및 시스템 수준 프로그래밍에 중점을 둘 것입니다. 2.C#은 2000 년 Microsoft에 의해 출시되었으며 C와 Java의 장점을 결합하여 진화는 단순성과 생산성에 중점을 둡니다. 예를 들어, C#2.0은 제네릭과 C#5.0 도입 된 비동기 프로그래밍을 소개했으며, 이는 향후 개발자의 생산성 및 클라우드 컴퓨팅에 중점을 둘 것입니다.

C# vs. C : 학습 곡선 및 개발자 경험C# vs. C : 학습 곡선 및 개발자 경험Apr 18, 2025 am 12:13 AM

C# 및 C 및 개발자 경험의 학습 곡선에는 상당한 차이가 있습니다. 1) C#의 학습 곡선은 비교적 평평하며 빠른 개발 및 기업 수준의 응용 프로그램에 적합합니다. 2) C의 학습 곡선은 가파르고 고성능 및 저수준 제어 시나리오에 적합합니다.

C# vs. C : 객체 지향 프로그래밍 및 기능C# vs. C : 객체 지향 프로그래밍 및 기능Apr 17, 2025 am 12:02 AM

C# 및 C가 객체 지향 프로그래밍 (OOP)의 구현 및 기능에 상당한 차이가 있습니다. 1) C#의 클래스 정의 및 구문은 더 간결하고 LINQ와 같은 고급 기능을 지원합니다. 2) C는 시스템 프로그래밍 및 고성능 요구에 적합한 더 미세한 입상 제어를 제공합니다. 둘 다 고유 한 장점이 있으며 선택은 특정 응용 프로그램 시나리오를 기반으로해야합니다.

See all articles

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

SublimeText3 영어 버전

SublimeText3 영어 버전

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

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

mPDF

mPDF

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