AP Computer Science A : Computer Science

Study concepts, example questions & explanations for AP Computer Science A

varsity tutors app store varsity tutors android store

Example Questions

Example Question #61 : Primitive Data Types

Which is true?

 

a = 4

b = 2

c = 5

d = 6

 

a) a = c - d 

b) a = b - d

c) a = d - b

d) a = c * d

Possible Answers:

a)

d)

c)

b)

Correct answer:

c)

Explanation:

c) is the correct choice because a = 6 - 2 since d = 6 and b = 2. Substitute the numbers for the variables in each answer choice. You will see that all of the answer choices are not equal to 4 except for c).

Example Question #11 : Evaluating Boolean Expressions

True or False.

 

This code snippet returns an error.

 

String s1 = "foo";

String s2 = "foo";

return s1 == s2;

Possible Answers:

True

False

Correct answer:

False

Explanation:

While the code snippet doesn't return an error, it also doesn't return the answer that you want. Testing string equality requires the method String.equals(). This code snippet uses == to compare two strings. == is a pointer equality function. To get the expected answer (true), the code should return s1.equals(s2).

Example Question #61 : Standard Data Structures

Which of the following Boolean expression evalutes to True?

 

I. False && False && False && True && False 

II. (False && False) || (True || False) || (False && (True || False))

III. (True && False) && (True || False || (True && True))

IV. !(True && True && False)

V. False || False || False || True || False

Possible Answers:

IV, V

III, IV, V, 

I, IV, V

II, IV, V

IV

Correct answer:

II, IV, V

Explanation:

Answer: II, IV, V

The best way to approach this problem is to divide each conditional into chunks. Then, if there is at least one True in a long list of OR statements, the statement must be true according to Boolean Logic. Likewise, if there is at least one False in a long list of AND's, the statment must be False. For example

False && False && False && True evalulates to False

and

True || False || False ... evaluetes to True

Statement I evalutes to False because False and any number of And's must evaluate to false because False && X evalutes to False, regardless of the value of X.

 

Statement II evalutes to True because there is one True statement in a list of OR's that make the entire statement True.

Statement III evalutes to False for the same reason Statement I does.

Statement IV is true because although the conditionals in the parentheses are False, the ! (not) operator negates the False to True.

Statement V is true.

Example Question #1 : Evaluating Boolean Expressions

What does the following code print?

int i = 3;

int j = 4;

int k = 5;

int l = i * k - j; 

int m =  i*2 + j + k; 

if ( ( l > m ) || ( l * i ) = (m+m+i) )

   System.out.println("The statement proves true");

else

   System.out.println("The statement proves false");

Possible Answers:

The statement proves true.

Compiler Error

The statement proves false.

Runtime Error

Correct answer:

Compiler Error

Explanation:

In the second condition, it is not a statement of equivalence but a statement of assignment. This would cause it to have a runtime error. If it was to be a == instead of =, the statement would be true.

Example Question #121 : Computer Science

Consider the following code:

int[] vals = {5,4,2};

String s = "Hervaeus";

String s2 = "";

for(int i = 0; i < s.length(); i++) {

     for(int j = 0; j < vals[i % vals.length]; j++) {

          s2 += s.charAt(i);

     }

}

System.out.println(s2);

What is the output for the code above?

Possible Answers:

HHHHHeeeerrvvvvvaaaaeeuuuuussss

Hervaeeeeeuuuuss

HHHHHeeeeerrrrrrvvvvvaaaaaeeeeeuuuuusssss

HHHHHeeeerrvaeus

The code will note execute.

Correct answer:

HHHHHeeeerrvvvvvaaaaeeuuuuussss

Explanation:

The main thing to look at for this question is the main loop for the code.  This loop first goes through each of the characters in the String s:

int i = 0; i < s.length(); i++

Next, notice the condition on the inner loop:

vals[i % vals.length]

The modulus on i will yield values that are between 0 and 2 (given the length of vals).  This means that you will loop in the inner loop the following sequence of times:

5,4,2,5,4,2,5,4

