Index


Destroying a linked list using a recursive procedural call

Note that the correct way to dispose of linear structure like a linked list is to use an interative procedure, not recursion (which would be the correct way to dispose of a tree, not a linear list.

The previous section demonstrated using a linked list to implement a LIFO stack, and in this section a generic method for destoying a linked list using the dispose procedure will be demonstrated, using a recursive procedural call.

You can download the source as a text file by clicking here -> linked_list_dispose_recursive.txt

You can imagine how a LIFO stack might be used to implement an undo function in a program (last in first off).  A program might also have a function to 'Discard all changes' (in otherwords we would clear the undo list) and in this case we would want to destroy a LIFO stack.

we will create a procedure and call it DestroyLIFOStack and pass it the head pointer pointing to the first item on the bottom of the stack.  When the procedure returns we will remember to set head equal to nil.

DestroyLIFOStack(head);

head:=nil;

The destruction of a linked list of any kind lends itself well to the use of a recursive procedural call.  A recursive call is a call by a function of procedure to itself, rather than to another function or procedure.  If a function called 'ADDit' calls itself (ADDit) it is making a recursive call, and you can think of these calls as piling up on a stack.

The last item in a linked list should be pointing to nil.  The second last item on a linked list would then be pointing to the last item which is pointing to nothing.  If we go down into a linked list until we reach the second last item we have a pointer then pointing to a record which is itself pointing to nothing.  When we call dispose we do not dispose of a pointer, but rather we dispose of whatever the pointer was pointing towards, in this example a record with an integer and a pointer to the next record.  This two field record will be destroyed when we call dispose.

Now if we find the second last record in a linked list we can then call dispose and destroy the last record which, like the '12' record above, is pointing to nil.  We could then move backwards to the third last record, and destroy the second last record, and keep moving backwards until we reach the first record, pointed to by head, destroy that record, set head to nil and we are done disposing of the linked list.

When you make a call to a function or procedure when the call returns computer code always continues on the next line of code.  For example in the following example if we call the procedure ADDit when the call returns execution begins again on the next line (i:=i+1).

Addit;

i:=i+1;

The following procedure for destroying a linked list makes use of this principle by making recursive calls to itself until it finds the pointer pointing to the last record which is a record pointing to nothing.  At this point the if statement does not execute (a record with a null pointer was found) and the code skips down to the dispose statement, and disposes of this last record, and then executes the procedure.  However this was a recursive procedure so all of the stacked up calls then begin to return one by one.  IN effect we have crawled downt he list stacking up procedural calls to the procedure itself.  Now each one of these stacked up calls must return, and we begin to fall back down the list again.  Each time the procedural call returns it falls down to the line with the dispose statement.  So we climbed the list in the first line of code, stacking up recursive calls, and now as they return we will fall back down the list, disposing of each record on the way until we reach the bottom, dispose of the first record, return from the procedure to the initial call at which time we must point head to nil, and the linked list has been destroyed.

The code for destroying the linked list looks like this (in this case we will be destroying our LIFOStack but the principle holds for all linked lists).


procedure TForm1.DestroyLIFOStack(apointer:link);

begin

If apointer^.nextlink<>nil then DestroyLIFOStack(apointer^.nextlink);

dispose(apointer);

end;

The first line of code states that if the nextlink of the record pointed to by apointer is not a null pointer then make a recursive call to the procedure passing  the nextlink pointed to by apointer (which it is established is not a null pointer).  Here we begin to climb up the list looking for the second last record.  Let us suppose we find the second last record (for the record pointed to by the next link on the record being pointed to is null) then we do not make another recursive procedure call but rather drop down to the next line of code, and destroy the last record.  It is then that the recursive (stacked up) procedure calls begin to return one.  The second last record destroyed the last record and exited the function (after being called by the third last record).  Now the third last record returns and drops down to the dispose line and destroys the second last record.  It was in turn called by the fourth last record, which now destroys the third last and so on down the line, until the record pointed to by the head pointer (the first item on the linked list is destroyed.  The procedure finally exits, and we remember to set the head to nil.

We can diagram this using a linked list with four items, as follows.  The key is simply whatever value is being stored in the record (or multiple values, whatever the case might be).  

          (call next)

head ­> | key | next | ­>  (call next)

                                    | key | next | ­>  (dispose next)

                                                          | key | next | ­> | key | next | ­>nil

                          (dispose next)

                          | key | next | ­> | key | next |

        (dispose next)

        | key | next | ­> | key | next |

(dispose)

head ­> | key | next |

return from procedure

set head to nil



Related pages:

Inserting, sorting, and disposing of elements on linked list

Implementing a LIFO stack using a linked list

Using an array to index and quickly search large linked lists - using the divide and conquer strategy that people use when looking up things in phone books. Even very large lists can be quickly searched using this type of strategy.


Index       Home




A Unified Field Theory

failed_gravity_theory.gif - 10361 Bytes



The Unified Field Theory
is also available as a zip file ->
unified.zip

Introduction :The Pioneer Effect and the New Physics. A brief description of the new physics required to explain the 'Pioneer Effect', which is the constant deceleration of space craft as they fly through space.




Principles of Evolution: A Study in the Evolution of Bedbugs



A couple of years ago my bedroom was invaded by bedbugs. There were two variant genetic lines. One type of bedbug was an enlongated, thin, tubular insect, and the second genetic line was a flat, perfectly circular insect. The result of the cross breeding of these two genetically distinct variants was the production of a bedbug with charcteristics of both, an enlongated, flat bedbug with a central bulge (such that the shape of the bedbug was somewhere between 'long' and 'circular'). The long skinny bedbugs were such strange and unfamiliar looking insects that at first I did not recognize them as being bedbugs, and considered them to be a seperate species of insect. However, as the photographs of bedbugs above indicate, enlongated and skinny bedbugs are not uncommon, and the photographs also show the variants that are produced by genetic combinations that result in an insect somewhere in between 'circular' and 'enlongated'.

Therefore it is my hypothesis that evolution occurs by means of the transfer of dominate genes, with the production of such dominant genes being the product of 'biological algorithms', a genetic software program that brings physical characteristics into harmony with behavior, such that when behavior changes, and a conflict then exists, this acts as a trigger and causes the release of dominant genes. The result is rapid evolution of species. The bedbug is a relatively new insect, not the product of millions of years of evolution but rather an insect that is evolving in real time. The newly emerging dominant form of the insect is the flat, round ciruclar insect, well adapted to living in human bedrooms (it is flat, rather than tubular, thus allowing it to hide in the smallest cracks, living a stealthy lifestyle, and it is round, which gives the insect a maximum storage capacity such that it must endanger itself only a few times a month by emerging to feed.

Other examples of rapid evolution include the development of long legs in an invasive species of toad in Australia. As the toads move into the mountainous regions of Australia, and their behvaior changes, making them 'climbing toads', over the course of just a couple of decades the toads in the highlands have grown long legs specially adapted to climbing. It is worth noting here that the toads are poisonous, and are a successful invasive species because they have no natural predators in Australia, and so it would not be the case that the toads with long legs were 'the fittest survivors', because all the toads are survivors, and therefore predation does not explain the rapid emergence and spread of such well adapted, long legged toads. Once again we see evidence for the existence of biological algorithms and the rapid spread of dominant genes through a population, which once introduced proceed to overwhelm the older genes which are being replaced (making toad long legged and a bed bug round and flat).


A Theological Experiment

My interest in pursuing the Unified Field Theory is spurred on by my need to discover the theoretical explanation of a new form of propulsion (as explained on this page: Why the Unified Field Theory?). The experiment involving the bedbugs came out of nowhere.

I also believe that it is possible to justify theological propositions using experimental methods. If a thing is an objective truth then it can be verified and proven true by means of experimentation. Such a theological proposition is of more value than a ‘divine revelation’, since such revelations depend upon nothing more than establishing authority figures which requires the creation of artificial hierarchies, for the only reason why I might be encouraged to believe an authority figure who orders me to believe unsubstantiated opinions is if I could somehow be convinced that this authority possessed a mind that was somehow superior to mine, and thus was fit to express opinions as though opinions were unquestionable facts and thus worthy of being elevated to the status of absolute dogma.

There is a self evident human inequality which is visibly apparent. Some people are ‘beautiful’ and thus are the true elite on this planet, and some people are not. It is this sexual inequality and the degeneration that follows upon beauty that is the true driving force behind all the evil that happens on earth. The need for ruthless oppression and the pursuit of wealth and the consequent creation of suffering and poverty which must follow upon this practice is for the purpose of creating an artificial alpha elite.

The true elites are the young and the beautiful. The artificial elite are the rich and the wealthy. The elite aging rich artificial alpha male has no good looks, for he is physically degenerate, but he will be found escorting beauty because he has a beautiful wallet. If he loses his wallet he will be found at home with all the other unattractive aged beta males sitting in a rocking chair watching reruns of Bonanza. No money, no sex. It is for this reason that the alpha males are found to be so ruthless and so violent in pursuit of their goal. The alpha male has fallen. The beta male has arisen and now the whole planet is full of ruinous destruction for it.

We see in religion a confused and contradictory reaction to this reality. On the one hand religion preaches a sexless heaven where castration and the clitorectomy create ‘pure spirits’. Muslims throw women under sacks. On the other hand religion supports hierarchy and is the prop of the elite alpha male. It is for this reason that religion is incoherent when it comes to speaking about sex.

Now we see this same principle at work in all of nature. Guppies dance and show off their colorful tails and the guppy who dances with the most colorful tail is the sexually successful guppy. Therefore it is the doctrine of the ruthless oppressor which teaches that the solution to human sexual violence is to be found in castration and the creation of pure ghosts. This would be equivalent to damning an aardvark for having the ‘sinful aardvark nature’ or prosecuting an anteater for the high crime of ‘ant genocide’.

Therefore it was my theological hypothesis that the correct solution to this problem is to give every guppy a beautiful colorful tail. I compare this solution to the classic religious solution which is to cut off every tail since having a tail is ‘sinful’. If having a tail is sinful then God must be sinful for no human being has any choice in deciding whether or not they would be born with a colorful tail, or whether they would not.

When I was young I was a beautiful guppy with a lovely tail. So everyone seemed to think. I am older now. My nose became very badly sunburned and destroyed. It seemed good to me to test my hypothesis by using these ‘biological algorithms’ to correct this problem. I healed half my nose as you can see by the line separating the still very dark patch on the side in the photograph below.





I documented my experiment on these pages. one two t hree four fi ve six


I have confirmed to my own satisfaction that my theological proposition is correct and that religious dogma is erroneous, being based as it was upon nothing more than ‘divine revelation’ which is just a form of opinionated speculation. For the time being I am not continuing this experiment, for I must wait until the weather on this planet improves, and the dark clouds of ruthless oppression break letting a little sun shine come through so that I can show the world the truth about God, by showing people how God goes about giving an old guppy back his beautiful colorful tail.


Until then I will have to sit on the sidelines, while all my scientific breakthroughs are deliberately ignored, while I wonder to myself what ever in the world could be wrong with the human race, because what this all will prove at the end of it all is that there definitely was something wrong with the people on this planet.