사용자가 입력 한 4 자의 문자열을 스크램블하는 프로그램을 작성해야합니다. (예제 TEST는 tset, ttse 등과 같이 뒤죽박죽이 될 수 있습니다.) 잘 작동하는 프로그램이 있지만 4 요소 char 배열로 제한되어 있습니다. 그리고 그것을 만들 수있는 방법이 있는지 알고 싶습니다. 미리 결정된 크기를 가져야합니다.셔플 링 문자열
//4 letter word scrambler (ex. test tets tset...)
int counter=0;
int main(int argc, char* argv[])
{
char str[4];
cout << "Please enter a word: "; //ask for input
cin >> str;
counter+=1; // set counter to 1
cout << counter << " " << str << endl;
for (int i=0;i<3;i++){// iteration through one full loop in array
swap(str[i], str[i+1]); //swap two elements as iterates through array
counter+=1;//add 1 to counter each time
cout <<counter<<" "<< str << endl;
}
for (int i=0;i<3;i++){
swap(str[i], str[i+1]);
counter+=1;
cout << counter<< " " << str << endl;
}
for (int i=0;i<3;i++){
swap(str[i], str[i+1]);
counter+=1;
cout << counter << " " << str << endl;
}
for (int i=0;i<2;i++){
swap(str[i], str[i+1]);
counter+=1;
cout << counter << " " << str << endl;
}
system("PAUSE");
return 0;
}
그냥 할 간단한 [피셔 - 예이츠 (HTTP ://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle) shuffle. 나는 C++을 사용하지 않으므로, 이미 이런 일을 할 수있는 무언가가있을 것입니다. 그러나 위키 기사는 꽤 좋으며 단순한 알고리즘입니다. shuffle이 * 전체 * 배열을 통해 어떻게 실행되는지 주목하십시오 (이것은 어떤 크기의 콜렉션으로도 확장 가능합니다). 이 구현을 사용하여 "현재 위치에서 출력"할 수 있습니다 (셔플 된 배열 결과를 저장할 필요가 없습니다). –
당신은 모든 순열을 찾거나 그것이 무작위 적이기를 원합니 까? – Dani
초기 솔루션은 어떤 일이든 정확하게 12 가지 솔루션을 제공하므로 많은 경우에 잘못되었다고 생각합니다. 다르게 배치 된 동등한 문자를 구별하고 싶습니까? 그래서, 당신은 반복의 유무에 관계없이 순열을 원합니까? _ (** TTTT **에 대한 결과는 ** 4 ** ** ** 1 **입니까?) _ – ch0kee