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

Ask A Question

Stats

  • Questions 205k
  • Answers 205k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer pubDate: The original publication date for the channel or item.… May 12, 2026 at 9:00 pm
  • Editorial Team
    Editorial Team added an answer First, whatever you do don't return a result and an… May 12, 2026 at 9:00 pm
  • Editorial Team
    Editorial Team added an answer I wouldn't rely on Mathematica's float-parsing. Instead I'd define rules… May 12, 2026 at 9:00 pm

Related Questions

I have a French site that I want to parse, but am running into
The problem: Let's say there is an XML file that contains both the data
I've never been completely happy with the way exception handling works, there's a lot
I'm looking into making some software that makes the keyboard function like a piano
I'm looking into making some software that makes the keyboard function like a piano

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

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.