#GESP202412C6T2. 判断题(每题 2 分,共 20 分)

判断题(每题 2 分,共 20 分)

第 1 题 构造函数是一种特殊的类成员函数,构造函数的名称和类名相同。但通过函数重载,可以创建多个同名的构造函数,条件是每个构造函数的参数列表不同。

{{ select(1) }}

  • 正确
  • 错误

第 2 题 类的静态成员函数既能访问类的静态数据成员,也能访问非静态数据成员。

{{ select(2) }}

  • 正确
  • 错误

第 3 题 栈中元素的插入和删除操作都在栈的顶端进行,所以方便用单向链表实现。

{{ select(3) }}

  • 正确
  • 错误

第 4 题 下面代码构建的树一定是完全二叉树:

struct TreeNode {
	int value;
	TreeNode* left;
	TreeNode* right;
};

TreeNode* buildCompleteBinaryTree() {
	TreeNode* root = new TreeNode {1};
	root->left = new TreeNode {2};
	root->right = new TreeNode {3};
	root->left->left = new TreeNode {4};
	root->left->right = new TreeNode {5};
	root->right->left = new TreeNode {6};
	return root;
}

{{ select(4) }}

  • 正确
  • 错误

第 5 题 在二叉排序树中,左子树所有节点的值都大于根节点的值,右子树所有节点的值都小于根节点的值。

{{ select(5) }}

  • 正确
  • 错误

第 6 题 在生成一个派生类的对象时,只调用派生类的构造函数。

{{ select(6) }}

  • 正确
  • 错误

第 7 题 下面的代码实现了二叉树的前序遍历,它通过递归方法访问每个节点并打印节点值。

void preorder(TreeNode* root) {
	if (root == NULL) return;
	cout << root->val << " ";
	preorder(root->left);
	preorder(root->right);
}

{{ select(7) }}

  • 正确
  • 错误

第 8 题 宽度优先搜索算法(BFS)保证了每个节点在最短路径的情况下被访问。

{{ select(8) }}

  • 正确
  • 错误

第 9 题 在解决简单背包问题时,动态规划的状态转移方程如下

dp[i][w] = max(dp[i-1][w], dp[i-1][w - weights[i-1]] + values[i-1]);

该方程表示:在考虑第 i 个物品时,当前背包容量为 w ,如果不放物品 i ,则最大价值是 dp[i-1][w] ;如果放入物品 i ,则最大价值是 dp[i-1][w - weights[i-1]] + values[i-1] ,其中数组 weightsvalues 分别表示所有物品的重量和价值,数组下标从 0 开始。

{{ select(9) }}

  • 正确
  • 错误

第 10 题 栈中元素的插入和删除操作都在栈的顶端进行,所以方便用双向链表比单向链表更合适表实现。

{{ select(10) }}

  • 正确
  • 错误