蓝墨云班课测试补做
0x00 写在前面
因为自己的疏忽,忘记完成上一周蓝墨云班课的测试,所以在博客中补做。
0x01 练习、翻译&解析
______ is the process of finding a designated target element within a group of items.
A.Sorting
B.Searching
C.Recursing
D.Helping
E.none of the above
______ 是用于在集合中找到某个指定元素的过程。(排序、查找、营救、帮助、以上都不是)
解析:这个题还是比较显然的,营救&帮助很显然就是用来凑数的选项,然后根据逻辑,显然是程序通过searching来找到某个指定元素的。
As the number of items in a search pool grows, the number of comparisons required to search ____
A.increases
B.decreases
C.stays the same
D.goes to 0
E.none of the above
当查找池中元素的数目增多了,一个查找所需要的比较的次数会____(增加、减少、不变、变为0、以上都不是)
解析:当数据的规模变大,一次查找所需要的比较的次数会由于算法的不同都有一定的增加。
A _____ search looks through the search pool one element at a time.
A.binary
B.clever
C.insertion
D.selection
E.linear
__查找每次对比查找池中的一个元素。(二分、clever、insertion、selection、线性)
解析:在所有选项中需要考虑的只有二分查找和线性查找,但是这题感觉有点问题,因为不管是哪个算法,在迭代的时候每次都只比较了一个元素。
public static Comparable linearSearch (Comparable[] data , Comparable target){
Comparable rlt = null;
int index = 0;
while (rlt == null && index < data.length){
if(data[index].compareTo(target) == 0){
rlt = data[index];
}
index += 1;
}
return rlt;
}
public static Comparable binarySearch(Comparable[] data, Comparable target){
Comparable rlt = null;
int first = 0, last = data.length - 1, mid;
while(rlt == null && first <= last){
mid = (first + last)/2;
if(data[mid].compareTo(target)==0){
rlt = data[mid];
}
else {
if(data[mid].compareTo(target) > 0){
last = mid - 1;
}
else {
first = mid + 1;
}
}
}
return rlt;
}
A _______________ search is more efficient than a linear search.
A.binary
B.selection
C.insertion
D.bubble
E.none of the above
__查找比线性查找更为高效。(二分、selection、insertion、bubble、以上都不是)
解析:二分查找的算法复杂度是O(log2n),显然要比线性查找O(n)的复杂度低得多。
In a binary search, ___________________________ .
A.it is assumed that all of the elements are integers.
B.it is assumed that all of the elements are Strings.
C.it is assumed that the search pool is small.
D.it is assumed that the search pool is ordered.
E.it is assumed that the search pool is large.
二分查找假定数据集合是__(由整数组成、由字符串组成、较小、有序、较大)
解析:因为二分查找是基于每次比较的结果分别“跳入”下标较大或者下标较小的元素上,这种机制就要求数组中的元素是有序的、可比较的。
____________________ is the process of arranging a group of items into a defined order.
A.Searching
B.Sorting
C.Selecting
D.Helping
E.none of the above
__是将一个数组按照指定顺序处理的过程。(查找、排序、选择、帮助、以上都不是)
解析:这个和第一题有点类似,显然是排序。
Which of the following is not a sorting algorithm?
A.Bubble sort
B.Quick sort
C.Merge sort
D.Selection sort
E.all of the above are sorting algorithms
以下哪一个不是排序算法?(冒泡、快排、合并排序、选择排序、以上都是)
解析:以上四个都是排序算法。
Which of the following algorithms is most easily expressed recursively?
A.linear search
B.quick sort
C.bubble sort
D.selection sort
E.none of the above algorithms are easily expressible recursively
以下哪一个算法最容易用递归来表达?(线性查找、快速排序、冒泡排序、选择排序、以上都不是)
解析:虽然理论上几乎所有的循环都可以转化为递归,但是通常而言,对于以上的四个算法我们只在快速排序中使用递归。
The ___________________ algorithm sorts values by repeatedly comparing neighboring elements in the list and swapping their position if the are not in order relative to each other.
A.insertion sort
B.selection sort
C.bubble sort
D.quick sort
E.merge sort
___排序算法通过重复比较相邻元素并交换其位置来实现排序。(插入排序、选择排序、冒泡排序、快速排序、合并排序)
解析:根据以下的算法,就可以知道,冒泡排序比较并在一些情况下交换了data数组的第j和第j+1个元素的值。
public static void bubbleSort (Comparable[] data)
{
int position, scan;
for (position = data.length - 1; position >= 0; position--)
{
for (scan = 0; scan <= position - 1; scan++)
if (data[scan].compareTo(data[scan+1]) > 0)
swap (data, scan, scan+1);
}
}
The __________________ algorithm sorts a list of values by repetitively inserting a particular value into a subset of the list that has already been sorted.
A.insertion sort
B.selection sort
C.bubble sort
D.quick sort
E.merge sort
__算法通过重复地在有序子序列中插入特定的值来实现排序。(插入排序、选择排序、冒泡排序、快速排序、合并排序)
public static void insertionSort (Comparable[] data)
{
for (int index = 1; index < data.length; index++)
{
Comparable key = data[index];
int position = index;
// Shift larger values to the right
while (position > 0 && data[position-1].compareTo(key) > 0)
{
data[position] = data[position-1];
position--;
}
data[position] = key;
}
}
The ___________________ of an algorithm shows the relationship between the size of the problem and the value we hope to optimize.
A.growth function
B.rowth analysis
C.size function
D.size analysis
E.none of the above
一个算法的____展示了问题规模和最优值的关系。(增长函数、增长分析、规模函数、规模分析、以上都不是)
Which of the following algorithms has a time complexity of O(log2 n)?
A.insertion sort
B.selection sort
C.bubble sort
D.linear search
E.binary search
下列哪个算法的复杂度是O(log2 n)?(插入排序、选择排序、冒泡排序、线性查找、二分查找)
解析:应该算是记忆题吧,显然是二分查找
Which of the following algorithms has a worst-case complexity of O(n2)?
A.insertion sort
B.selection sort
C.bubble sort
D.all of the above
E.neither a, b, nor c
下列那个算法的最坏情况复杂度是O(n^2)?(插入排序、选择排序、冒泡排序、以上都是、以上都不是)
解析:和上题一样是记忆题,排序算法中除了快速排序、合并排序和桶排序,其他都是O(n2)。
Suppose we have algorithms that solve a particular problem that have the following complexities. Which one is most efficient?
A.O(1)
B.O(log2n)
C.O(n2)
D.O(n3)
E.O(2n)
假如若干能解决相同问题的算法,算法复杂度如下所示,哪个更高效?
解析:显然是O(1)。
Which of the following algorithms has a worst case complexity of O(n log2n)?
A.insertion sort
B.selection sort
C.bubble sort
D.merge sort
E.none of the above
那个算法在最坏情况下,算法复杂度为O(nlog2n)?(插入排序、选择排序、桶排序、合并排序、以上都不是)
解析:合并算法的最好复杂度为O(log2n),最坏复杂度为O(nlog2n),与快速排序类似。
Every algorithm for a problem has the same efficiency.(False)
对于同一问题的算法都具有相同的复杂度。
解析:这显然是错误的,比如说排序算法里面的几种排序算法都分别有不同的算法复杂度。
A linear search is more efficient than a binary search.(False)
线性查找比二分查找更高效。
解析:这个是不一定的,因为二分查找仅仅在有序的数组下可用。
A linear search always requires more comparisons than a binary search.(False)
线性查找总是需要相比二分查找更多的比较次数。
解析:这也是不一定的,通常来说这个说法没有问题,但是在一些特定的情况下,线性查找就是最好的情况,一次就找到,但是二分查找是最坏的情况,需要查找O(log2n)次。
If there are more items in a search pool, then it will typically require more comparisons to find an item.(True)
如果搜索池中有了更多的元素,则通常会需要更多次数的比较。
Bubble sort is the most efficient searching algorithm.(False)
桶排序是最高效的搜索算法。
解析:首先,桶排序并不是搜索算法,其次,桶排序也不应该认为是最高效的算法,在很多情况下,桶排序所要求的空间复杂度是有些不划算的。
Quick sort works by separating a list into two lists, and recursively sorting the two lists using quick sort.(True)
快排通过将一个列表分为两个子列表,然后递归地对两个子列表使用快排。
解析:如代码所示,分别对min,pivot-1和pivot+1,max两个子列表使用了快速排序
public class QuickSort {
public static void quickSort(Comparable[] data, int min, int max){
int pivot;
if(min < max){
pivot = partition(data,min,max);
quickSort(data,min,pivot - 1);
quickSort(data,pivot + 1,max);
}
}
private static void swap(Comparable[] data, int index1, int index2){
Comparable temp = data[index1];
data[index1] = data[index2];
data[index2] = temp;
}
private static int partition (Comparable[] data, int min, int max){
Comparable partitionValue = data[min];
int left = min;
int right = max;
while (left < right){
while (data[left].compareTo(partitionValue)<=0&&left<right)left+=1;
while (data[right].compareTo(partitionValue)>0)right -= 1;
if(left<right)swap(data,left,right);
}
swap(data,min,right);
return right;
}
}
Bubble sort works by separating a list into two lists, recursively sorting the two lists using bubble sort, and then combining the sorted sublists into a sorted list.(False)
桶排序通过将列表分割为子列表,递归地对子列表使用桶排序,然后将有序子序列合并。
解析:跟上面的是弄反了,桶排序并没有用到递归和分割列表。
To represent constant time complexity we use O(c).(False)
我们通过O(c)来表示常数级别的复杂度。
解析:我们通过O(1)来表示常数级别的复杂度。
With each comparison, a binary search eliminates approximately half of the items remaining in the search pool.(True)
二分查找在每次比较的时候都去除了查找池中一半的元素。
解析:二分查找通过比较中间元素的大小,然后就可以去除当前查找池中一半的元素。
The selection sort algorithm sorts a list of values by repeatedly putting a particular value into its final, sorted position.(True)
选择排序通过将一个特定的值插入到最终的有序位置来实现排序。