forked from aishraj/JavaScript-Interview-Questions
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path007.js
More file actions
209 lines (191 loc) · 2.27 KB
/
007.js
File metadata and controls
209 lines (191 loc) · 2.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
/*
* <!--
* This program is distributed under
* the terms of the MIT license.
* Please see the LICENSE file for details.
* -->
*/
/*
* Implement a routine that prints all the permutations of a given string.
* Do *not* use recursion.
*/
/*____________________________________________________________________________*/
/**
* @function {public static} swap
*
* Swaps the two characters of a given string.
*
* @param {String} str - the `String` to swap.
* @param {Integer} i - the first character index.
* @param {Integer} j - the second character index.
*
* @return the swapped `String`.
*/
function swap(str, i, j) {
var ar = str.split('');
var temp = ar[i];
ar[i] = ar[j];
ar[j] = temp;
return ar.join('');
}
/**
* A helper.
*/
function print(str) {
console.log(str);
}
/**
* @function {public static} permute
*
* Iteratively permutes the `String` using
* the "CountDown QuickPerm Algorithm".
* ref: http://permute.tchs.info/01example.php
*
* @param {String} str - the `String` to permute.
*/
function permute(str) {
var len = str.length;
var p = [];
for(var i=0; i<len+1; i++) {
p[i] = i;
}
var i = 1;
var j = 0;
print(str);
while (i < len) {
p[i] -= 1;
j = (i%2 === 0) ? 0 : p[i];
str = swap(str, j, i);
print(str);
i = 1;
while (p[i] === 0) {
p[i] = i;
i++;
}
}
}
/*____________________________________________________________________________*/
permute('SF_CA');
/*
Output: ($ /usr/bin/node 007.js)
SF_CA
FS_CA
_SFCA
S_FCA
F_SCA
_FSCA
_FCSA
F_CSA
C_FSA
_CFSA
FC_SA
CF_SA
CS_FA
SC_FA
_CSFA
C_SFA
S_CFA
_SCFA
FSC_A
SFC_A
CFS_A
FCS_A
SCF_A
CSF_A
ASF_C
SAF_C
FAS_C
AFS_C
SFA_C
FSA_C
FS_AC
SF_AC
_FSAC
F_SAC
S_FAC
_SFAC
_AFSC
A_FSC
F_ASC
_FASC
AF_SC
FA_SC
SA_FC
AS_FC
_SAFC
S_AFC
A_SFC
_ASFC
CASF_
ACSF_
SCAF_
CSAF_
ASCF_
SACF_
SAFC_
ASFC_
FSAC_
SFAC_
AFSC_
FASC_
FCSA_
CFSA_
SFCA_
FSCA_
CSFA_
SCFA_
ACFS_
CAFS_
FACS_
AFCS_
CFAS_
FCAS_
_CASF
C_ASF
A_CSF
_ACSF
CA_SF
AC_SF
ACS_F
CAS_F
SAC_F
ASC_F
CSA_F
SCA_F
S_ACF
_SACF
AS_CF
SA_CF
_ASCF
A_SCF
C_SAF
_CSAF
SC_AF
CS_AF
_SCAF
S_CAF
F_CAS
_FCAS
CF_AS
FC_AS
_CFAS
C_FAS
C_AFS
_CAFS
AC_FS
CA_FS
_ACFS
A_CFS
AFC_S
FAC_S
CAF_S
ACF_S
FCA_S
CFA_S
_FACS
F_ACS
A_FCS
_AFCS
FA_CS
AF_CS
*/