This will replicate the given letter at the index (i) in the initial string, using 5,4,2,5, etc as the replication count.  Thus, you will replicate "H" 5 times, "e" 4, etc.  This gives you an output:

HHHHHeeeerrvvvvvaaaaeeuuuuussss

Example Question #1 : Common Data Structures

Consider the following code:

char[] values = {'I',' ','l','o','v','e',' ','y','o','u','!','!'};

String s = "";

for(int i = 0; i < values.length / 2; i++) {

    char temp = values[i];

    values[i] = values[values.length - i-1];

    values[values.length - i-1] = temp;

}

for(int i = 0; i < values.length; i++) {

    s += values[i];

}

System.out.println(s);

What is the output for the code above?

Possible Answers:

!!you love I

!!uoy evol I

!uyeolI!o vl

!you I love!

None of the others

Correct answer:

!!uoy evol I

Explanation:

It is easiest to think of the values array as a String: "I love you!!".

Now, the loop is going to run for   or  times.  Notice what it does on each iteration.  It swaps the values at i and values.length - i -1.  Thus, it will do the following swaps:

0 and 11

1 and 10

etc...

This sequence of swaps will eventually reverse the array.  Thus, your output is:

!!uoy evol I

Example Question #122 : Computer Science

Which of the following blocks of code makes every other character in the string s to be upper case, starting with the second character?

Possible Answers:

String s = "This is a great string!";

String s2 = "";

for(int i = 0; i < s.length(); i++) {

        char c = Character.toLowerCase(s.charAt(i));

        if(i % 2 == 1) {

                c = Character.toUpperCase(c);

        }

        s2+=c;

}

String s = "This is a great string!";

String s2 = "";

for(int i = 0; i < s.length(); i++) {

        char c = s.charAt(i);

        if(i % 2 == 1) {

                c = Character.toUpperCase(c);

        }

        s2+=c;

}

String s = "This is a great string!";

String s2 = "";

for(int i = 0; i < s.length(); i++) {

        char c = Character.toLowerCase(s.charAt(i));

        if(i % 2 == 0) {

                c = Character.toUpperCase(c);

        }

        s2+=c;

}

String s = "This is a great string!";

String s2 = "";

for(int i = 0; i < s.length(); i++) {

        char c = Character.toLowerCase(s.charAt(i));

        if(i % 2 == 3) {

                c = Character.toUpperCase(c);

        }

        s2+=c;

}

String s = "This is a great string!";

String s2 = "";

for(int i = 0; i < s.length(); i++) {

        char c = Character.toLowerCase(s.charAt(i));

        s2+=c;

        if(i % 2 == 0) {

                c = Character.toUpperCase(c);

        }

}

Correct answer:

String s = "This is a great string!";

String s2 = "";

for(int i = 0; i < s.length(); i++) {

        char c = Character.toLowerCase(s.charAt(i));

        if(i % 2 == 1) {

                c = Character.toUpperCase(c);

        }

        s2+=c;

}

Explanation:

Given that strings cannot be internally modified, you will have to store your result in a new string, namely s2.  Now, for each character in s, you will have to make that charater lower case to begin with:

char c = Character.toLowerCase(s.charAt(i));

