5.5. Lab: for Loops

  • Note that the course policy is that you should not use generative AI without authorization. If you are suspected to have used generative AI and not able to explain/reproduce your work when requested, all your related assignments throughout the semester will be regraded as 0.

  1. Create a dotnet console app project (Create a C# Project), if you have not, in your USERNAME/workspace/introcscs directory; call it Ch05ForLoop.

  2. Prepare your code in VS Code.

  3. Use the file Program.cs to code.

  4. The namespace of this project is IntroCSCS.

  5. The class name of this project is Ch05ForLoop.

  6. When executing code, you will only use the Main() method in class Ch05ForLoop.

  7. You will prepare methods in the same class to be called from the Main() method.

  8. Use a Word document to prepare your assignment.

  9. Number the questions and annotate your answers (using // in code when appropriate) to show your understanding.

  10. For coding questions, screenshot and paste 1) your code in VS Code and 2) the results of the code’s execution (command prompt and username are part of the execution).

Goals for this lab:

  • Practice with loops. You are encouraged to use a for loop where appropriate.

  • Use nested loops where appropriate.

5.5.1. For Loop Lab

This part of the lab comes from loop_lab_stub/loop_lab.cs. You may refer to the code while answering the questions here.

  1. From the terminal, go to your Ch05ForLoop project folder.

  2. code . + Enter from within the Ch05ForLoop directory.

  3. Start working on the methods.

Your task is to Fill in method bodies for each part below:

  1. Complete method PrintReps to be called from Main() like:

    /// Print n copies of s, end to end.
    /// For example PrintReps("Ok", 9) prints: OkOkOkOkOkOkOkOkOk
    static void PrintReps(string s, int n)
    

    Hint: How would you do something like the example PrintReps("Ok", 9) or with a higher count by hand? Probably count under your breath as you write:

     1 2 3 4 5 6 7 8 9
    OkOkOkOkOkOkOkOkOk
    

    This is a counting loop. Use a C-style for loop.

  2. Complete method StringOfReps

    /// Return a string containing n copies of s, end to end.
    /// For example StringOfReps("Ok", 9) returns: "OkOkOkOkOkOkOkOkOk"
    static string StringOfReps(string s, int n)
    

    Note the distinction from the previous part: Here the method prints nothing. Its work is returned as a single string. You have call the method like:

    Console.WriteLine(StringOfReps("Ok", 9));
    
  3. Complete method Factorial: (A factorial, in mathematics, is the product of all positive integers less than or equal to a given positive integer and denoted by that integer and an exclamation point.)

    /// Return n! (n factorial: 1*2*3 *...* n if n >=1;
    /// 0! is 1.).  For example Factorial(4) returns 1*2*3*4 = 24.
    static int Factorial(int n)
    

    It is useful to think of the sequence of steps to calculate a concrete example of a factorial, say 6!:

    Start with 1
    2 * 1 = 2
    3 * 2 = 6
    4 * 6 = 24
    5 * 24 = 120
    6 * 120 = 720
    

    ALSO find the largest value of n for which the method works. (You might want to add a bit of code further testing Factorial, to make this easier.) Caution: although a negative result from the product of two positive numbers is clearly wrong, only half of the allowed values are negative, so the first wrong answer could equally well be positive. Explain how you find the largest value of ``n`` that works in this method.

5.5.2. Head or Tails

Write a method Flip(), that will just randomly print Heads or Tails once. Accomplish this by choosing 0 or 1 arbitrarily with a random number generator. More details follow.

Use a Random object, and make the Random object a local variable inside the Flip method.

It is generally a good idea to only create a single ``Random`` object that stays in scope for the whole program so it can be used by various programs. One way to do that is to make it static. For our purpose here, just place the random object declaration in your Flip() method:

Random r = new Random();

Note again that in the future you would place the object inside your class but outside of any method, so you can use ``r`` in any method in your class.

For int variables low and higher, with low < higher:

int n = r.Next(low, higher);

returns a (pseudo) random int, satisfying low <= n < higher. If you select low and higher as 0 and 2, so there are only two possible values for n, then you can choose to print Heads or Tails with an if-else statement based on the result.

In your Flip method, create a for loop so you generate a random sequence of 10 heads and/or tails. Print out the heads/tails like:

Tails Tails Tails Tails Heads Tails Heads Tails Tails Tails

Place return "" in your else block to avoid a “not all paths return value” warning if you use an else if statement (or simply put the return line at the end of the code block).

Warning

We have discovered some problems with the Next() implementation that sometimes results in random values not being generated. This is likely a bug that will be fixed. If you experience any problems with Next(), the following is for you!

5.5.3. Group Flips

Write a method GroupFlips() using the Flip() method from the last question to:

/// Print out the results from the total number of random flips of a coin.
/// Group them groupSize per line, each followed by a space.
/// The last line may contain fewer than groupSize flips
/// if total is not a multiple of groupSize.  The last line
/// should be followed by exactly one newline in all cases.
/// For example, GroupFlips(10, 4) *could* produce:
///   Heads Heads Tails Heads
///   Heads Tails Heads Tails
///   Tails Tails
static void GroupFlips(int total, int groupSize)

Complete this method definition and test with a variety of calls to GroupFlips in Main. The output from the previous exercise would be produced by the call:

GroupFlips(10, 1);

5.5.4. Reverse String foreach

We already have discussed Reversed String Print. It used a for loop to go through the characters in reverse order. Write a version with the only loop heading:

foreach(char ch in s) {

and no reference to indices in s.

5.5.5. Only Letters

Write a program that defines and tests a method with description and heading:

/// Return s with all non-letters removed.
/// For example OnlyLetters("Hello, World!") returns "HelloWorld".
static string OnlyLetters(string s)

Assume the English alphabet.

5.5.6. Palindrome Exercise

Write a program palindrome.cs that defines and tests a method with description and heading:

/// Return true when s is a palindrome.
/// For example IsPalindrome("A Toyota!") returns true.
static bool IsPalindrome(string s)

A palindrome is a string that contains the same sequence of letters, ignoring capitalization, forward and backward. Non-letters are ignored. Examples are “Madam, I’m Adam.” and “Able was I ‘ere I saw Elba.”

IsPalindrome can be written very concisely by copying and using methods from previous exercises.

Predict what these code fragments print. Then check yourself in csharp:

for (int i = 3; i > 0; i--) {
    for (int j = i; j < 4; j++) {
        Console.Write(j);
    }
    Console.WriteLine();
}

string s = "abcdef";
for (int i = 1; i < s.Length; i += 2) {
    for (int k = 0; k < i; k++) {
        Console.Write(s[i]);
    }
}

5.5.7. Power Table

  1. Write a method that completes and tests with this heading. Be sure your program tests with several values for each parameter:

    /// Print a table of powers of positive integers.
    /// Assume 1 <= nMax <= 12, 1 <= powerMax <= 7.
    /// Example: output of PowerTable(3, 4)
    ///       n^1       n^2      n^3      n^4
    ///         1         1        1        1
    ///         2         4        8       16
    ///         3         9       27       81
    ///
    public static void PowerTable(int nMax, int powerMax)
    

    Make sure the table always ends up with right-justified columns.

  2. Make the table have columns all the same width, but make the width be as small as possible for the parameters provided, leaving a minimal one space (but not less!) between columns somewhere in the table. Consider heading widths, too.