Explain the importance of programming style concepts

Assignment Help Other Subject
Reference no: EM133137852

ITECH1400 Fundamentals of Programming - Federation University

ASSIGNMENT - THUE-MORSE SEQUENCES

Learning Outcomes
The following course learning outcomes are assessed by completing this assessment:

Knowledge:
K1. Identify and use the correct syntax of a common programming language.
K2. Recall and use typical programming constructs to design and implement simple software solutions.
K4. Explain the importance of programming style concepts (documentation, mnemonic names, indentation).

Skills:
S1. Utilise pseudocode and/or algorithms as a major program design technique.
S2. Write and implement a solution algorithm using basic programming constructs.
S4. Describe program functionality based on analysis of given program code.

Application of knowledge and skills:
A1. Develop self-reliance and judgement in adapting algorithms to diverse contexts.
A2. Design and write program solutions to identified problems using accepted design constructs.

ASSESSMENT DETAILS
0.Introduction. The Thue-Morse sequence is an infinite word in the alphabet of two symbols, ‘0' and ‘1', which can be constructed in the following way:
(0) t0 = ‘0'
(1) t1 = ‘0' + ‘1' = ‘01'
(2) t2 = ‘01' + ‘10' = ‘0110'
(3) t3 = ‘0110' + ‘1001' = ‘01101001'
...

(n) tn = tn-1 + (tn-1)¯, where (tn-1)¯ denotes the ‘inverse' of tn-1,

i.e. all ‘0's in tn-1 are replaced by ‘1's and vice versa.

...
It is easy to see that each ti is the first half of ti+1, and ti+1
can be seen as an extension of ti.
This sequence of extensions can be performed infinitely many times, thus building an infinite word, T, which contains all tis as its prefixes (beginnings):
T = ‘0110100110010110100101100110100110010110011010010...'
T has an important property: it does not contain "cubes", i.e. three consecutive identical blocks (sub-words).
Thue-Morse sequence has multiple applications ranging from Chess to Group Theory and Differential Geometry.

Task 1. Building Thue-Morse sequence. In this task you are required to write a Python function named thue_morse(n), that takes a positive integer parameter, n, and returns the string tn (defined above).

In your program you may define other (auxiliary) functions with arbitrary names, however, the solution function of this task should be named thue_morse(n).


Task 2. Building a square-free word in the alphabet of three symbols.

In this task you are required to write a function in Python that builds an arbitrarily long (potentially infinite) square-free word in the alphabet of three symbols, ‘1', ‘2', ‘3'. I.e. a word that does not contain "squares" - two consecutive identical sub-words.
Although, this can be done by using the Thue-Morse sequence, in this task we will use another construction, suggested by S. Arshon.

Construction of the Square-Free Word: Again, as in Task 1, we will build a sequence of finite words, ai, that can be extended to an infinite word.
We start with a0 = ‘1'.
Each next word, ak+1, is constructed by replacing each occurrence of the symbols ‘1', ‘2', ‘3' in the previous word, ak, with 3- letter words according to the following rules:

(1) if symbol ‘1' is in an odd position in ak, then it is replaced with the word ‘123', if ‘1' is in even position, it is replaced with ‘321'.

(2) if symbol ‘2' is in an odd position in ak, then it is replaced with the word ‘231', if ‘2' is in even position, it is replaced with ‘132'.

(3) if symbol ‘3' is in an odd position in ak, then it is replaced with the word ‘312', if ‘3' is in even position, it is replaced with ‘213'.

Here's the table repeating the replacement rules in a tabular format:

Please note, that in this description the first symbol is considered to be in position 1. Therefore, you will need to make the necessary adjustments when using Python strings, which are zero-based.

Below you can see the first few steps of the construction process:
a0 = ‘1'
a1 = ‘123'
a2 = ‘123132312'
a3 = ‘123132312321312132312321231'
...
A = ‘1231323123213121323123212312132313213123212313213121323...'

The Programming Tasks.
(a) You are required to write a Python function named square_free(n), that takes a positive integer parameter n and returns the string an (defined above).
Again, as in Task 1, you may define other (auxiliary) functions with arbitrary names, however, the solution function of this task should be named square_free(n).