Next, for the odd values of i, you will need to make your value to be upper case.  The modulus operator is great for this!  You can use % 2 to find the odd values.  When the remainder of a division by 2 is equal to 1, you know you have an odd value.  Hence, you have the condition:

 if(i % 2 == 1) {...

Then, once you appropriately capitalize, you can place your character on s2.

Example Question #122 : Computer Science

Which of the following blocks of code converts an array of characters into a string?

Possible Answers:

private static void string() {

    char[] vals = {'A','t', ' ', '6',' ','a','m','!'};

    String s = "";

    for(int i = 0; i < vals.length; i++) {

        vals[i] = s;

    }

}

private static void string() {

    char[] vals = {'A','t', ' ', '6',' ','a','m','!'};

    String s;

    for(int i = 0; i < vals.length; i++) {

        s += vals[i];

    }

}

private static void string() {

    String s = "At 6 am!";

    char[] vals = new char[s.length()];

    for(int i = 0; i < s.length(); i++) {

        vals[i] = s.charAt(i);

    }

}

private static void string() {

    char[] vals = {'A','t', ' ', '6',' ','a','m','!'};

    String s = "";

    for(int i = 0; i < vals.length; i++) {

        s = vals[i];

    }

}

private static void string() {

    char[] vals = {'A','t', ' ', '6',' ','a','m','!'};

    String s = "";

    for(int i = 0; i < vals.length; i++) {

        s += vals[i];

    }

}

Correct answer:

private static void string() {

    char[] vals = {'A','t', ' ', '6',' ','a','m','!'};

    String s = "";

    for(int i = 0; i < vals.length; i++) {

        s += vals[i];

    }

}

Explanation:

The easiest way to consider this is by commenting on the correct answer.  You must begin by defining the character array:

char[] vals = {'A','t', ' ', '6',' ','a','m','!'};

Next, you must initialize the string value s to be an empty string.  This is critical.  Otherwise, you can't build your string!

String s = "";

Next, you have the loop.  This goes through the characters and concatenates the values to the variable s. The operation to concatenate the characters is the "+=". This will give you the string value of the array of characters.

Example Question #122 : Computer Science

See code below:

String[] books = {

                "De Secundis Intentionibus",

                "Leviathan",

                "Averrois Commentaria Magna in Aristotelem De celo et mundo",

                "Logica Docens for Idiots",

                "Logica Utens for Tuba Players"

};

String userInput;

// In code excised from here, a person inputs the value "Logica Utens for Tuba Players" ... 

for(int i = 0; i < books.length; i++) {

        if(books[i] == userInput) {

                System.out.println("This is a wonderful book!!");

        }

}

What is the error in the code above?

Possible Answers:

The use of if on an array element.

The string comparison.

The use of the [] operator on the array.

The way the array is declared.

It overruns an array.

Correct answer:

The string comparison.

Explanation:

The only major issue with this code is the use of the == operator to compare the two strings.  Since the user has input this value, will not have an equality on this test.  You must use the method .equals in order to check whether two strings are equal.  The code should be:

if(books[i].equals(userInput)){

...

(There are some cases in which == will work for string comparison, namely when literals are involved.  However, you should avoid relying on this and always use .equals().)

Example Question #1 : Common Data Structures

String[] books = {

                        "Logica sive Ars Rationalis",

                        "Kritik der reinen Vernunft",

                        "Cursus Philosophicus Thomisticus",

                        "Happy words for happy people",

                        "Insane words for an insane world"

};

String str = "Kittens in a cart";

ArrayList<String> vals = new ArrayList<String>();

for(int i = 0; i < books.length; i++) {

            if(books[i].compareTo(str) > 0) {

                        vals.add(books[i]);

            }

}

System.out.println(vals);

What is the output for this method?

Possible Answers:

[]

[Kritik der reinen Vernunft, Logica sive Ars Rationalis]

[Logica sive Ars Rationalis, Kritik der reinen Vernunft]

[Cursus Philosophicus Thomisticus, Happy words for happy people, Insane words for an insane world]

[Happy words for happy people, Insane words for an insane world]

Correct answer:

[Logica sive Ars Rationalis, Kritik der reinen Vernunft]

Explanation:

The compareTo method for strings compares to string objects and returns:

  • 0 when they are equal
  • Something positive when the given string is alphabetically (really, lexicographically) later than the argument to the method.
  • Something negative when the given string is alphabetically (really, lexicographically) before the argument to the method.

Our strings could be put in this order:

"Cursus Philosophicus Thomisticus"

"Happy words for happy people"

"Insane words for an insane world"

"Kritik der reinen Vernunft"

"Logica sive Ars Rationalis"

 

For each of these, we are asking, "Is it later in order than 'Kittens in a cart'?"  This is true for "Kritik der reinen Vernunft" and "Logica sive Ars Rationalis".  Thus, our output is:

[Logica sive Ars Rationalis, Kritik der reinen Vernunft]

Notice the order—this is due to the order in the original array.

Learning Tools by Varsity Tutors