Assignment Part 1: A ten-minute Microsoft PowerPoint style presentation to be presented to your colleagues. The presentation can include links to performance data with additional speaker notes and a bibliography using the Harvard referencing system. The presentation slides for the findings should be submitted with speaker notes as one copy.
Assignment Part 2: The submission is in the form of an individual written report. This should be written in a concise, formal business style using single spacing and font size 12. You are required to make use of headings, paragraphs, subsections and illustrations as appropriate, and all work must be supported with research and referenced using the Harvard referencing system. Please also provide a bibliography using the Harvard referencing system. The recommended word limit is 2,000-2,500 words, although you will not be penalized for exceeding the total word limit.
Assignment Part 3: The submission is in the form of an individual written report. This should be written in a concise, formal business style using single spacing and font size 12. You are required to make use of headings, paragraphs, subsections and illustrations as appropriate, and all work must be supported with research and referenced using the Harvard referencing system. Please also provide a bibliography using the Harvard referencing system. The recommended word limit is 1,000-2,000 words, although you will not be penalized for exceeding the total word limit.
You would also submit the actual project file (programme code)
Assignment Part 4: The submission is in the form of an individual written report. This should be written in a concise, formal business style using single spacing and font size 12. You are required to make use of headings, paragraphs, subsections and illustrations as appropriate, and all work must be supported with research and referenced using the Harvard referencing system. Please also provide a bibliography using the Harvard referencing system. The recommended word limit is 2,000-2,500 words, although you will not be penalized for exceeding the total word limit.
Course Learning Outcomes:
A) Examine abstract data types, concrete data structures and algorithms LO2 Specify abstract data types and algorithms in a formal notation
B) Implement complex data structures and algorithms
C) Assess the effectiveness of data structures and algorithms
Assignment Brief and Guidance:
You are working in Elexa as a software developer. Elexa is a solution development company involved in providing IT solutions to corporate sector. It has just got the contract to design and develop a middleware solution that will interface at the front-end to multiple computer provisioning interfaces including SOAP, HTTP, JML and CLI, and the back-end telecom provisioning network via CLI.
Being confident in your proven technical skills and knowledge-base, you Project Manager has made you Team Lead and made you responsible to inform them about designing and implementation of abstract data types.
In this regard, you are required to create a presentation for all collaborating partners on how ADTs can be utilized to improve software design, development and testing.
Furthermore, you have to document an introductory report for distribution to all partners on how to specify abstract data types and algorithms in a formal notation.
Part 1:
You will need to prepare a presentation on how to create a design specification for data structures (i.e. array, set, stack, queue, list tree etc.), explaining the valid operations that can be carried out on the structures using the example of:
1. A stack ADT, a concrete data structure for a First In First out (FIFO) queue.
2. Two sorting algorithms (i.e. insertion, quick, merge, bucket, selection etc.).
3. Two network shortest path algorithms (i.e. Dijkstra's, Bellman-Ford, Floyd-Warshall, Johnson's, Viterbi etc.)
4. You will include formal notations and details in your presentation so that the audience get a clear idea as to what they are and how they function (P1)
5. Further include the role of memory stack in this process, its operations and how it implements function calls (A diagrammatic representation i.e. Process flow etc. would be highly supportive) (P2)
6. For FIFO queue, support your evidence with an example and a diagrammatic representation (M1)
7. Include the comparison of performance of two sorting algorithms (M2)
8. Include the operational analysis of two network shortest path algorithms and support your evidence with example and/or diagrammatic representation (D1)
Part 2:
You will need to provide a formal written report that includes the following:
1. Explanation on how to specify an abstract data type using the example of software stack. You should include the elements like ADT specification using formal notation e.g. ASN.1, use of non-executable program specification language e.g. SDL and VDM, Issues e.g. complexity in software development, design patterns, parallelism, interfaces, encapsulation, information hiding, efficiency etc. and creational conditions like pre- conditions, post-conditions and error conditions (P3)
2. Explanation of the advantages of encapsulation and information hiding when using an ADT (M3)
3. Discussion of imperative ADTs with regards to object orientation. Support your viewpoint with formal justification whether you agree or disagree (D2)
Part 3:
You will need to demonstrate the implementation of atleast one complex data structure and one algorithm in an executable programming language. You need to develop a report that would include:
1. Information about the complex data structure used (i.e. Multi-dimensional arrays, linked lists, stacks, queues, trees, hash tables, heap, graph etc.) and algorithms (sorting, searching, tree traversal, list traversal, hash functions, string manipulation etc.) using handle, pointer, class, methods etc. in an executable programming language
2. Intended and desired outcome of the implementation. Further include what type of problem this implementation of data structure and algorithm would address.
3. Programme code written in the executable programming language
4. Screenshots of the code execution (P4)
5. Any error handling and debugging performed during the process.
6. Test results at execution time and analyzing the actual outcomes against the desired and intended outcomes (P5)
7. Demonstrate how the implementation of selected data structure and algorithm solves the defined problem (M4)
8. Critically evaluate the complexity level of the implemented data structure and algorithm in terms of its implementation and operations (D3)
Part 4:
You will need to provide a formal written report that includes the following:
1. Evaluating the effectiveness of an algorithm (i.e. run time benchmark, compiler/interpreter dependencies, resource usage, degree of parallelism, time, space, power performance etc.) using asymptotic analysis approach (P6)
2. Determine two ways, using which, the efficiency of an algorithm can be measured. Support your evidence with examples and/or diagrammatic representation (P7)
3. With the help of an example, explain what trade-off may occur when specifying an ADT (M5)
4. Evaluate three benefits (i.e. Representation Independence, Modularity, Interchangeability of Parts) of using implementation independent data structures (D4)
Our professional Data Structure and Algorithm Assignment Help tutors always do a comprehensive research before composing any assignment paper, so that, students always get the most genuine assignment work.
Tags: Data Structure and Algorithm Assignment Help, Data Structure and Algorithm Homework Help, Data Structure and Algorithm Coursework, Data Structure and Algorithm Solved Assignments
Download:- Data Structure and Algorithm.rar