[5 pts] Suppose we were to execute f(n) for some number n using the following method.
public class Question1 { public static void f(int n) { int i = 1; while(i * i <= n) { i += 1; } IO.print(i - 1); } }
[5 pts] Suppose we were to execute the following run() method.
public class Question2 { public static void f(int n) { switch(n) { case 0: return 5; case 1: return 7; case 2: return 9; case 3: return 11; default: return 13; } } public static void run() { IO.println(f(2)); IO.println(f(-2)); } }
[5 pts] Suppose we were to execute the following run() method.
public class Question3 { public static int[] f(int[] arr) { arr = new int[arr.length]; for(int i = 0; i < arr.length; i++) { arr[i] = 2 * i; } return arr; } public static void run() { int[] a = { 9, 8, 7 }; int[] b = f(a); IO.println(a[1]); IO.println(b.length); IO.println(b[1]); } }
[15 pts] Write a class method named mode that takes an array of ints as a parameter and returns the integer that occurs in the array most frequently. For example, the following code fragment that uses your mode method should print 23.
int[] a = { 23, 34, 45, 23, 0, 23 }; IO.println(mode(a));
9 13
8 3 2
public static int mode(int[] data) { int maxcount = 0; int maxnum = 0; for(int i = 0; i < data.length; i++) { int count = 0; for(int j = 0; j < data.length; j++) { if(data[j] == data[i]) count++; } if(count > maxcount) { maxcount = count; maxnum = data[i]; } } return maxnum; }