Given a query string s and a set of all possible query strings, return all strings in the set that have s as a prefix

Do I have to take mana from my deck or hand when tapping this card?

"Oh no!" in Latin

Highest stage count that are used one right after the other?

How do you justify more code being written by following clean code practices?

Did I make a mistake by ccing email to boss to others?

Error in master's thesis, I do not know what to do

Do native speakers use "ultima" and "proxima" frequently in spoken English?

Air travel with refrigerated insulin

Non-Borel set in arbitrary metric space

Should I be concerned about student access to a test bank?

What is the tangent at a sharp point on a curve?

Would a primitive species be able to learn English from reading books alone?

New Order #2: Turn My Way

Can you describe someone as luxurious? As in someone who likes luxurious things?

Sort with assumptions

Walter Rudin's mathematical analysis: theorem 2.43. Why proof can't work under the perfect set is uncountable.

categorizing a variable turns it from insignificant to significant

What is this high flying aircraft over Pennsylvania?

How to preserve electronics (computers, ipads, phones) for hundreds of years?

Why do Radio Buttons not fill the entire outer circle?

What do the positive and negative (+/-) transmit and receive pins mean on Ethernet cables?

Are hand made posters acceptable in Academia?

How do I prevent inappropriate ads from appearing in my game?

Is there a distance limit for minecart tracks?



Given a query string s and a set of all possible query strings, return all strings in the set that have s as a prefix














0












$begingroup$



Implement an autocomplete system. That is, given a query string s and
a set of all possible query strings, return all strings in the set
that have s as a prefix.



For example, given the query string de and the set of strings [dog,
deer, deal], return [deer, deal].




 class DailyCodingProble11 

public static void main(String args[])

String[] words = "dog", "deer", "deal" ;
Trie trie = new Trie();
for (String word : words)
trie.insert(word);

trie.search("de", trie.root, 0).stream().forEach(word -> System.out.println(word));
trie.search("do", trie.root, 0).stream().forEach(word -> System.out.println(word));



class TrieNode
public Character content;
public TrieNode[] children = new TrieNode[26];
public boolean isWord;

TrieNode(Character ch)
this.content = ch;



class Trie
TrieNode root;

Trie()
root = new TrieNode('*');


public void insert(String word)
TrieNode currentNode = root;
for (int i = 0; i < word.length(); i++)
Character ch = word.charAt(i);
if (currentNode.children[ch - 'a'] == null)
currentNode.children[ch - 'a'] = new TrieNode(ch);

currentNode = currentNode.children[ch - 'a'];


currentNode.isWord = true;


public List<String> search(String searchTxt, TrieNode currentNode, int index)
List<String> results = new ArrayList<>();
Character ch = searchTxt.charAt(index);
if (currentNode.children[ch - 'a'] == null)
return results;

currentNode = currentNode.children[ch - 'a'];
if (index == searchTxt.length() - 1)
findWords(currentNode, new StringBuilder(searchTxt), results);
return results;

return search(searchTxt, currentNode, ++index);


public void findWords(TrieNode currentNode, StringBuilder sb, List<String> results)

for (TrieNode child : currentNode.children)
if (child != null)
if (child.isWord == true)
results.add(sb.append(child.content).toString());

findWords(child, new StringBuilder(sb).append(child.content), results);








How can I improve my solution? Are there any code improvements?









share









