15-100: Introductory/Intermediate Programming (Section F)
Fall 2006
Exercise 
09/13/2006
Written - ifs, vars, etc.
Due:  Wed, Sept 20
beginning of class

Relevant Reading:

  • Chapters 5 and 6 of the Karel J. Robot text.
  • Pgs 49-58 of Head First Java.
  • Skim the first chapter of Head First Java.
  • If you have other readings (eg. the Pohl download), look for the following topics:
    • variables, references, assignment, if-else, while, for loops

Assignment:  (worth 10 exercise points) You are encouraged to work together on this exercise.   However, each person should write up their own answers to the questions and hand in their own sheet.    Please put your answers on the answer sheet provided.

For each of the following (Qs 1-10) tell whether the two snippets of code are execution equivalent.  If they are not, explain why not.  (For instance, describe a starting situation where the two snippets do something different, and state what each does.)

1)
pickBeeper();
while (nextToABeeper())
    pickBeeper();
while (nextToABeeper())
      pickBeeper();


2)
if (nextToABeeper())
    while (nextToABeeper())
        pickBeeper();
while (nextToABeeper())
      pickBeeper();


3)
if (facingEast())
{
   move();
   if (facingNorth())
      move();
   turnLeft();
}

if (facingEast() || facingNorth())
{
   move();
}
turnLeft();



4)
if (facingEast())
{
   move();
   if (facingNorth())
      move();
   turnLeft();
}
if (facingEast() && facingNorth())
{
   move();
}
turnLeft();


5)
if (frontIsClear())
    move();
if (! frontIsClear())
    turnLeft();

if (frontIsClear())
    move();
else
    turnLeft();


6)
if (facingWest())
    turnLeft();
else
{  while (facingEast())
   {  turnLeft();
      move();
   }
   move();
}

if (facingWest())
    turnLeft();
else

   move();
}


7)
for (int i = 0; i < 6; i++)
    move();
move();
move();
move();
move();
move();
move();


8)
if (nextToABeeper() && facingNorth())
{  turnLeft();
   if (!nextToABeeper())
      move();
   turnLeft();
}

if (nextToABeeper() && facingNorth())
{  turnLeft();
   move();
   turnLeft();
}


9)
if (nextToABeeper())
    pickBeeper();
else
    move();

if (! nextToABeeper())
    move();
else
    pickBeeper();


10)
if (facingWest() || facingEast())
    move();
else
    turnLeft();

if (! facingWest() && ! facingEast())
    turnLeft();
else
    move();


11)  Write code that has a robot named karel move one block away from its current position and put down a beeper at its new location.   Which direction?   Any direction that is not blocked.     If ALL directions are blocked (ie, karel is in a tiny box),   the robot should remain where it is and not put down a beeper.

12)   Write a code that has a robot named karel put down 12 beepers along the bottom street of the world.  THEN, it returns to the origin, goes up to street 2 and picks up 10 beepers on the corner of street 2 and avenue 1.  If there are not 10 beepers on that corner, the robot should pick up the beepers that ARE there and NOT have an error shutoff.


13
)  What do each of the following expressions evaluate to in Java?   Feel free to type them in and find out.

a)  22 / 7               b)  22 %  7             c)    7 / 22                 d)  7 % 22
e)  10 *  6 / 9        f)   10 * (6 / 9)        g)   10.0 * 6  / 9        h)   10.0  *  (6 / 9)
i)  10 + 5 * 9         j)  10 * 5 + 9
 

14)  Assume the following skeleton of a program.


public class Application
{
  public static void main(String [] args)
  {
      int i = 10;
      double  pi  = 3.14159;

      int a = 0, b=0;
      char c = 'X';
      double f = 0.0, g = 0.0;
      boolean x = true, y = true;

      // snippets go here
  }
}

For each of the following snippets to be inserted where indicated above, indicate the ouput (in the console/terminal window) when the program is run.  If the snippet does not compile, say so and why.   Each snippet is intended to be taken SEPARATELY.  

Try to guess each answer, then use the computer to verify that you were correct.  Ask questions of things you don't understand.   Use the files in the folder of ex09-13.zip file to test your guesses.
 
a)  a = 5;
    System.out.println(a);
    System.out.println(b);
b)  a = i * 5;
    System.out.println(a);
    System.out.println(i);
c)  i = a * 5; 
    System.out.println(a);
    System.out.println(i);
d)  f = 5.3;
    a = f * 2;
    System.out.println(a);
    System.out.println(f);
e)  a = 10;
    c = 'a'; 
    // note single quotes
    System.out.println(a);
    System.out.println(c);
f)  a = 'c'; 
    // note single quotes
    System.out.println(a);
    System.out.println(c);
g)  a = 10;
    c = "a"; 
    // note double quotes
    System.out.println(a);
    System.out.println(c);
h)   c = 'A'; 
    System.out.println(c + 1);
    System.out.println(c + c);
i)    c = 'B'; 
    System.out.println(c + 1);
    System.out.println(c + c);
j)  a = 10;
    c =  a;
    System.out.println(a);
    System.out.println(c);
k)  a = 10;
    b = a * 2;
    a = 6;
    System.out.println(a);
    System.out.println(b);
l)  a = 10;
    f = a * 2;
    a = 6;
    System.out.println(a);
    System.out.println(f);
m)  a = 10;
    b = 3;
    a = a + 2;
    System.out.println(a);
    System.out.println(b);
n)  a = 10;
    b = a + 5;
    a = a + 2;
    System.out.println(a);
    System.out.println(b);
o)  x = true;
    y = false;
    System.out.println(x);
    System.out.println(!  x);
    System.out.println(y);
    System.out.println(!y);
    System.out.println(x && y);
    System.out.println(x || y);
p)  a = 10;
    a++;
    System.out.println(a);
q)  a = 10;
    a--;
    System.out.println(a);
r)  k = 10;
    k--;
    System.out.println(k);
s)  f = 10;
    f--;
    System.out.println(f);
t)  c = 10;
    c--;
    System.out.println(c);
 u)  a = 10;
    a += 5;
    System.out.println(a);
v)  a = 10;
    b = 20;
    if ((a < 10) && (b >10))
        System.out.println("Hello");
    System.out.println("Goodbye");
w)  a = 10;
    b = 20;
    if ((a < 10) && (b >10))
    {         
       System.out.println("Hello");

       System.out.println("Goodbye");
    }
x)  a = 10;
    b = 20;
    if ((a < 10) || (b >10))
        System.out.println("Hello");
    System.out.println("Goodbye");
y)  a = 10;
    b = 20;
    if ((a < 10) || (b >10))
    {      
      System.out.println("Hello");
      System.out.println("Goodbye");
      }
z) a = 10;
   b = 20;
   if (! ((a < 10) && (b >10)))
   {    
      System.out.println("Hello");
      System.out.println("Goodbye");
   }
  else
     System.out.println("Greetings");
  System.out.println("Farewell");
aa)  a = 10;
      while (a <=20)
      {   a = a + 1;
          System.out.println(a);
      }
bb)   a = 10;
     while (a <=20)
        a = a + 1;
     System.out.println(a);
      
cc)   a = 20;
     b = 50;
     while ((a > 10)  && (b > 10))
     {  System.out.println(a + "b");
        a = a - 1;
        b = b - 10;
     }
  



EXTRA CREDIT: 
Do problem 4 on page 170 of the Karel J Robot text.


Handin:
  • Hand in your answers at the beginning of class on Wednesday.