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

Assignment Help Programming Languages
Reference no: EM132882690

ITECH1400 Fundamentals of Programming - Federation University

Learning Outcome: 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:- Thue-Morse Sequences_partners.rar

Reference no: EM132882690

Questions Cloud

Compare and contrast project management methodologies : Review lean transformation framework by explaining lean approaches, project lifecycle and change management - Compare and contrast project management
Review the ten sources of organizational toxicity described : Review the ten sources of organizational toxicity described in Peter-O'Grady and Malloch and describe the ways in which these can be handled by leaders
Describe strategies to make the off-label use and dosage : Describe strategies to make the off-label use and dosage of drugs safer for children from infancy to adolescence. Include descriptions and names of off-label
Discuss a global implication of the disease : Discuss a global implication of the disease. How is this addressed in other countries or cultures? Is this disease endemic to a particular area?
Building a square-free word in the alphabet of three symbols : Write a function in Python that builds an arbitrarily long (potentially infinite) square-free word in the alphabet of three symbols
Did the program or policy meet the original intent : What stakeholders were identified in the evaluation of the program or policy? Who would benefit most from the results and reporting of the program
Explain the legislation and what was accomplished : Explain the legislation and what was accomplished. What additional steps need to be taken to continue advocacy for this issue?
What specific bills has the legislator sponsored : Choose a legislator on the state or federal level who is also a nurse and discuss the importance of the legislator/nurse's role as advocate for improving health
Outline a plan for how might address pmhnp practice issue : Explain what you think are the barriers to PMHNPs practicing independently in your state(ILLINOIS) Outline a plan for how you might address PMHNP practice issue

Reviews

Write a Review

Programming Languages Questions & Answers

  Creating a program that will generate a txt output file

Creating a program that uses a .txt file as input. Creating a program that will generate a .txt output file. You'll be given a text file, called mstu4031_input.txt. That file will contain a list of grades.

  Write a program that counts the number of lines characters

Your mission, should you choose to accept it, is to plot the top 20 characters with the most lines of dialogue in the script in a bar plot.

  Develop logic for program to read customer records

Develop the logic for a program that reads in 100 customer records and stores the first and last name and total purchases in three parallel arrays.

  Create a serial sequence detector

You are to create a "Serial Sequence Detector". Your design will take in clock, reset, and one-bit data signal. Your design will check input data signal on rising edge of the input clock.

  Define the alert function

I have this file and I'm trying to Modify the display_alert() function to also display a line of the countdown on the web page.

  List all other use cases at comparable level of abstraction

One use case is to make a flight reservation. List all other use cases at a comparable level of abstraction. Summarize the purpose of each use case with a sentence.

  Use switch statement to display roman numeral version

Use a switch statement to display the Roman numeral version of that number. Input Validation: Do not accept a number less than 1 or greater than 10.

  Write program to accept number from user-fibonacci series

Write a program that accepts a number 'n' from the user and generates Fibonacci series till n (Fibonacci series starts with 0 and 1.

  Write the definitions of the classes described in exercise

Write the definitions of the classes described in this programming exercise and a program to test your classes. Indent code and insert comments to document your program. Program must be implemented and run as instructed.

  Write application that inputs a telephone number as string

Write an application that inputs a telephone number as a string in the form (555) 555-5555. The application should String method split to extract the area code as a token.

  Write a program that will find mean and standard deviation

Write a program, using C#, that will find the mean and standard deviation of a number of data points. The program should allow the user to either enter data.

  Program to display contents of file in separate line

Display the contents of the file GRADES created in Problem 1. Each student's record should appear on a separate line and include the total score (the sum of the three tests) for that student.

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