Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 174775
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T13:34:58+00:00 2026-05-11T13:34:58+00:00

The problem: Let’s say there is an XML file that contains both the data

  • 0

The problem: Let’s say there is an XML file that contains both the data and the hierarchy of certain elements of interest to the application:

  <root>     <node title='lvl1Node'>         <node title='lvl2Node'>             <node title='lvl3Node'></node>         </node>     </node>     <node title='lvl1Node2'></node>     <node title='lvl1Node3'>         <node title='lvl2Node2'>             <node title='lvl3Node2'>                 <node title='lvl4Node'></node>             </node>         </node>     </node>   </root> 

Now let’s say your application needs to provide an API to retrieve these nodes. You need to write a method that returns the nodes without losing information about their hierarchy.

My question is how would you go about it ? What kind of data type would you use. A tree data type is the obvious answer but it not provided in the standard Collections API and writing it yourself is always a last resort (programmers are lazy, reinventing the wheel etc).

I also thought of an ArrayList where each item is either an Object (for node without subnodes) or an Arraylist (for node with subnodes) but I like generics and this feels too much like a hack. Is there a cleverer way to do it ?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T13:34:59+00:00Added an answer on May 11, 2026 at 1:34 pm

    The first question you should be asking yourself is how do you need to access the data? Depth-first iterations? Search for specific values?

    At first glance, this is a tree of nodes where each node can have zero or more children.

    So it goes something like this:

    class Node {   Node parent;   List<Node> children; } 

    It’s like a linked list, but each node can branch out into an arbitrary number of children. If you need to find items directly by id the best bet is to keep a seperate hashmap index.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Let's say I have an XML file that looks like this: <a id=x> <b>
My problem is simple. I search a specific pattern in a file (let's say
is there an easy way to solve the following problem. Let's say I fetch
I have a small problem with XPath contains with dom4j ... Let's say my
Consider this problem: I have a program which should fetch (let's say) 100 records
Here's a coding problem for those that like this kind of thing. Let's see
I've had this problem a couple of times. Let's say I want to display
I've got a philosophical programming problem. Let's say I have a class named Employees.
The problem: let's say I have two tables Client , and Product , in
My problem Let's say I want to hold my messages in some sort of

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.