DM823: String Algorithms (5 ECTS)
        
        
		STADS: 15014301		
		
		
		
		
		
Level
		Master's level course approved as PhD course		
		
		
		
Teaching period
		The course is offered in the autumn semester.		
The course is offered according to needs.		
		
		
		
Teacher responsible
		 Email: rolf@imada.sdu.dk
Timetable
 Email: rolf@imada.sdu.dk
Timetable
		
				
		 
		  | Group | Type | Day | Time | Classroom | Weeks | Comment | 
		 
  | Common | I | Monday | 10-12 | U142 | 36 |  | 
 
  | Common | I | Monday | 10-12 | IMADA semi | 37,39-40,45 |  | 
 
  | Common | I | Monday | 10-12 | U61 | 38,47 |  | 
 
  | Common | I | Monday | 10-12 | U155 | 41 |  | 
 
  | Common | I | Monday | 10-12 | U12 | 43 |  | 
 
  | Common | I | Monday | 10-12 | U31 | 44,46 |  | 
 
  | Common | I | Monday | 10-12 | U146 | 48,50-51 |  | 
 
  | Common | I | Monday | 10-12 | U10 | 49 |  | 
 
  | Common | I | Tuesday | 15-17 | U10 | 36 |  | 
 
  | Common | I | Tuesday | 15-17 | IMADA semi | 37-41,43-44,50-51 |  | 
 
  | Common | I | Tuesday | 15-17 | U29A | 45-49 |  | 
 
  | Common | I | Wednesday | 14-16 | IMADA semi | 36-41,43-51 |  | 
		
		 
		Show entire timetable
	Show personal time table for this course.
	
	
 
	
Comment:
	Ubegrænset deltagerantal.	
	
Prerequisites:
None.
Academic preconditions:
Students taking the course are expected to:
- Have knowledge of methods for the design, correctness analysis, and time analysis of algorithms, corresponding to the contents of the course DM507 Algorithms and Data Structures.
- Be able to use these methods with precision and level of abstraction corresponding to a Bachelor's degree in Computer Science.
Course introductionData sets consisting partly or entirely of string data are common: Most database applications have strings as one of the data types used, and in some areas, such as word processing, bioinformatics, and web retrieval, strings are the core data type. Additionally, strings are a generic and fundamental data model in Computer Science, containing e.g. integers and multi-dimensional data as special cases.
The aim of the course is to give the student knowledge of a number of algorithms and data structures for problems on strings and to enable the student to apply these, or variants thereof, which is important in situations where string data appears.
The course builds on the knowledge acquired in the course DM507 Algorithms and data structures, as well as other algorithmic courses in the Bachelor's programme in Computer Science, and gives competences for master thesis
work in the area.
In relation to the competence profile of the degree it is the explicit focus of the course to:
- Give knowledge and understanding of a collection of specialized models and methods developed within Computer Science based on research on highest international level, as well as of models and methods aimed at applications in other subject areas.
- Give skills to describe, analyze and solve computational problems by using the methods learnt, to analyze pros and cons of different methods in Computer Science, as well as to develop new variants of the methods learnt where the problem at hands requires this.
- Give the competence to plan and execute scientific projects on a high technical level.
Expected learning outcomeThe learning objectives of the course is that the student demonstrates the ability to:
- Explain the functionality and correctness of the algorithms and data structures covered.
- Analyze the algorithms and data structures covered wrt. time and space complexity.
- Design efficient algorithms and data structures for variants of the problem scenarios covered.
- Formulate the above in precise language and notation.
- Implement algorithms and data structures covered in the course.
- Perform experiments on these implementations and reflect on the results achieved.
- Describe the implementation and experimental work done in clear and precise language, and in a structured fashion.
Subject overviewThe following main topics are contained in the course:
- Pattern matching, exact and approximate.
- Suffix trees, suffix arrays, and other string data structures.
- String sorting.
- Compression algorithms.
- Algorithms for string distance measures.
LiteratureMeddeles ved kursets start.
Website
This course uses  
e-learn (blackboard).
Prerequisites for participating in the exam
Project assignment. Pass/fail, internal evaluation by teacher.
Assessment and marking:
Oral Exam, Danish 7-mark scale, external examiner.
Expected working hours
The teaching method is based on three phase model.
Intro phase: 32 hours
Educational activities
Educational formActivities during the study phase: Project.
Language
This course is taught in English, if international students participate. Otherwise the course is taught in Danish.
Course enrollment
See deadline of enrolment.
Tuition fees for single courses
See fees for single courses.