$endgroup$
















    0












    $begingroup$



    Implement an autocomplete system. That is, given a query string s and
    a set of all possible query strings, return all strings in the set
    that have s as a prefix.



    For example, given the query string de and the set of strings [dog,
    deer, deal], return [deer, deal].




     class DailyCodingProble11 

    public static void main(String args[])

    String[] words = "dog", "deer", "deal" ;
    Trie trie = new Trie();
    for (String word : words)
    trie.insert(word);

    trie.search("de", trie.root, 0).stream().forEach(word -> System.out.println(word));
    trie.search("do", trie.root, 0).stream().forEach(word -> System.out.println(word));



    class TrieNode
    public Character content;
    public TrieNode[] children = new TrieNode[26];
    public boolean isWord;

    TrieNode(Character ch)
    this.content = ch;



    class Trie
    TrieNode root;

    Trie()
    root = new TrieNode('*');


    public void insert(String word)
    TrieNode currentNode = root;
    for (int i = 0; i < word.length(); i++)
    Character ch = word.charAt(i);
    if (currentNode.children[ch - 'a'] == null)
    currentNode.children[ch - 'a'] = new TrieNode(ch);

    currentNode = currentNode.children[ch - 'a'];


    currentNode.isWord = true;


    public List<String> search(String searchTxt, TrieNode currentNode, int index)
    List<String> results = new ArrayList<>();
    Character ch = searchTxt.charAt(index);
    if (currentNode.children[ch - 'a'] == null)
    return results;

    currentNode = currentNode.children[ch - 'a'];
    if (index == searchTxt.length() - 1)
    findWords(currentNode, new StringBuilder(searchTxt), results);
    return results;

    return search(searchTxt, currentNode, ++index);


    public void findWords(TrieNode currentNode, StringBuilder sb, List<String> results)

    for (TrieNode child : currentNode.children)
    if (child != null)
    if (child.isWord == true)
    results.add(sb.append(child.content).toString());

    findWords(child, new StringBuilder(sb).append(child.content), results);








    How can I improve my solution? Are there any code improvements?









    share









    $endgroup$














      0












      0








      0





      $begingroup$



      Implement an autocomplete system. That is, given a query string s and
      a set of all possible query strings, return all strings in the set
      that have s as a prefix.



      For example, given the query string de and the set of strings [dog,
      deer, deal], return [deer, deal].




       class DailyCodingProble11 

      public static void main(String args[])

      String[] words = "dog", "deer", "deal" ;
      Trie trie = new Trie();
      for (String word : words)
      trie.insert(word);

      trie.search("de", trie.root, 0).stream().forEach(word -> System.out.println(word));
      trie.search("do", trie.root, 0).stream().forEach(word -> System.out.println(word));



      class TrieNode
      public Character content;
      public TrieNode[] children = new TrieNode[26];
      public boolean isWord;

      TrieNode(Character ch)
      this.content = ch;



      class Trie
      TrieNode root;

      Trie()
      root = new TrieNode('*');


      public void insert(String word)
      TrieNode currentNode = root;
      for (int i = 0; i < word.length(); i++)
      Character ch = word.charAt(i);
      if (currentNode.children[ch - 'a'] == null)
      currentNode.children[ch - 'a'] = new TrieNode(ch);

      currentNode = currentNode.children[ch - 'a'];


      currentNode.isWord = true;


      public List<String> search(String searchTxt, TrieNode currentNode, int index)
      List<String> results = new ArrayList<>();
      Character ch = searchTxt.charAt(index);
      if (currentNode.children[ch - 'a'] == null)
      return results;

      currentNode = currentNode.children[ch - 'a'];
      if (index == searchTxt.length() - 1)
      findWords(currentNode, new StringBuilder(searchTxt), results);
      return results;

      return search(searchTxt, currentNode, ++index);


      public void findWords(TrieNode currentNode, StringBuilder sb, List<String> results)

      for (TrieNode child : currentNode.children)
      if (child != null)
      if (child.isWord == true)
      results.add(sb.append(child.content).toString());

      findWords(child, new StringBuilder(sb).append(child.content), results);








      How can I improve my solution? Are there any code improvements?









      share









      $endgroup$





      Implement an autocomplete system. That is, given a query string s and
      a set of all possible query strings, return all strings in the set
      that have s as a prefix.



      For example, given the query string de and the set of strings [dog,
      deer, deal], return [deer, deal].




       class DailyCodingProble11 

      public static void main(String args[])

      String[] words = "dog", "deer", "deal" ;
      Trie trie = new Trie();
      for (String word : words)
      trie.insert(word);

      trie.search("de", trie.root, 0).stream().forEach(word -> System.out.println(word));
      trie.search("do", trie.root, 0).stream().forEach(word -> System.out.println(word));



      class TrieNode
      public Character content;
      public TrieNode[] children = new TrieNode[26];
      public boolean isWord;

      TrieNode(Character ch)
      this.content = ch;



      class Trie
      TrieNode root;

      Trie()
      root = new TrieNode('*');


      public void insert(String word)
      TrieNode currentNode = root;
      for (int i = 0; i < word.length(); i++)
      Character ch = word.charAt(i);
      if (currentNode.children[ch - 'a'] == null)
      currentNode.children[ch - 'a'] = new TrieNode(ch);

      currentNode = currentNode.children[ch - 'a'];


      currentNode.isWord = true;


      public List<String> search(String searchTxt, TrieNode currentNode, int index)
      List<String> results = new ArrayList<>();
      Character ch = searchTxt.charAt(index);
      if (currentNode.children[ch - 'a'] == null)
      return results;

      currentNode = currentNode.children[ch - 'a'];
      if (index == searchTxt.length() - 1)
      findWords(currentNode, new StringBuilder(searchTxt), results);
      return results;

      return search(searchTxt, currentNode, ++index);


      public void findWords(TrieNode currentNode, StringBuilder sb, List<String> results)

      for (TrieNode child : currentNode.children)
      if (child != null)
      if (child.isWord == true)
      results.add(sb.append(child.content).toString());

      findWords(child, new StringBuilder(sb).append(child.content), results);








      How can I improve my solution? Are there any code improvements?







      java programming-challenge





      share












      share










      share



      share










      asked 1 min ago









      Maclean PintoMaclean Pinto

      2667




      2667




















          0






          active

          oldest

          votes











          Your Answer





          StackExchange.ifUsing("editor", function ()
          return StackExchange.using("mathjaxEditing", function ()
          StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
          StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
          );
          );
          , "mathjax-editing");

          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "196"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f215813%2fgiven-a-query-string-s-and-a-set-of-all-possible-query-strings-return-all-strin%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Code Review Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          Use MathJax to format equations. MathJax reference.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f215813%2fgiven-a-query-string-s-and-a-set-of-all-possible-query-strings-return-all-strin%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          कुँवर स्रोत दिक्चालन सूची"कुँवर""राणा कुँवरके वंशावली"

          शेव्रोले वोल्ट अनुक्रम इतिहास इन्हे भी देखें चित्र दीर्घा संदर्भ दिक्चालन सूची

          चैत्य भूमि चित्र दीर्घा सन्दर्भ बाहरी कडियाँ दिक्चालन सूची"Chaitya Bhoomi""Chaitya Bhoomi: Statue of Equality in India""Dadar Chaitya Bhoomi: Statue of Equality in India""Ambedkar memorial: Centre okays transfer of Indu Mill land"चैत्यभमि