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

  • SEARCH
  • Home
  • 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 6637967
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 25, 20262026-05-25T23:22:43+00:00 2026-05-25T23:22:43+00:00

I expet that this code should output: 8 8 but it does not. class

  • 0

I expet that this code should output:

8
8

but it does not.

class tree:
    def __init__(self, size=2):
        if size == 0:
            return None
        if size > 1:
            half = size//2
            self.left = tree(size-half)
            self.right = tree(half)
        else:
            self.left = self.right = None
        self.free = size
        self.size = size

    def resize(self,n):
        while self.size < n:
            t = tree(0)
            t.left = self
            t.right = tree(self.size)
            t.free = t.left.size + t.right.size
            t.size = self.size * 2
            self = t
        print("size in resize", self.size)

t = tree()
t.resize(5)
print("size of t", t.size)

output:

size in resize 8
size of t 2

I know I could do return self in resize and t = tree.resize(5) in main, but what if I want to return something else?

  • 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. Editorial Team
    Editorial Team
    2026-05-25T23:22:43+00:00Added an answer on May 25, 2026 at 11:22 pm

    Karl’s answer is entirely right about everything, but there is certainly a way to make resize act as you’re expecting.

    Three steps:

    1. Make a copy of the tree
    2. Re-initialize the tree so it’s the next size larger
    3. Set the enlarged tree’s left to the copy of the original tree

      def resize(self,n):
              while self.size < n:
                  new = self.copy()
                  self.__init__(int(round(self.size, 2)) * 2)
                  self.left = new
      
              print("size in resize",self.size)
      
      def copy(self):
              new = tree(1)
              new.left = self.left
              new.right = self.right
              new.size = self.size
              new.free = self.free
              return new
      

    Basically, you were trying to do it backwards — replace self and reuse self for self.left, instead of replacing self.left and reusing self.

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

Sidebar

Related Questions

In the following example should I expect that values.size() will be called every time
Sorry if this isn't Stack Overflow worthy but I'm stumped. Here is my code:
I have this code that creates the navigation for a slideshow. It works just
Given this code: class Overloading extends Object { static public void target(Object val, String
I would appreciate an extra set of eyes on this code. It's supposed to
In C#, if you do this, it will compile: namespace Name { public class
I am trying to cache everything that is output by layout script and controller's
How do you test if compiled code returns the expected output or fails as
I am having trouble using system() from libc on Linux. My code is this:
This is a very standard newbie question, but I am looking for an expert

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.