(b) Write a Python function named print3Blocks(s) that takes a string, s, as a parameter and prints it in blocks of 3 symbols separated by white spaces. For example, print3Blocks(a3) will print:

123 132 312 321 312 132 312 321 231

Task 3. Counting the number of squares in a string.
In this task you are required to write a Python function named count_squares(s) that takes a string, s, as a parameter and returns the number of "squares" in s, i.e. the number of occurrences of two consecutive identical sub-words in s.

For example, count_squares (‘1231233') should return 2 as there are two "squares" in its argument: ‘1231233' and ‘1231233'.

Attachment:- Fundamentals of Programming.rar

Reference no: EM133137852

Questions Cloud

Potential risks for utilizing telehealth services : Address any regulations/policies that should be put in place to further utilization as well as any safeguards that should be implemented to address any potentia
Understanding the healthcare needs of special populations : Discuss how Christian worldview frames understanding the healthcare needs of special populations
Understanding the healthcare needs of special populations : Discuss how Christian worldview frames understanding the healthcare needs of special populations
Describe the importance of having a dei strategy : You have been hired as the Chief Diversity Officer (CDO) for a medium-sized company. The company does not currently have a diversity, equity and inclusion (DEI)
Explain the importance of programming style concepts : Recall and use typical programming constructs to design and implement simple software solutions - Explain the importance of programming style concepts
Design process for welders versus financial managers : Specify the commonalities and the differences in the survey design process for welders versus financial managers. Instead of designing a survey, would it be mor
Calculate inventory turnover and days in inventory : Calculate inventory turnover, days in inventory, and gross profit rate for Sandhill's Photo Corporation for 2020 and 2021
Existing dominant form of unionism : The AFL, IWW, and CIO were all created out of frustration with the existing dominant form of unionism at the time. Explain. What does this imply about the futur
Did these views change during the period of welfare : Describe how the Knights of Labor, the American Federation of Labor, and the Industrial Workers of the World differed in their views of efficiency, equity, and

Reviews

Write a Review

Other Subject Questions & Answers

  What are the common business problems

What are the common business problems addressed by Big Data analytics? In the era of Big Data, are we about to witness the end of data warehousing? Why?

  Compare and contrast the arab uprisings in two of the states

Compare and contrast the Arab Uprisings (and their aftermath) in two of the states that we have covered since the midterm (Syria, Yemen, Egypt).

  Did you use scholarly resources to support your work

Find two examples of when communication was used to bridge two socio-cultural groups, and one example of divisive communication. You may use examples from.

  Reflect on how decision support technologies

Consider where you seek support for clinical decisions. Do you seek advice from other health care professionals in your organization? Do you use computerized clinical decision support systems? Do you perform your own research? Assess the advantage..

  Are decisions made by individuals in response to positive

Social influence is not always negative. In some instances, it may be used to promote beneficial behaviors. Are the decisions made by individuals in response to positive social influences more valid than those made in response to negative social ..

  What strategies will you implement for grouping students

Oftentimes, during math instruction, students are grouped to incorporate collaboration and cooperative learning. What strategies will you implement for grouping

  Case study on hurricane katrina

Case Study on Hurricane Katrina

  Essay on ramsey case

What is the first officer's responsibility at a crime scene and what was done or not done in Ramsey case? Describe how to collect and preserve glass evidence.

  Select a particular medication or clinical problem

Select a particular medication or clinical problem. Describe how the CPOE and/or CDSS technologies support care decisions in this area.

  Discuss importance of developing a viable policy adoption

Explain the Public Policy Lifecycle utilizing a public policy you have become familiar with. Discuss the importance of developing a viable Policy Adoption and what policy makers need to consider when adopting new, or amending existing, policies.

  Major factors influencing demographic shifts

What are three major factors influencing demographic shifts in the aging population in the US - Define demography and explain it in your own words

  Describe metacognition in your own words

Describe metacognition in your own words. What are some metacognitive skills that you utilize when learning something new? Why do you think it is important for students to have these skills? How can students be taught to think? Provide at least tw..

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd