자바(Java)/자바 AP
AP Computer Science A [FRQ] Practice (3)
긱펀
2024. 4. 4. 22:04
반응형
AP Computer Science A [FRQ] Practice (3)
FRQ 3번 문제에는 1-D Array나 ArrayList를 활용한 문제가 나옵니다.
아래는 시험과 관련된 주요 알고리즘 입니다.
Here are some common algorithms that you should be familiar with for the AP CSA exam:
- Determine the minimum or maximum value in an array
- Compute a sum, average, or mode of array elements
- Search for a particular element in the array
- Determine if at least one element has a particular property
- Determine if all elements have a particular property
- Access all consecutive pairs of elements
- Determine the presence or absence of duplicate elements
- Determine the number of elements meeting specific criteria
- Shift or rotate elements left or right
- Reverse the order of the elements
Here are two common array traversal loops that can be used for these algorithms:
1 2 3 4 5 6 7 8 9 10 11 | for (int value : array) { if (value ....) ... } for(int i=0; i < array.length; i++) { if (array[i] ....) ... } | cs |
*FRQ 2012 3번 문제
[정답은 아래 "더보기" 클릭]
더보기
*FRQ 2012 3번 문제 모범답안
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | // Question 3: Horse Barn // Part (a): public int findHorseSpace(String name) { for (int i = 0; i < this.spaces.length; i++) { if (this.spaces[i]!=null && name.equals(this.spaces[i].getName())) { return i; } } return -1; } //Part (b): public void consolidate() { for (int i = 0; i < this.spaces.length-1; i++) { if (this.spaces[i] == null) { for (int j = i+1; j < this.spaces.length; j++) { if (this.spaces[j] != null) { this.spaces[i] = this.spaces[j]; this.spaces[j] = null; j = this.spaces.length; } } } } } //Part (b): Alternative solution (auxiliary with array) public void consolidate() { Horse[] newSpaces = new Horse[this.spaces.length]; int nextSpot = 0; for (Horse nextHorse : this.spaces) { if (nextHorse != null) { newSpaces[nextSpot] = nextHorse; nextSpot++; } } this.spaces = newSpaces; } //Part (b): Alternative solution (auxiliary with ArrayList) public void consolidate() { List<Horse> horseList = new ArrayList<Horse>(); for (Horse h : this.spaces) { if (h != null) horseList.add(h); } for (int i = 0; i < this.spaces.length; i++) { this.spaces[i] = null; } for (int i = 0; i < horseList.size(); i++) { this.spaces[i] = horseList.get(i); } } | cs |
*FRQ 2007 1번 문제(b번만 배열관련 문제)
[정답은 아래 "더보기" 클릭]
더보기
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | // part (a) public static boolean isSelfDivisor(int number) { int n = number; while(n > 0) { int digit = n % 10; if(digit == 0 || number % digit != 0) { return false; } n /= 10; } return true; } // part (b) public static int[] firstNumSelfDivisors(int start, int num) { int[] selfs = new int[num]; int numStored = 0; int nextNumber = start; while(numStored < num) { if(isSelfDivisor(nextNumber)) { selfs[numStored] = nextNumber; numStored++; } nextNumber++; } return selfs; } | cs |
(다르게)
(a)
public class SelfDivisor {
public static boolean isSelfDivisor(int number) {
int originalNumber = number;
while(number > 0) {
int digit = number % 10;
if(digit == 0) return false;
else {
if((originalNumber % digit) == 0) {
number /= 10;
}
else return false;
}
}
return true;
}
}
(b)
public static int[] firstNumSelfDivisors(int start, int num) {
int number = start;
int[] result = new int[num];
int idx = 0;
while(idx < num) {
if(isSelfDivisor(number)) {
result[idx] = number;
idx++;
}
number++;
}
return result;
}
*FRQ 2011 1번 문제
[정답은 아래 "더보기" 클릭]
더보기
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | //Part (a): public int limitAmplitude(int limit) { int numChanged = 0; for (int i = 0; i < this.samples.length; i++) { if (this.samples[i] < -limit) { this.samples[i] = -limit; numChanged++; } if (this.samples[i] > limit) { this.samples[i] = limit; numChanged++; } } return numChanged; } //Part (b): public void trimSilenceFromBeginning() { int i = 0; while (this.samples[i] == 0) { i++; } int[] newSamples = new int[this.samples.length - i]; for (int j = 0; j < newSamples.length; j++) { newSamples[j] = this.samples[j+i]; } this.samples = newSamples; } | cs |
(다르게)
public class Sound {
private int[] samples;
// (a)
public int limitAmplitude(int limit) {
int numChanged = 0;
for(int i = 0; i < this.samples[i]; i++) {
if(samples[i] > limit) {
samples[i] = limit;
numChanged++;
}
else if(samples[i] < -limit) {
samples[i] = -limit;
numChanged++;
}
}
return numChanged;
}
//(b)
public void trimSilenceFromBeginning() {
int num = this.samples.length;
int[] temp = new int[num];
int idx = 0;
for(int i = 0; i < num; i++) {
if(sample[i] == 0) continue;
else {
temp[idx] = this.sample[i];
idx++;
}
}
this.sample = temp;
}
}
*FRQ 2009 1번 문제
[정답은 아래 "더보기" 클릭]
더보기
*FRQ 2009 1번 문제 정답
(a)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | PART A: /** Returns an array of the values obtained by tossing * a number cube numTosses times. * @param cube a NumberCube * @param numTosses the number of tosses to be recorded * Precondition: numTosses > 0 * @return an array of numTosses values */ public static int[] getCubeTosses(NumberCube cube, int numTosses) { int[] cubeTosses = new int[numTosses]; for (int i = 0; i < numTosses; i++) { cubeTosses[i] = cube.toss(); } return cubeTosses; } | cs |
(b)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | PART B: /** Returns the starting index of a longest run of two or more * consecutive repeated values in the array values. * @param values an array of integer values representing a series * of number cube tosses * Precondition: values.length > 0 * @return the starting index of a run of maximum size; * -1 if there is no run */ public static int getLongestRun(int[] values) { int currentLen = 0; int maxLen = 0; int maxStart = -1; for (int i = 0; i < values.length-1; i++) { if (values[i] == values[i+1]) { currentLen++; if (currentLen > maxLen) { maxLen = currentLen; maxStart = i - currentLen + 1; } } else { currentLen = 0; } } return maxStart; } | cs |
(다르게)
public class NumberCube {
// @return an integer value between 1 and 6, inclusive
public int toss() {
}
// (a)
public static int[] getCubeTosses(NumberCube cube, int numTosses) {
int[] myCube = new int[numTosses];
for(int i = 0; i < myCube.length; i++) {
myCube[i] = cube.toss();
}
return myCube;
}
// (b)
public static int getLongestRun(int[] values) {
int count = 0;
int maxLength = 0;
int maxIndex = -1;
for(int i = 0; i < values.length - 1; i++) {
if(values[i] == values[i+1]) {
count++;
if(count > maxLength) {
maxLength = count;
maxIndex = i - count + 1;
}
}
else {
count = 0;
}
}
return maxIndex;
}
}
728x90
반응형