This function:
function indexWord(index, word, letters) {
var letter;
if (!letters) letters = word.split("");
while (letters.length) {
letter = letters.shift().toLowerCase();
if (!(letter in index)) index[letter] = {_items: []};
index[letter]._items.push(word);
indexWord(index[letter], word, letters);
}
}
called like this:
var store = ["Alaska", "Alabama", "North Korea", "South Korea"],
index = {}, i;
for (i = 0; i < store.length; i++) {
indexWord(index, store[i]);
}
gives you the following index:
{
a: {
_items: ["Alaska", "Alabama"],
l: {
_items: ["Alaska", "Alabama"],
a: {
_items: ["Alaska", "Alabama"],
s: {
_items: ["Alaska"],
k: {
_items: ["Alaska"],
a: {
_items: ["Alaska"]
}
}
},
b: {
_items: ["Alabama"],
a: {
_items: ["Alabama"],
m: {
_items: ["Alabama"],
a: {
_items: ["Alabama"]
}
}
}
}
}
}
},
n: {
_items: ["North Korea"],
o: {
_items: ["North Korea"],
r: {
_items: ["North Korea"],
t: {
_items: ["North Korea"],
h: {
_items: ["North Korea"],
" ": {
_items: ["North Korea"],
k: {
_items: ["North Korea"],
o: {
_items: ["North Korea"],
r: {
_items: ["North Korea"],
e: {
_items: ["North Korea"],
a: {
_items: ["North Korea"]
}
}
}
}
}
}
}
}
}
}
},
s: {
_items: ["South Korea"],
o: {
_items: ["South Korea"],
u: {
_items: ["South Korea"],
t: {
_items: ["South Korea"],
h: {
_items: ["South Korea"],
" ": {
_items: ["South Korea"],
k: {
_items: ["South Korea"],
o: {
_items: ["South Korea"],
r: {
_items: ["South Korea"],
e: {
_items: ["South Korea"],
a: {
_items: ["South Korea"]
}
}
}
}
}
}
}
}
}
}
}
}
where either index["a"]["l"]._items or index.a.l._items can be used to access ["Alaska", "Alabama"].