Wednesday, November 27, 2019

Explain the different data structures that are avaliable to computer programmers, giving examples of their use, and reasons why they would be chosen instead of others Essay Example

Explain the different data structures that are avaliable to computer programmers, giving examples of their use, and reasons why they would be chosen instead of others Essay Example Explain the different data structures that are avaliable to computer programmers, giving examples of their use, and reasons why they would be chosen instead of others Essay Explain the different data structures that are avaliable to computer programmers, giving examples of their use, and reasons why they would be chosen instead of others Essay Essay Topic: The Chosen Dats structures are one of the most common principles computer operation, the ability to locate, add or delete data is common and used as soon as you turn on your computer system. The fundamental reason for using data structures is that it uses efficient ways of carrying out the above operations when large amounts of data are involved in the calculations. Lists, string, stacks, queues, arrays trees are some of the most common data structures. They have been adapted from many pre-computing methods, as a queue in its principal is exactly the same as a queue in a shop for items, for example. Linear List A linear list could be considered a one-dimensional array. The list of numbers form what is called a linear list, ie. 5.1, 1.2, .5.9, .3.6, .4.7. Those numbers on themselves are meaningless data, however with a context it becomes information, for example 5.1 is the 0-60 time of a car would be a suitable context. The data in the list has to have a numeric amount of =0. Data can be stored inside computers as a linear list. If an item has to be added, then the item of data in the middle of the list, then all the data after the item needs to be inserted after the item to make way for the new item of data. Algorithms could be developed to do this, however in reality they would not be used, and would prove to be not efficient if large amounts of data were involved. The pointer system is the preffered system to be used, which shows how newer data structures enable the user to insert and delete items of data without having to move any existing data. However this is not the most efficient way of dealing with large amounts of data. Stacks A stack is a method used to insert and delete items from a linear list. The concept of a stack is of fundamental importance in computing as it is used in so many different applications, adnt hius principle of a stack is illustrated. E.g. The numbers in the list: 23, 54, 10 90. If the numbers were set out vertically, the list would look like: 23 54 10 90 If 77 was added to the stack when it is pushed on top of the stack. The stack now looks like this: 77 23 54 10 90 If an item is to be removed, is it said to be popped off the stack in the last number in first number out (LIFO last in first out). Often machine code programming involved push and pop as mnemonics for the same purpose. In reality this system works within a computer memory using a pointer system, so that is points to a memory location inside the computer that indicates the top of the stack. If the pointer is ued iin this way then it gains the name stack pointer. Queues A queue is very simmilar I principle to how a stack operates. A queue is often called a FIFO stack (First in First out). The operation of the queue is the same as the operation of a normal queue. (if you were first into a shop you would get server first). When the data has been processed and the first operation has been used (start pointer) the stack does not shift up, just the pointers are moved. This therefore acts as a circular list, so when all the items have been popped and some more pushed on, the procedure is started again from the top using three pointers. The pseudocode to delete some data from a queue could be shown as the following: PROCEDURE INSERT(Size, Start_Pointer, Stop_pointer, Data) (*is queue full?*) IF start_pointer = 1 AND Stop_Pointer = Size OR Start_Pointer = Stop_Pointer + 1 THEN PRINT Queue is already full EXIT PROCEDURE ENDIF (*Check to see if queue is empty*) IF Start_pointer = 0 THEN (*initialise queue*) SET Start_pointer = 1 and SET Stop_pointer = 1 (*Queue not empty, update pointers*) ELSE IF Stop_pointer = Size THEN SET Stop_pointer = 1 (*Put stop_pointer back to beginning*) ELSE SET Stop_pointer = Stop_pointer + 1 (*Update stop_pointer*) ENDIF ENDIF QUEUE(Stop_pointer) = Data (*Store data in queue*) END PROCEDURE Arrays An array is ordering of data elements so that information can be extracted from them. The size of an array depends on the number of rows and columns. Most high level languages allow many more than two or three dimensional arrays, however much memory is consumed for multi-dimensional arrays. Eg. A 5-D array containing 10 elements in each D would require: 10 X 10 X 10 X 10 X 10 = 100,000 locations. (if each number could be scored in one location). Arrays must be represented in computers as a linear list ( a 1-D array). To represent an array in a computers memory requires mapping of each element of the array to the corresponding locations that will score the array. The 3 X 4 array with an identifies, T. eg. 10 21 37 31 T = 35 22 14 66 13 82 26 94 Using row-by-row mapping, this array is shown as: (1,1) (1,2) (1,3) (1,4) (2,1) (2,2) (2,3) (2,4) (3,1) (3,2) (3,3) (3,4) T 10, 21, 37, 31, 35, 22, 14, 66, 13, 82, 26, 94 Linked Lists In a linked list the structure of the data does not necessarily reflect the way in which the data is stored in the computers memory locations. A linked list uses pointers, where a pointer is simply a number stored in memory which points to another locations where another item of data can be located. When data is required to be added or deleted to a list, it becomes a valuable function of a linked list that additions or deletions can be operated without having to move other items of data. The only parts which actually change are the pointers within the list. The end pointer is usual to be known as a free space pointer at at least one location, which will be where new data is added in the list. The deletion of an item of data will cause a change of pointer location, not of the actual data itself. The procedure for adding a new node. The process for this is shown in five simplied steps below: 1. Determine where in the list the node is to be inserted 2. Store data at the position indicated by free storage pointer 3. Alter free storage pointer to point to the next free location. 4. Alter the files on either side. Eg. 1-2-3 (with 2 being the new node, 1 is linked to 2 and 2 to 3 via changing the current 13 pointer locations. The same principal can be used for circular (ring) lists with the start and end pointer being attached to the same node. Tree Structures Data can not exactly fit into a list structure, and other structures (eg hierarchial data structure) are used. Such a data structure is useful for a related objects, for example a vehicle parts list with the car as a whole taking the primary hierarchial postion. At the bottom of the tree there is a child node which is said to have no children (most commonly called a leaf node or terminal node). Although this is easier to quickly locate data in this way, it is more difficult to add and delete nodes compared with that of linear lists. It is usual to use some form of stack, so that the route though the tree can be tracked to the previously visited nodes. Binary Trees These are a kind of the parent node is only allowed two terminal nodes. Binary tree structures are implemented using pointer systems in similar ways to the node pointers used with linked lists. Once the child node from the parent node is chosen, the further choices exist in a sub-tree because the root node is no longer entirely accessible. Hash tables A hash funtion is a set of rules when applied to a five digit key field creates a suitable address in the table. The has function is simmialr to a pointer that is used to point to a location where the necessary data is located. A generalised has function is used simmialry to the following example Address = Hash function (key field) Hash function = key field is squared, then taken right- hand digits and finally add 1. Using the hashing function for the following number: (12345) we get: Original Number|Number squared|Right-hand three digits|Right-hand three digits ADD 1 12345 152399025 025 26 One disadvantage of the hashing function is their ability to create the same address within the table for different key fields. This is known as a collision.

No comments:

Post a Comment

Note: Only a member of this blog may post a comment.