UVA 156 Ananagrams STL 애플리케이션
몇 개의 단어를 정해서 사전순으로 출력하면 다시 배열된 단어가 존재하지 않습니다.(테스트 결과 중복된 단어는 포함되지 않음)
단어 재배열: 자모마다 나타나는 횟수는 같지만 순서가 다르다. 즉 단어의 순서에 대한 정렬이다
사고방식 분석
리셋이 등가로 전환될 수 있는지의 여부: 단어의 구성 자모는 순서와 상관없이 두 가지 해결 방향이 있다(표준화)
map
map dict; // ->
따라서 표준화된 단어(전체 소문자로 전환) 후에 서로 다른 사고방식에 따라 횟수를 통계하고 해당하는 옛 단어를 기록할 수 있다
set ans;
저장 출력 결과, 자동 사전 순서대로 배열AC 코드(C++11, 맵 표준화, 순서 무관)
일괄 정렬
#include
using namespace std;
map dict; // ->
map trans; // ->
set ans; // ,
string s, st;
int main() {
while (cin >>s && s!= "#") {
st = s;
for (auto& ch : st) //
if (ch >= 'A' && ch <= 'Z') ch = tolower(ch); //
sort(st.begin(), st.end()); // ,
dict[st]++; //
trans[st] = s; //
}
for (auto p : dict) if (p.second == 1) ans.insert(trans[p.first]); // 1
for (auto& p : ans) cout <
문자 개수
#include
using namespace std;
map
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.