[
  {
    "prompt": "The access matrix approach to protection has the difficulty that<|start_2d|>\"the matrix, if stored directly, is large and can be clumsy to manage\" <|split_2d|>\"it is not capable of expressing complex protection requirements\" <|split_2d|>\"deciding whether a process has access to a resource is undecidable\" <|split_2d|>\"there is no way to express who has rights to change the access matrix itself\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "the matrix, if stored directly, is large and can be clumsy to manage",
      "incorrect_answers": [
        "it is not capable of expressing complex protection requirements",
        "deciding whether a process has access to a resource is undecidable",
        "there is no way to express who has rights to change the access matrix itself"
      ]
    }
  },
  {
    "prompt": "An integer c is a common divisor of two integers x and y if and only if c is a divisor of x and c is a divisor of y. Which of the following sets of integers could possibly be the set of all common divisors of two integers?<|start_2d|>\"{-6,-2, -1, 1, 2, 6}\" <|split_2d|>\"{-6, -2, -1, 0, 1, 2, 6}\" <|split_2d|>\"{-6, -3, -2, -1, 1, 2, 3, 6}\" <|split_2d|>\"{-6, -3, -2, -1, 0, 1, 2, 3, 6}\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "{-6, -3, -2, -1, 1, 2, 3, 6}",
      "incorrect_answers": [
        "{-6,-2, -1, 1, 2, 6}",
        "{-6, -2, -1, 0, 1, 2, 6}",
        "{-6, -3, -2, -1, 0, 1, 2, 3, 6}"
      ]
    }
  },
  {
    "prompt": "In the NoNicks operating system, the time required by a single file-read operation has four nonoverlapping components:\ndisk seek time-25 msec\ndisk latency time-8 msec\ndisk transfer time- 1 msec per 1,000 bytes\noperating system overhead-1 msec per 1,000 bytes + 10 msec\nIn version 1 of the system, the file read retrieved blocks of 1,000 bytes. In version 2, the file read (along with the underlying layout on disk) was modified to retrieve blocks of 4,000 bytes. The ratio of-the time required to read a large file under version 2 to the time required to read the same large file under version 1 is approximately<|start_2d|>\"1:4\" <|split_2d|>\"1:3.5\" <|split_2d|>\"1:1\" <|split_2d|>\"1.1:1\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "1:3.5",
      "incorrect_answers": [
        "1:4",
        "1:1",
        "1.1:1"
      ]
    }
  },
  {
    "prompt": "You want to cluster 7 points into 3 clusters using the k-Means Clustering algorithm. Suppose after the first iteration, clusters C1, C2 and C3 contain the following two-dimensional points: C1 contains the 2 points: {(0,6), (6,0)} C2 contains the 3 points: {(2,2), (4,4), (6,6)} C3 contains the 2 points: {(5,5), (7,7)} What are the cluster centers computed for these 3 clusters?<|start_2d|>\"C1: (3,3), C2: (4,4), C3: (6,6)\" <|split_2d|>\"C1: (3,3), C2: (6,6), C3: (12,12)\" <|split_2d|>\"C1: (6,6), C2: (12,12), C3: (12,12)\" <|split_2d|>\"C1: (0,0), C2: (48,48), C3: (35,35)\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "C1: (3,3), C2: (4,4), C3: (6,6)",
      "incorrect_answers": [
        "C1: (3,3), C2: (6,6), C3: (12,12)",
        "C1: (6,6), C2: (12,12), C3: (12,12)",
        "C1: (0,0), C2: (48,48), C3: (35,35)"
      ]
    }
  },
  {
    "prompt": "Any set of Boolean operators that is sufficient to represent all Boolean expressions is said to be complete. Which of the following is NOT complete?<|start_2d|>\"{AND, NOT}\" <|split_2d|>\"{NOT, OR}\" <|split_2d|>\"{AND, OR}\" <|split_2d|>\"{NAND}\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "{AND, OR}",
      "incorrect_answers": [
        "{AND, NOT}",
        "{NOT, OR}",
        "{NAND}"
      ]
    }
  },
  {
    "prompt": "Consider the collection of all undirected graphs with 10 nodes and 6 edges. Let M and m, respectively, be the maximum and minimum number of connected components in any graph in the collection. If a graph has no selfloops and there is at most one edge between any pair of nodes, which of the following is true?<|start_2d|>\"M = 10, m = 10\" <|split_2d|>\"M = 10, m = 1\" <|split_2d|>\"M = 7, m = 4\" <|split_2d|>\"M = 6, m = 4\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "M = 7, m = 4",
      "incorrect_answers": [
        "M = 10, m = 10",
        "M = 10, m = 1",
        "M = 6, m = 4"
      ]
    }
  },
  {
    "prompt": "Resolution theorem proving for showing that a formula of propositional logic is not satisfiable has which of the following properties?\nI. It is a sound proof system in the sense that there does not exist a proof of the unsatisfiability of a satisfiable formula of propositional logic.\nII. It is a complete proof system in the sense that there is a proof of unsatisfiability for every unsa tisfiable formula of propositional logic.\nIII. It is a succinct proof system in the sense that whenever an unsatisfiable formula F of propositional logic has a resolution proof, F also has a proof whose length is polynomial in the length of F.<|start_2d|>\"I only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II only\" <|split_2d|>\"I and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I and II only",
      "incorrect_answers": [
        "I only",
        "III only",
        "I and III only"
      ]
    }
  },
  {
    "prompt": "Which of the following statements describe(s) properties of a purely segmented memory system?\nI. It divides memory into units of equal size.\nII. It permits implementation of virtual memory.\nIII. It suffers from internal fragmentation.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II only",
      "incorrect_answers": [
        "I only",
        "III only",
        "I and III"
      ]
    }
  },
  {
    "prompt": "Which of the following statements about floating-point arithmetic is NOT true?<|start_2d|>\"It is inherently nonassociative because some numbers have no exact representation.\" <|split_2d|>\"It is inherently nonassociative because there have to be upper and lower bounds on the size of numbers.\" <|split_2d|>\"Associativity can be achieved with appropriate roundoff conventions.\" <|split_2d|>\"Some rational numbers have no exact representation.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Associativity can be achieved with appropriate roundoff conventions.",
      "incorrect_answers": [
        "It is inherently nonassociative because some numbers have no exact representation.",
        "It is inherently nonassociative because there have to be upper and lower bounds on the size of numbers.",
        "Some rational numbers have no exact representation."
      ]
    }
  },
  {
    "prompt": "Suppose sharing of tiles in a multilevel directory structure is achieved with directory entries that are links pointing to a node containing information about a shared file. Information in this node includes (1) the owner of the file, (2) a count of the number of links to the tile, and (3) the disk block numbers of the file. What is a primary drawback to this approach to sharing?<|start_2d|>\"If the owner modifies the file, another user who does not share will see the changes.\" <|split_2d|>\"If the owner renames the file, other users will not be able to access it.\" <|split_2d|>\"If the owner is allowed to delete a file, dangling links may result.\" <|split_2d|>\"If any user who shares the file appends to it, others who share it will not be able to access the new disk blocks.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "If the owner is allowed to delete a file, dangling links may result.",
      "incorrect_answers": [
        "If the owner modifies the file, another user who does not share will see the changes.",
        "If the owner renames the file, other users will not be able to access it.",
        "If any user who shares the file appends to it, others who share it will not be able to access the new disk blocks."
      ]
    }
  },
  {
    "prompt": "Mergesort works by splitting a list of n numbers in half, sorting each half recursively, and merging the two halves. Which of the following data structures will allow mergesort to work in O(n log n) time?\nI. A singly linked list\nII. A doubly linked list\nIII. An array<|start_2d|>\"None\" <|split_2d|>\"III only\" <|split_2d|>\"I and II only\" <|split_2d|>\"I, II, and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I, II, and III",
      "incorrect_answers": [
        "None",
        "III only",
        "I and II only"
      ]
    }
  },
  {
    "prompt": "If p(x) is the minimal-degree interpolating polynomial for the real-valued function f(x) at the n + 1 distinct real numbers x0, .... xn what is the maximum possible degree of p(x)?<|start_2d|>\"n\" <|split_2d|>\"n + 1\" <|split_2d|>\"n + 2\" <|split_2d|>\"2n\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "n",
      "incorrect_answers": [
        "n + 1",
        "n + 2",
        "2n"
      ]
    }
  },
  {
    "prompt": "An internal hash table has 5 buckets, numbered 0, 1, 2, 3, 4. Keys are integers, and the hash function h(i) = i mod 5 is used, with linear resolution of collisions (i.e., if bucket h(i) is filled, the buckets h(i) + 1, h(i) + 2, ... are tried successively with all bucket numbers computed modulo 5). If elements with keys 13, 8, 24, 10, and 3 are inserted, m that order, into an initially blank hash table, then the content of the bucket numbered 2 is<|start_2d|>\"3\" <|split_2d|>\"8\" <|split_2d|>\"10\" <|split_2d|>\"13\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "3",
      "incorrect_answers": [
        "8",
        "10",
        "13"
      ]
    }
  },
  {
    "prompt": "TCP protocol is responsible (among other things) for<|start_2d|>\"Routing packets through the network\" <|split_2d|>\"Reliable delivery of packets between directly connected machines\" <|split_2d|>\"Reliable delivery of large (multi-packet) messages between machines that are not necessarily directly connected\" <|split_2d|>\"Dealing with differences among operating system architectures\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Reliable delivery of large (multi-packet) messages between machines that are not necessarily directly connected",
      "incorrect_answers": [
        "Routing packets through the network",
        "Reliable delivery of packets between directly connected machines",
        "Dealing with differences among operating system architectures"
      ]
    }
  },
  {
    "prompt": "Let A and B be two sets of words (strings) from \u03a3*, for some alphabet of symbols \u03a3. Suppose that B is a subset of A. Which of the following statements must always be true of A and B ?\nI. If A is finite, then B is finite.\nII. If A is regular, then B is regular.\nIII. If A is context-free, then B is context-free.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I only",
      "incorrect_answers": [
        "II only",
        "III only",
        "I and II only"
      ]
    }
  },
  {
    "prompt": "For all strings x, the function x^M is defined recursively as follows.\ne^M= e, and\nif w is a string and a is a string with length 1, then\n(aw)^M = aw^Ma.\nLet a be a string with length 1, and let x and y be arbitrary strings. Which of the following is true?<|start_2d|>\"a^M = a\" <|split_2d|>\"(ax)^M = (xa)^M\" <|split_2d|>\"(xy)^M = y^Mx^M\" <|split_2d|>\"None of the above\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "None of the above",
      "incorrect_answers": [
        "a^M = a",
        "(ax)^M = (xa)^M",
        "(xy)^M = y^Mx^M"
      ]
    }
  },
  {
    "prompt": "Which of the following is NOT a reasonable justification for choosing to busy-wait on an asynchronous event?<|start_2d|>\"The wait is expected to be short.\" <|split_2d|>\"A busy-wait loop is easier to code than an interrupt handler.\" <|split_2d|>\"There is no other work for the processor to do.\" <|split_2d|>\"The program executes on a time-sharing system.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "The program executes on a time-sharing system.",
      "incorrect_answers": [
        "The wait is expected to be short.",
        "A busy-wait loop is easier to code than an interrupt handler.",
        "There is no other work for the processor to do."
      ]
    }
  },
  {
    "prompt": "The language {ww | w in (0 + 1)*} is<|start_2d|>\"not accepted by any Turing machine\" <|split_2d|>\"accepted by some Turing machine, but by no pushdown automaton\" <|split_2d|>\"accepted by some pushdown automaton, but not context-free\" <|split_2d|>\"context-free, but not regular\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "accepted by some Turing machine, but by no pushdown automaton",
      "incorrect_answers": [
        "not accepted by any Turing machine",
        "accepted by some pushdown automaton, but not context-free",
        "context-free, but not regular"
      ]
    }
  },
  {
    "prompt": "Which of the following statements about Ethernets is typically FALSE?<|start_2d|>\"Ethernets use circuit switching to send messages.\" <|split_2d|>\"Ethernets use buses with multiple masters.\" <|split_2d|>\"Ethernet protocols use a collision-detection method to ensure that messages are transmitted properly.\" <|split_2d|>\"Networks connected by Ethernets are limited in length to a few hundred meters.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Ethernets use circuit switching to send messages.",
      "incorrect_answers": [
        "Ethernets use buses with multiple masters.",
        "Ethernet protocols use a collision-detection method to ensure that messages are transmitted properly.",
        "Networks connected by Ethernets are limited in length to a few hundred meters."
      ]
    }
  },
  {
    "prompt": "Let P be a procedure that for some inputs calls itself (i.e., is recursive). If P is guaranteed to terminate, which of the following statements must be true?\nI. P has a local variable.\nII. P has an execution path where it does not call itself.\nIII. P either refers to a global variable or has at least one parameter.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"I and II only\" <|split_2d|>\"II and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II and III only",
      "incorrect_answers": [
        "I only",
        "II only",
        "I and II only"
      ]
    }
  },
  {
    "prompt": "Which of the following comes closest to being a perfectly secure encryption scheme?<|start_2d|>\"The Caesar Cipher, a substitution cipher\" <|split_2d|>\"DES (Data Encryption Standard), a symmetric-key algorithm\" <|split_2d|>\"Enigma, a transposition cipher\" <|split_2d|>\"One-time pad\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "One-time pad",
      "incorrect_answers": [
        "The Caesar Cipher, a substitution cipher",
        "DES (Data Encryption Standard), a symmetric-key algorithm",
        "Enigma, a transposition cipher"
      ]
    }
  },
  {
    "prompt": "Of the following problems concerning a given undirected graph G, which is currently known to be solvable in polynomial time?<|start_2d|>\"Finding a longest simple cycle in G\" <|split_2d|>\"Finding a shortest cycle in G\" <|split_2d|>\"Finding ALL spanning trees of G\" <|split_2d|>\"Finding a largest clique in G\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Finding a shortest cycle in G",
      "incorrect_answers": [
        "Finding a longest simple cycle in G",
        "Finding ALL spanning trees of G",
        "Finding a largest clique in G"
      ]
    }
  },
  {
    "prompt": "The IP protocol is primarily concerned with<|start_2d|>\"Routing packets through the network\" <|split_2d|>\"Reliable delivery of packets between directly connected machines\" <|split_2d|>\"Reliable delivery of large (multi-packet) messages between machines that are not necessarily directly connected\" <|split_2d|>\"Dealing with differences among operating system architectures\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Routing packets through the network",
      "incorrect_answers": [
        "Reliable delivery of packets between directly connected machines",
        "Reliable delivery of large (multi-packet) messages between machines that are not necessarily directly connected",
        "Dealing with differences among operating system architectures"
      ]
    }
  },
  {
    "prompt": "Of the following, which best approximates the ratio of the number of nonterminal nodes to the total number of nodes in a complete K-ary tree of depth N?<|start_2d|>\"1/K\" <|split_2d|>\"K-1/K\" <|split_2d|>\"log_10 (1/N)\" <|split_2d|>\"N-1/m\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "1/K",
      "incorrect_answers": [
        "K-1/K",
        "log_10 (1/N)",
        "N-1/m"
      ]
    }
  },
  {
    "prompt": "Consider a computer system in which processes can request and release one or more resources. Once a process has been granted a resource, the process has exclusive use of that resource until it is released. If a process requests a resource that is already in use, the process enters a queue for that resource, waiting until the resource is available. Which of the following will NOT deal effectively with the problem of deadlock?<|start_2d|>\"Giving priorities to processes and ordering the wait queues by priority\" <|split_2d|>\"Having a process request all its required resources when it first begins, and restarting if it cannot obtain them all\" <|split_2d|>\"Numbering the resources and requiring that processes request resources in order of increasing number\" <|split_2d|>\"Having processes time out and restart after a random interval of waiting\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Giving priorities to processes and ordering the wait queues by priority",
      "incorrect_answers": [
        "Having a process request all its required resources when it first begins, and restarting if it cannot obtain them all",
        "Numbering the resources and requiring that processes request resources in order of increasing number",
        "Having processes time out and restart after a random interval of waiting"
      ]
    }
  },
  {
    "prompt": "\"Magic memory\"' has two operations: Read and Clear. Both are indivisible and mutually exclusive. Clear sets the magic memory to zero. Read returns a value that represents the number of Read operations since the last Clear operation. Which of the following is (are) true of \"Magic memory\"?\nI. It can provide the functionality of an atomic Test-and-Set.\nII. It can be used to coordinate processes running on a shared-memory multiprocessor.\nIII. It is only useful on a multiprocessor.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I and II",
      "incorrect_answers": [
        "I only",
        "II only",
        "III only"
      ]
    }
  },
  {
    "prompt": "Which of the following is the name of the data structure in a compiler that is responsible for managing information about variables and their attributes?<|start_2d|>\"Abstract Syntax Tree (AST)\" <|split_2d|>\"Attribute Grammar\" <|split_2d|>\"Symbol Table\" <|split_2d|>\"Semantic Stack\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Symbol Table",
      "incorrect_answers": [
        "Abstract Syntax Tree (AST)",
        "Attribute Grammar",
        "Semantic Stack"
      ]
    }
  },
  {
    "prompt": "Which of the following algorithms has running time \u0398(n^2) in the worst case but \u0398(n log n) on average?<|start_2d|>\"Bubblesort\" <|split_2d|>\"Mergesort\" <|split_2d|>\"Heapsort\" <|split_2d|>\"Quicksort\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Quicksort",
      "incorrect_answers": [
        "Bubblesort",
        "Mergesort",
        "Heapsort"
      ]
    }
  },
  {
    "prompt": "Languages with a structure that implements abstract data types (e.g., a C++ class) can prevent access to components of this structure by all operations except those that are part of this structure. However, definitions of such a structure often contain declarations of components of the structure (e.g., the header file for a C++ class may contain declarations of its private components). For such a language, an object's name could be bound at run time to stack storage for its component values (direct representation) or to a stack pointer referencing heap storage for its component values (indirect representation). Which of the following statements about comparisons between direct and indirect representations is (are) true?\nI. Indirect representation noticeably increases compilation time.\nII. Direct representation decreases the time needed to access components of a variable.\nIII. When the storage size of some private component of a variable changes, indirect representation minimizes the number of recompilations of source modules that must be performed.<|start_2d|>\"I only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II only\" <|split_2d|>\"II and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II and III only",
      "incorrect_answers": [
        "I only",
        "III only",
        "I and II only"
      ]
    }
  },
  {
    "prompt": "Which of the following is NOT a property of bitmap graphics?<|start_2d|>\"Fast hardware exists to move blocks of pixels efficiently.\" <|split_2d|>\"Realistic lighting and shading can be done.\" <|split_2d|>\"All line segments can be displayed as straight.\" <|split_2d|>\"Polygons can be filled with solid colors and textures.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "All line segments can be displayed as straight.",
      "incorrect_answers": [
        "Fast hardware exists to move blocks of pixels efficiently.",
        "Realistic lighting and shading can be done.",
        "Polygons can be filled with solid colors and textures."
      ]
    }
  },
  {
    "prompt": "Which of the following is true of interrupts?<|start_2d|>\"They are generated when memory cycles are 'stolen'.\" <|split_2d|>\"They are used in place of data channels.\" <|split_2d|>\"They can indicate completion of an I/O operation.\" <|split_2d|>\"They cannot be generated by arithmetic operations.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "They can indicate completion of an I/O operation.",
      "incorrect_answers": [
        "They are generated when memory cycles are \"stolen\".",
        "They are used in place of data channels.",
        "They cannot be generated by arithmetic operations."
      ]
    }
  },
  {
    "prompt": "In a height-balanced binary search tree, the heights of the left and right descendents of any node differ by at most 1. Which of the following are true of such a tree?\nI. Worst-case search time is logarithmic in the number of nodes.\nII. Average-case search time is logarithmic in the number of nodes.\nIII. Best-case search time is proportional to the height of the tree.\nIV. The height of the tree is logarithmic in the number of nodes.<|start_2d|>\"I and III only\" <|split_2d|>\"II and III only\" <|split_2d|>\"II and IV only\" <|split_2d|>\"I, II, and IV\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I, II, and IV",
      "incorrect_answers": [
        "I and III only",
        "II and III only",
        "II and IV only"
      ]
    }
  },
  {
    "prompt": "Bob writes down a number between 1 and 1,000. Mary must identify that number by asking \"yes/no\" questions of Bob. Mary knows that Bob always tells the truth. If Mary uses an optimal strategy, then she will determine the answer at the end of exactly how many questions in the worst case?<|start_2d|>\"1,000\" <|split_2d|>\"999\" <|split_2d|>\"500\" <|split_2d|>\"10\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "10",
      "incorrect_answers": [
        "1,000",
        "999",
        "500"
      ]
    }
  },
  {
    "prompt": "Which of the following is (are) true about virtual memory systems that use pages?\nI. The virtual address space can be larger than the amount of physical memory.\nII. Programs must be resident in main memory throughout their execution.\nIII. Pages correspond to semantic characteristics of the program.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"I and II\" <|split_2d|>\"I and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I only",
      "incorrect_answers": [
        "II only",
        "I and II",
        "I and III"
      ]
    }
  },
  {
    "prompt": "Which of the following is usually NOT represented in a subroutine's activation record frame for a stack-based programming language?<|start_2d|>\"Values of local variables\" <|split_2d|>\"A heap area\" <|split_2d|>\"The return address\" <|split_2d|>\"Stack pointer for the calling activation record\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "A heap area",
      "incorrect_answers": [
        "Values of local variables",
        "The return address",
        "Stack pointer for the calling activation record"
      ]
    }
  },
  {
    "prompt": "Which of the following statements about a remote procedure call is true?<|start_2d|>\"It is used to call procedures with addresses that are farther than 2^16 bytes away.\" <|split_2d|>\"It cannot return a value.\" <|split_2d|>\"It cannot pass parameters by reference.\" <|split_2d|>\"It cannot call procedures implemented in a different language.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "It cannot pass parameters by reference.",
      "incorrect_answers": [
        "It is used to call procedures with addresses that are farther than 2^16 bytes away.",
        "It cannot return a value.",
        "It cannot call procedures implemented in a different language."
      ]
    }
  },
  {
    "prompt": "Of the following sorting algorithms, which has a running time that is LEAST dependent on the initial ordering of the input?<|start_2d|>\"Insertion sort\" <|split_2d|>\"Quicksort\" <|split_2d|>\"Merge sort\" <|split_2d|>\"Selection sort\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Merge sort",
      "incorrect_answers": [
        "Insertion sort",
        "Quicksort",
        "Selection sort"
      ]
    }
  },
  {
    "prompt": "A particular parallel program computation requires 100 seconds when executed on a single processor. If 40 percent of this computation is \"inherently sequential\" (i.e., will not benefit from additional processors), then the theoretically best possible elapsed times for this program running with 2 and 4 processors, respectively, are<|start_2d|>\"20 and 10 seconds\" <|split_2d|>\"30 and 15 seconds\" <|split_2d|>\"50 and 25 seconds\" <|split_2d|>\"70 and 55 seconds\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "70 and 55 seconds",
      "incorrect_answers": [
        "20 and 10 seconds",
        "30 and 15 seconds",
        "50 and 25 seconds"
      ]
    }
  },
  {
    "prompt": "Consider the representation of six-bit numbers by two's complement, one's complement, or by sign and magnitude. In which representation is there overflow from the addition of the integers 011000 and 011000?<|start_2d|>\"Two's complement only\" <|split_2d|>\"Sign and magnitude and one's complement only\" <|split_2d|>\"Two's complement and one's complement only\" <|split_2d|>\"All three representations\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "All three representations",
      "incorrect_answers": [
        "Two's complement only",
        "Sign and magnitude and one's complement only",
        "Two's complement and one's complement only"
      ]
    }
  },
  {
    "prompt": "Of the following, which best characterizes computers that use memory-mapped I/O?<|start_2d|>\"The computer provides special instructions for manipulating I/O ports.\" <|split_2d|>\"I/O ports are placed at addresses on the bus and are accessed just like other memory locations.\" <|split_2d|>\"To perform an I/O operation, it is sufficient to place the data in an address register and call the channel to perform the operation.\" <|split_2d|>\"Ports are referenced only by memory-mapped instructions of the computer and are located at hardwired memory locations.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I/O ports are placed at addresses on the bus and are accessed just like other memory locations.",
      "incorrect_answers": [
        "The computer provides special instructions for manipulating I/O ports.",
        "To perform an I/O operation, it is sufficient to place the data in an address register and call the channel to perform the operation.",
        "Ports are referenced only by memory-mapped instructions of the computer and are located at hardwired memory locations."
      ]
    }
  },
  {
    "prompt": "Many cryptographic protocols base their security on assumptions about the computational difficulty of integer factorization. Integer factorization serves this purpose because we believe that<|start_2d|>\"integer multiplication is a function whose inverse, factorization, remains difficult for a large class of inputs\" <|split_2d|>\"P = NP\" <|split_2d|>\"even if P = NP, integer factorization is still likely not to be polynomial-time computable\" <|split_2d|>\"testing primality is computationally intractable\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "integer multiplication is a function whose inverse, factorization, remains difficult for a large class of inputs",
      "incorrect_answers": [
        "P = NP",
        "even if P = NP, integer factorization is still likely not to be polynomial-time computable",
        "testing primality is computationally intractable"
      ]
    }
  },
  {
    "prompt": "Which of the following sets of bit strings CANNOT be described with a regular expression?<|start_2d|>\"All bit strings whose number of zeros is a multiple of five\" <|split_2d|>\"All bit strings starting with a zero and ending with a one\" <|split_2d|>\"All bit strings with an even number of zeros\" <|split_2d|>\"All bit strings with more ones than zeros\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "All bit strings with more ones than zeros",
      "incorrect_answers": [
        "All bit strings whose number of zeros is a multiple of five",
        "All bit strings starting with a zero and ending with a one",
        "All bit strings with an even number of zeros"
      ]
    }
  },
  {
    "prompt": "Which of the following conditions can be expressed by a Boolean formula in the Boolean variables p_1, p_2, p_3, p_4 and the connectives \u2227,\u2228 (without \u00ac)?\nI. At least three of p_1, p_2, p_3, p_4 are true.\nII. Exactly three of p_1, p_2, p_3, p_4 are true.\nIII. An even number of p_1, p_2, p_3, p_4 are true.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I only",
      "incorrect_answers": [
        "II only",
        "III only",
        "I and III"
      ]
    }
  },
  {
    "prompt": "Two alternatives for interconnecting a set of processors with bidirectional links are (1) the fully interconnected network, in which each processor is directly connected to every other processor, and (2) the ring network, in which each processor is connected to two other processors. The worst-case path length for a network is the maximum, over all pairs of nodes in the network, of the minimum length paths (measured in number of links) between the nodes. For each type of interconnection of n processors, a figure of merit can be formed as the product of the number of links required for the network times the worst-case path length connecting any two processors. The ratio of this figure of merit for the fully interconnected network compared to that of the ring network, for even n > 2, is<|start_2d|>\"1/(n^2)\" <|split_2d|>\"1/(n(n-1))\" <|split_2d|>\"1/n\" <|split_2d|>\"(n-1)/n\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "(n-1)/n",
      "incorrect_answers": [
        "1/(n^2)",
        "1/(n(n-1))",
        "1/n"
      ]
    }
  },
  {
    "prompt": "For a connected, undirected graph G = (V, E), which of the following must be true?\nI. \u03a3_{v\u2208V} degree(v) is even.\nII. |E| \u2265 |V| \u2212 1\nIII. G has at least one vertex with degree 1.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I and II",
      "incorrect_answers": [
        "I only",
        "II only",
        "III only"
      ]
    }
  },
  {
    "prompt": "In multiprogrammed systems it is advantageous if some programs such as editors and compilers can be shared by several users. Which of the following must be true of multiprogrammed systems in order that a single copy of a program can be shared by several users?\nI. The program is a macro.\nII. The program is recursive.\nIII. The program is reentrant.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"II and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "III only",
      "incorrect_answers": [
        "I only",
        "II only",
        "II and III only"
      ]
    }
  },
  {
    "prompt": "Which of the following decimal numbers has an exact representation in binary notation?<|start_2d|>\"0.1\" <|split_2d|>\"0.2\" <|split_2d|>\"0.3\" <|split_2d|>\"0.5\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "0.5",
      "incorrect_answers": [
        "0.1",
        "0.2",
        "0.3"
      ]
    }
  },
  {
    "prompt": "Function signatures describe the types of the arguments to a function as well as the return value of the function. For instance, the addition function on reals has a signature of\nadd : real x real -> real\nsince it takes two real numbers and returns a real number. But, for a language that allows functions as return values, addition could be considered to have the signature\nadd : real -> (real -> real)\nwhich means that add takes a single real (the first operand) and returns a new function that itself takes a single real (the second operand) and returns a real (the result). This process of reducing a function with multiple arguments to a function with fewer arguments is called currying. Which of the following is correct?<|start_2d|>\"Currying can be applied to any function to the point where it has exactly one input argument.\" <|split_2d|>\"Currying cannot be applied to functions of more than two arguments.\" <|split_2d|>\"Currying cannot be applied to functions that return functions as arguments.\" <|split_2d|>\"Currying cannot be applied w functions that haw arguments that are functions.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Currying can be applied to any function to the point where it has exactly one input argument.",
      "incorrect_answers": [
        "Currying cannot be applied to functions of more than two arguments.",
        "Currying cannot be applied to functions that return functions as arguments.",
        "Currying cannot be applied w functions that haw arguments that are functions."
      ]
    }
  },
  {
    "prompt": "Array A contains 256 elements of 4 bytes each. Its first element is stored at physical address 4,096.\nArray B contains 512 elements of 4 bytes each. Its first element is stored at physical address 8,192.\nAssume that only arrays A and B can be cached in an initially empty, physically addressed, physically tagged, direct-mapped, 2K-byte cache with an 8-byte block size. The following loop is then executed.\nfor (i = 0; i < 256; i++)\n        A[i] = A[i] + B[2*i];\nDuring the execution of the loop, how many bytes will be written to memory if the cache has a write-back policy?<|start_2d|>\"0\" <|split_2d|>\"256\" <|split_2d|>\"1024\" <|split_2d|>\"2000\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "0",
      "incorrect_answers": [
        "256",
        "1024",
        "2000"
      ]
    }
  },
  {
    "prompt": "In which of the following representations of numbers by 8-bit words is the addition of the integers 109 and -42 within range?\nI. One's complement\nII. Two's complement\nIII. Sign and magnitude<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"I and II only\" <|split_2d|>\"I, II, and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I, II, and III",
      "incorrect_answers": [
        "I only",
        "II only",
        "I and II only"
      ]
    }
  },
  {
    "prompt": "If a malicious process is granted temporary administrator-level access to a system<|start_2d|>\"the threat is over as soon as the process is killed\" <|split_2d|>\"the threat is over after the operating system is rebooted\" <|split_2d|>\"the thread is over after rebooting the machine and replacing files that show a virus infection\" <|split_2d|>\"the threat is often permanent until the entire disk is wiped clean\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "the threat is often permanent until the entire disk is wiped clean",
      "incorrect_answers": [
        "the threat is over as soon as the process is killed",
        "the threat is over after the operating system is rebooted",
        "the thread is over after rebooting the machine and replacing files that show a virus infection"
      ]
    }
  },
  {
    "prompt": "Which of the following statements about horizontal versus vertical microarchitecture is (are) true?\nI. Programs for horizontal architectures require more time steps than those for vertical architectures.\nII. Horizontal microinstructions are unencoded.\nIII. Horizontal microinstructions usually have a single opcode and multiple operand specifiers.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"II and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II only",
      "incorrect_answers": [
        "I only",
        "III only",
        "II and III only"
      ]
    }
  },
  {
    "prompt": "A \"strictly binary tree\" is a binary tree in which every node that is not a leaf has two children. Suppose that for a class of strictly binary trees there exists c > 0 such that, for any tree in the class, the ratio of the lengths of any two root-to-leaf paths is bounded above by c. Which of the following best characterizes the height h of any tree in this class, where N is the number of nodes in the tree and N > 1 ?<|start_2d|>\"h <= log2(N)\" <|split_2d|>\"h = 1/c * log2(N)\" <|split_2d|>\"h < c log2(N)\" <|split_2d|>\"h > c log2(N)\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "h < c log2(N)",
      "incorrect_answers": [
        "h <= log2(N)",
        "h = 1/c * log2(N)",
        "h > c log2(N)"
      ]
    }
  },
  {
    "prompt": "Which of the following sorting algorithms has average-case and worst-case running times of O(n log n)?<|start_2d|>\"Bubble sort\" <|split_2d|>\"Insertion sort\" <|split_2d|>\"Merge sort\" <|split_2d|>\"Quicksort\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Merge sort",
      "incorrect_answers": [
        "Bubble sort",
        "Insertion sort",
        "Quicksort"
      ]
    }
  },
  {
    "prompt": "Consider the following equations concerning a stack module that has the operations Push, Pop, Top, and IsEmpty. Which of the equations does NOT represent the conventional semantics of a stack?<|start_2d|>\"IsEmpty(Push(Stack,Elem)) = true\" <|split_2d|>\"Pop(Push(Stack,Elem)) = Stack\" <|split_2d|>\"Top(Push(Stack,Elem)) = Elem\" <|split_2d|>\"IsEmpty(Push(Push(Stack,Elem1),Elem2)) = false\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "IsEmpty(Push(Stack,Elem)) = true",
      "incorrect_answers": [
        "Pop(Push(Stack,Elem)) = Stack",
        "Top(Push(Stack,Elem)) = Elem",
        "IsEmpty(Push(Push(Stack,Elem1),Elem2)) = false"
      ]
    }
  },
  {
    "prompt": "Assume that any assignment statement can be executed in unit time. If as many identical processors as needed are used, what is the minimum number of time units needed to execute the assignments\nA := B + C\nB := A - B\nC := A * E\nD := A/F\nE := B - C\nF := A + B\nwith the same result as if the assignments were executed in the order shown?<|start_2d|>\"1\" <|split_2d|>\"2\" <|split_2d|>\"3\" <|split_2d|>\"4\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "3",
      "incorrect_answers": [
        "1",
        "2",
        "4"
      ]
    }
  },
  {
    "prompt": "Two expressions E and F are said to be unifiable if there are substitutions for the variables of E and F that make the expressions lexically identical. In the following three expressions, only w, x, y, and z are variables.\nI. f(w,w)\nII. f(x,1)\nIII. f(y,g(z))\nWhich pairs of these expressions is (are) pairs of unifiable expressions?<|start_2d|>\"(I, II) only\" <|split_2d|>\"(I, III) only\" <|split_2d|>\"(II, III) only\" <|split_2d|>\"(I, II) and (I, III) only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "(I, II) and (I, III) only",
      "incorrect_answers": [
        "(I, II) only",
        "(I, III) only",
        "(II, III) only"
      ]
    }
  },
  {
    "prompt": "Which of the following instruction-set features is NOT generally considered an obstacle to aggressive pipelining of an integer unit?<|start_2d|>\"Condition codes set by every instruction\" <|split_2d|>\"Variable-length encoding of instructions\" <|split_2d|>\"Instructions requiring widely varying numbers of cycles to execute\" <|split_2d|>\"Several different classes (sets) of registers\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Several different classes (sets) of registers",
      "incorrect_answers": [
        "Condition codes set by every instruction",
        "Variable-length encoding of instructions",
        "Instructions requiring widely varying numbers of cycles to execute"
      ]
    }
  },
  {
    "prompt": "Let k >= 2. Let L be the set of strings in {0, 1}^* such that x \\in L if and only if the number of 0's in x is divisible by k and the number of 1's in x is odd. The minimum number of states in a deterministic finite automaton (DFA) that recognizes L is<|start_2d|>\"k + 2\" <|split_2d|>\"2k\" <|split_2d|>\"k log k\" <|split_2d|>\"k^2\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "2k",
      "incorrect_answers": [
        "k + 2",
        "k log k",
        "k^2"
      ]
    }
  },
  {
    "prompt": "Let G = (V, E) be a finite directed acyclic graph with |E| > 0. Which of the following must be true?\nI. G has a vertex with no incoming edge.\nII. G has a vertex with no outgoing edge.\nIII. G has an isolated vertex, that is, one with neither an incoming edge nor an outgoing edge.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I and II only",
      "incorrect_answers": [
        "I only",
        "II only",
        "III only"
      ]
    }
  },
  {
    "prompt": "Let T be a depth-first search tree of a connected undirected graph G. For each vertex v of T, let pre(v) be the number of nodes visited up to and including v during a preorder traversal of T, and post(v) be the number of nodes visited up to and including v during a postorder traversal of T. The lowest common ancestor of vertices u and v in T is a vertex w of T such that w is an ancestor of both u and v, and no child of w is an ancestor of both u and v. Let (u, v) be an edge in G that is not in T, such that pre(u) < pre(v). Which of the following statements about u and v must be true?\nI. post(u) < post(v)\nII. u is an ancestor of v in T.\nIII. If w is the lowest common ancestor of u and v in T, then w = u.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"II and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II and III",
      "incorrect_answers": [
        "I only",
        "II only",
        "III only"
      ]
    }
  },
  {
    "prompt": "In systems with support for automatic memory management, a garbage collector typically has the responsibility for reclaiming allocated memory objects whose contents cannot affect any future legal computation. Such objects are identified by determining that they cannot be reached from a root set. Which of the following is NOT part of the root set in a typical garbage collector?<|start_2d|>\"Actual parameters of the active procedures\" <|split_2d|>\"Dynamically allocated objects on the heap\" <|split_2d|>\"Global variables of the program\" <|split_2d|>\"Local variables on the call stack\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Dynamically allocated objects on the heap",
      "incorrect_answers": [
        "Actual parameters of the active procedures",
        "Global variables of the program",
        "Local variables on the call stack"
      ]
    }
  },
  {
    "prompt": "In the Internet Protocol (IP) suite of protocols, which of the following best describes the purpose of the Address Resolution Protocol?<|start_2d|>\"To translate Web addresses to host names\" <|split_2d|>\"To determine the IP address of a given host name\" <|split_2d|>\"To determine the hardware address of a given host name\" <|split_2d|>\"To determine the hardware address of a given IP address\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "To determine the hardware address of a given IP address",
      "incorrect_answers": [
        "To translate Web addresses to host names",
        "To determine the IP address of a given host name",
        "To determine the hardware address of a given host name"
      ]
    }
  },
  {
    "prompt": "Which of the following language features requires that stack-based storage allocation be used rather than static allocation?<|start_2d|>\"Recursive procedures\" <|split_2d|>\"Arbitrary goto's\" <|split_2d|>\"Two-dimensional arrays\" <|split_2d|>\"Integer-valued functions\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Recursive procedures",
      "incorrect_answers": [
        "Arbitrary goto's",
        "Two-dimensional arrays",
        "Integer-valued functions"
      ]
    }
  },
  {
    "prompt": "Which of the following is not a sentence that is generated by the grammar A -> BC, B -> x|Bx, C -> B|D, D -> y|Ey, E -> z?<|start_2d|>\"xyz\" <|split_2d|>\"xy\" <|split_2d|>\"xxzy\" <|split_2d|>\"xxxxy\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "xyz",
      "incorrect_answers": [
        "xy",
        "xxzy",
        "xxxxy"
      ]
    }
  },
  {
    "prompt": "Let T (n) be defined by T(1) = 7 and T(n + 1) = 3n + T(n) for all integers n \u2265 1. Which of the following represents the order of growth of T(n) as a function of n?<|start_2d|>\"\u0398(n)\" <|split_2d|>\"\u0398(n log n)\" <|split_2d|>\"\u0398(n^2)\" <|split_2d|>\"\u0398(n^2 log n)\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "\u0398(n^2)",
      "incorrect_answers": [
        "\u0398(n)",
        "\u0398(n log n)",
        "\u0398(n^2 log n)"
      ]
    }
  },
  {
    "prompt": "Which of the following problems is (are) decidable?\nI. Given a (finite) string w, is w a prefix of the decimal expansion of \u03c0?\nII. Given a program and an input, is the program\u2019s output the decimal expansion of \u03c0?\nIII. Given a program that takes as input a prefix of the decimal expansion of \u03c0, is the program\u2019s output always the same for every prefix?<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I only",
      "incorrect_answers": [
        "II only",
        "III only",
        "I and II only"
      ]
    }
  },
  {
    "prompt": "Which of the following statements about circuits is (are) true?\nI. Combinational circuits may have feedback; sequential circuits do not.\nII. Combinational circuits have a \"memoryless\" property; sequential circuits do not.\nIII. Both sequential and combinational circuits must be controlled by an external clock.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"I and II only\" <|split_2d|>\"II and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II only",
      "incorrect_answers": [
        "I only",
        "I and II only",
        "II and III only"
      ]
    }
  },
  {
    "prompt": "Two single-user workstations are attached to the same local area network. On one of these workstations, file pages are accessed over the network from a file server; the average access time per page is 0.1 second. On the other of these workstations, file pages are accessed from a local disk; the average access time per page is 0.05 second. A particular compilation requires 30 seconds of computation and 200 file page accesses. What is the ratio of the total time required by this compilation if run on the diskless (file server) workstation to the total time required if run on the workstation with the local disk, if it is assumed that computation is not overlapped with file access?<|start_2d|>\"1/1\" <|split_2d|>\"5/4\" <|split_2d|>\"5/3\" <|split_2d|>\"10/5\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "5/4",
      "incorrect_answers": [
        "1/1",
        "5/3",
        "10/5"
      ]
    }
  },
  {
    "prompt": "Assume that a debugger places a breakpoint at a load instruction at virtual address 0x77E81234 (hexadecimal notation) in a debugged process P. If the text segment of P begins at 0x77E80000 in P\u2019s virtual address space and if the debugger has mapped this same text segment at 0x01000000 in its virtual address space, which of the following is the virtual address used by the debugger in its WRITE operation, along with a description of how the debugger has mapped the virtual memory page containing this address?<|start_2d|>\"0x01001234; page mapped with READ/WRITE access\" <|split_2d|>\"0x01001234; page mapped with COPY-ON-WRITE access\" <|split_2d|>\"0x76E81234; page mapped with READ/WRITE access\" <|split_2d|>\"0x76E81234; page mapped with COPY-ON-WRITE access\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "0x01001234; page mapped with READ/WRITE access",
      "incorrect_answers": [
        "0x01001234; page mapped with COPY-ON-WRITE access",
        "0x76E81234; page mapped with READ/WRITE access",
        "0x76E81234; page mapped with COPY-ON-WRITE access"
      ]
    }
  },
  {
    "prompt": "Which of the following considerations applies (apply) to choosing the page size in a paging system?\nI. An advantage of larger pages is that they lead to smaller page tables.\nII. An advantage of smaller pages is that they lead to less waste due to internal fragmentation.\nIII. Normally, the dominant factor in disk access time is not dependent on page length, so longer pages can be used advantageously.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"I and III only\" <|split_2d|>\"I, II, and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I, II, and III",
      "incorrect_answers": [
        "I only",
        "II only",
        "I and III only"
      ]
    }
  },
  {
    "prompt": "Two processors, M-5 and M-7, implement the same instruction set. Processor M-5 uses a 5-stage pipeline and a clock cycle of 10 nanoseconds. Processor M-7 uses a 7-stage pipeline and a clock cycle of 7.5 nanoseconds. Which of the following is (are) true?\nI. M-7\u2019s pipeline has better maximum throughput than M-5\u2019s pipeline.\nII. The latency of a single instruction is shorter on M-7\u2019s pipeline than on M-5\u2019s pipeline.\nIII. Programs executing on M-7 will always run faster than programs executing on M-5.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"I and III\" <|split_2d|>\"II and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I only",
      "incorrect_answers": [
        "II only",
        "I and III",
        "II and III"
      ]
    }
  },
  {
    "prompt": "Which of the following pairs of 8-bit, two's-complement numbers will result in overflow when the members of the pairs are added?<|start_2d|>\"11111111, 00000001\" <|split_2d|>\"00000001, 10000000\" <|split_2d|>\"11111111, 10000001\" <|split_2d|>\"10000001, 10101010\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "10000001, 10101010",
      "incorrect_answers": [
        "11111111, 00000001",
        "00000001, 10000000",
        "11111111, 10000001"
      ]
    }
  },
  {
    "prompt": "Two computers communicate with each other by sending data packets across a local area network. The size of these packets is 1,000 bytes. The network has the capacity to carry 1,000 packets per second. The CPU time required to execute the network protocol to send one packet is 10 milliseconds. The maximum rate at which one computer can send data to another is approximately<|start_2d|>\"10,000 bytes/second\" <|split_2d|>\"25,000 bytes/ second\" <|split_2d|>\"100,000 bytes/ second\" <|split_2d|>\"500,000 bytes/ second\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "100,000 bytes/ second",
      "incorrect_answers": [
        "10,000 bytes/second",
        "25,000 bytes/ second",
        "500,000 bytes/ second"
      ]
    }
  },
  {
    "prompt": "Consider the following grammar.\nS \u2192 ( S )\nS \u2192 x\nWhich of the following statements is (are) true?\nI. The grammar is ambiguous.\nII. The grammar is suitable for top-down parsing.\nIII. The grammar is suitable for bottom-up parsing.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"II and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II and III only",
      "incorrect_answers": [
        "I only",
        "II only",
        "III only"
      ]
    }
  },
  {
    "prompt": "Hash tables can contribute to an efficient average-case solution for all of the problems described below EXCEPT:<|start_2d|>\"Counting distinct values: Given a set of n keys, determine the number of distinct key values.\" <|split_2d|>\"Dynamic dictionary: Support the operations of insert, delete, and search in a dictionary.\" <|split_2d|>\"Range search: Given values a and b, find all the records whose key value is in the range a, b.\" <|split_2d|>\"Symbol table lookup: Given a program identifier, find its type and address.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Range search: Given values a and b, find all the records whose key value is in the range a, b.",
      "incorrect_answers": [
        "Counting distinct values: Given a set of n keys, determine the number of distinct key values.",
        "Dynamic dictionary: Support the operations of insert, delete, and search in a dictionary.",
        "Symbol table lookup: Given a program identifier, find its type and address."
      ]
    }
  },
  {
    "prompt": "Let A be a finite set with m elements, and let B be a finite set with n elements. The number of distinct functions mapping A into B is<|start_2d|>\"n^m\" <|split_2d|>\"n!/(n - m)!\" <|split_2d|>\"n!\" <|split_2d|>\"n!/(m!(n - m)!)\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "n^m",
      "incorrect_answers": [
        "n!/(n - m)!",
        "n!",
        "n!/(m!(n - m)!)"
      ]
    }
  },
  {
    "prompt": "To compute the matrix product M_1M_2, where M_1 has p rows and q columns and where M_2 has q rows and r columns, takes time proportional to pqr, and the result is a matrix of p rows and r columns. Consider the product of three matrices N_1N_2N_3 that have, respectively, w rows and x columns, x rows and y columns, and y rows and z columns. Under what condition will it take less time to compute the product as (N_1N_2)N_3 (i.e., multiply the first two matrices first) than to compute it as N_1(N_2 N_3)?<|start_2d|>\"There is no such condition; i.e., they will always take the same time.\" <|split_2d|>\"1/x + 1/z < 1/w + 1/y\" <|split_2d|>\"x > y\" <|split_2d|>\"1/w + 1/x < 1/y + 1/z\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "1/x + 1/z < 1/w + 1/y",
      "incorrect_answers": [
        "There is no such condition; i.e., they will always take the same time.",
        "x > y",
        "1/w + 1/x < 1/y + 1/z"
      ]
    }
  },
  {
    "prompt": "The hit ratio of a cache memory is the percentage of accesses (reads and writes) for which data are found in the cache. Write-through is a policy whereby every write operation updates main memory. Write-back is a policy whereby a write operation to a line found in the cache does not affect main memory until the line is evicted from the cache. Write-allocation is a policy whereby a cache line is allocated and loaded on a write-miss. If it is assumed that write-allocation is always used, which of the following is true?<|start_2d|>\"Write-back usually results in a better hit ratio than write-through.\" <|split_2d|>\"Write-through usually results in a better hit ratio than write-back.\" <|split_2d|>\"The percentage of write operations resulting in a main memory operation will never be larger for write-back than for write-through.\" <|split_2d|>\"The percentage of write operations resulting in a main memory operation will never be larger for writethrough than for write-back.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "The percentage of write operations resulting in a main memory operation will never be larger for write-back than for write-through.",
      "incorrect_answers": [
        "Write-back usually results in a better hit ratio than write-through.",
        "Write-through usually results in a better hit ratio than write-back.",
        "The percentage of write operations resulting in a main memory operation will never be larger for writethrough than for write-back."
      ]
    }
  },
  {
    "prompt": "A particular disk unit uses a bit string to record the occupancy or vacancy of its tracks, with O denoting vacant and 1 denoting occupied. A 32-bit segment of this string has the hexadecimal value D4FE2003. The percentage of occupied tracks for the corresponding part of the disk, to the nearest percent, is<|start_2d|>\"12%\" <|split_2d|>\"25%\" <|split_2d|>\"38%\" <|split_2d|>\"44%\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "44%",
      "incorrect_answers": [
        "12%",
        "25%",
        "38%"
      ]
    }
  },
  {
    "prompt": "An Euler circuit of an undirected graph is a circuit in which each edge of the graph appears exactly once. Which of the following undirected graphs must have an Euler circuit?\nI. A complete graph with 12 vertices\nII. A complete graph with 13 vertices\nIII. A tree with 13 vertices<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II only",
      "incorrect_answers": [
        "I only",
        "III only",
        "I and II"
      ]
    }
  },
  {
    "prompt": "Which of the following characteristics of a programming language is best specified using a context-free grammar?<|start_2d|>\"Identifier length\" <|split_2d|>\"Maximum level of nesting\" <|split_2d|>\"Operator precedence\" <|split_2d|>\"Type compatibility\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Operator precedence",
      "incorrect_answers": [
        "Identifier length",
        "Maximum level of nesting",
        "Type compatibility"
      ]
    }
  },
  {
    "prompt": "Which of the following statements about datagrams sent by a node in a network using IPv4 protocol is (are) true?\nI. Datagrams at the source must be the size of the smallest maximum transmission unit (MTU) of all the links on a path to the destination.\nII. Datagrams may be fragmented during routing.\nIII. Datagrams are reassembled only at the destination.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"II and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II and III",
      "incorrect_answers": [
        "I only",
        "II only",
        "III only"
      ]
    }
  },
  {
    "prompt": "A starvation-free job-scheduling policy guarantees that no job waits indefinitely for service. Which of the following job-scheduling policies is starvation-free?<|start_2d|>\"Round-robin\" <|split_2d|>\"Priority queuing\" <|split_2d|>\"Shortest job first\" <|split_2d|>\"Youngest job first\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Round-robin",
      "incorrect_answers": [
        "Priority queuing",
        "Shortest job first",
        "Youngest job first"
      ]
    }
  },
  {
    "prompt": "Of the following, which gives the best upper bound for the value of f(N) where f is a solution to the recurrence f(2N + 1) = f(2N) = f(N) + log N for N >= 1, with f(1) = 0?<|start_2d|>\"O(log N)\" <|split_2d|>\"O(N log N)\" <|split_2d|>\"O(log N) + 0(1)\" <|split_2d|>\"O((log N)^2)\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "O((log N)^2)",
      "incorrect_answers": [
        "O(log N)",
        "O(N log N)",
        "O(log N) + 0(1)"
      ]
    }
  },
  {
    "prompt": "Company X shipped 5 computer chips, 1 of which was defective, and Company Y shipped 4 computer chips, 2 of which were defective. One computer chip is to be chosen uniformly at random from the 9 chips shipped by the companies. If the chosen chip is found to be defective, what is the probability that the chip came from Company Y?<|start_2d|>\"2 / 9\" <|split_2d|>\"4 / 9\" <|split_2d|>\"1 / 2\" <|split_2d|>\"2 / 3\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "2 / 3",
      "incorrect_answers": [
        "2 / 9",
        "4 / 9",
        "1 / 2"
      ]
    }
  },
  {
    "prompt": "Which of the following problems can be solved by a standard greedy algorithm?\nI. Finding a minimum spanning tree in an undirected graph with positive-integer edge weights\nII. Finding a maximum clique in an undirected graph\nIII. Finding a maximum flow from a source node to a sink node in a directed graph with positive-integer edge capacities<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and II only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I only",
      "incorrect_answers": [
        "II only",
        "III only",
        "I and II only"
      ]
    }
  },
  {
    "prompt": "A program that checks spelling works in the following way. A hash table has been defined in which each entry is a Boolean variable initialized to false. A hash function has been applied to each word in the dictionary, and the appropriate entry in the hash table has been set to true. To check the spelling in a document, the hash function is applied to every word in the document, and the appropriate entry in the hash table is examined. Which of the following is (are) correct?\nI. true means the word was in the dictionary.\nII. false means the word was not in the dictionary.\nIII. Hash table size should increase with document size.<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"I and II only\" <|split_2d|>\"II and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "II only",
      "incorrect_answers": [
        "I only",
        "I and II only",
        "II and III only"
      ]
    }
  },
  {
    "prompt": "One approach to handling fuzzy logic data might be to design a computer using ternary (base-3) logic so that data could be stored as \u201ctrue,\u201d \u201cfalse,\u201d and \u201cunknown.\u201d If each ternary logic element is called a flit, how many flits are required to represent at least 256 different values?<|start_2d|>\"4\" <|split_2d|>\"5\" <|split_2d|>\"6\" <|split_2d|>\"7\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "6",
      "incorrect_answers": [
        "4",
        "5",
        "7"
      ]
    }
  },
  {
    "prompt": "Local caching of files is common in distributed file systems, but it has the disadvantage that<|start_2d|>\"Temporary inconsistencies among views of a file by different machines can result\" <|split_2d|>\"The file system is likely to be corrupted when a computer crashes\" <|split_2d|>\"A much higher amount of network traffic results\" <|split_2d|>\"Caching makes file migration impossible\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "Temporary inconsistencies among views of a file by different machines can result",
      "incorrect_answers": [
        "The file system is likely to be corrupted when a computer crashes",
        "A much higher amount of network traffic results",
        "Caching makes file migration impossible"
      ]
    }
  },
  {
    "prompt": "Array A contains 256 elements of 4 bytes each. Its first element is stored at physical address 4,096.\nArray B contains 512 elements of 4 bytes each. Its first element is stored at physical address 8,192.\nAssume that only arrays A and B can be cached in an initially empty, physically addressed, physically tagged, direct-mapped, 2K-byte cache with an 8-byte block size. The following loop is then executed.\nfor (i = 0; i < 256; i++)\n        A[i] = A[i] + B[2*i];\nDuring the execution of the loop, how many bytes will be written to memory if the cache has a write-through policy?<|start_2d|>\"0\" <|split_2d|>\"256\" <|split_2d|>\"1024\" <|split_2d|>\"2048\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "1024",
      "incorrect_answers": [
        "0",
        "256",
        "2048"
      ]
    }
  },
  {
    "prompt": "At time 0, five jobs are available for execution on a single processor, with service times of 25, 15, 5, 3, and 2 time units. Which of the following is the minimum value of the average completion time of these jobs?<|start_2d|>\"50\" <|split_2d|>\"208/5\" <|split_2d|>\"92/5\" <|split_2d|>\"10\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "92/5",
      "incorrect_answers": [
        "50",
        "208/5",
        "10"
      ]
    }
  },
  {
    "prompt": "Let G = (V, E) be a connected, undirected graph, and let a and b be two distinct vertices in V. Let P_1 be the problem of finding a shortest simple path between a and b, and let P_2 be the problem of finding a longest simple path between a and b. Which of the following statements about P_1 and P_2 is true?<|start_2d|>\"Both P_1 and P_2 can be solved in polynomial time.\" <|split_2d|>\"P_1 can be solved in polynomial time but P_2 is not known to be solvable in polynomial time.\" <|split_2d|>\"P_1 is not known to be solvable in polynomial time but P_2 can be solved in polynomial time.\" <|split_2d|>\"It is not known whether either P_1 or P_2 can be solved in polynomial time.\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "P_1 can be solved in polynomial time but P_2 is not known to be solvable in polynomial time.",
      "incorrect_answers": [
        "Both P_1 and P_2 can be solved in polynomial time.",
        "P_1 is not known to be solvable in polynomial time but P_2 can be solved in polynomial time.",
        "It is not known whether either P_1 or P_2 can be solved in polynomial time."
      ]
    }
  },
  {
    "prompt": "A major advantage of direct mapping of a cache is its simplicity. The main disadvantage of this organization is that<|start_2d|>\"it does not allow simultaneous access to the intended data and its tag\" <|split_2d|>\"it is more expensive than other types of cache organizations\" <|split_2d|>\"the cache hit ratio is degraded if two or more blocks used alternately map onto the same block frame in the cache\" <|split_2d|>\"its access time is greater than that of other cache organizations\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "the cache hit ratio is degraded if two or more blocks used alternately map onto the same block frame in the cache",
      "incorrect_answers": [
        "it does not allow simultaneous access to the intended data and its tag",
        "it is more expensive than other types of cache organizations",
        "its access time is greater than that of other cache organizations"
      ]
    }
  },
  {
    "prompt": "Let M be a single-tape, deterministic Turing machine with tape alphabet {blank,0,1}, and let C denote the (possibly infinite) computation of M starting with a blank tape. The input to each problem below is M, together with a positive integer n. Which of the following problems is (are) decidable?\nI. The computation C lasts for at least n steps.\nII. The computation C lasts for at least n steps, and M prints a 1 at some point after the nth step.\nIII. M scans at least n distinct tape squares during the computation C.<|start_2d|>\"None\" <|split_2d|>\"III only\" <|split_2d|>\"I and II only\" <|split_2d|>\"I and III only\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I and III only",
      "incorrect_answers": [
        "None",
        "III only",
        "I and II only"
      ]
    }
  },
  {
    "prompt": "A 3-way, set-associative cache is<|start_2d|>\"one in which each main memory word can be stored at any of 3 cache locations\" <|split_2d|>\"effective only if 3 or fewer processes are running alternately on the processor\" <|split_2d|>\"possible only with write-back\" <|split_2d|>\"faster to access than a direct-mapped cache\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "one in which each main memory word can be stored at any of 3 cache locations",
      "incorrect_answers": [
        "effective only if 3 or fewer processes are running alternately on the processor",
        "possible only with write-back",
        "faster to access than a direct-mapped cache"
      ]
    }
  },
  {
    "prompt": "Consider an object-oriented language in which all entities are objects. Two relationships arise: (1) the instance relationship, between an object and the class of which that object is a member, and (2) the subclass relationship, between a class and the superclass from which that class inherits properties. In such a language, when a message is sent to an object requesting execution of one of its methods (procedures), the method is located by following<|start_2d|>\"one instance link and then zero or more subclass links\" <|split_2d|>\"one or more instance links and then one or more subclass links\" <|split_2d|>\"one or more instance links\" <|split_2d|>\"one subclass link and then one or more instance links\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "one instance link and then zero or more subclass links",
      "incorrect_answers": [
        "one or more instance links and then one or more subclass links",
        "one or more instance links",
        "one subclass link and then one or more instance links"
      ]
    }
  },
  {
    "prompt": "In a pipelined RISC computer where all arithmetic instructions have the same CPI (cycles per instruction), which of the following actions would improve the execution time of a typical program?\nI. Increasing the clock cycle rate\nII. Disallowing any forwarding in the pipeline\nIII. Doubling the sizes of the instruction cache and the data cache without changing the clock cycle time<|start_2d|>\"I only\" <|split_2d|>\"II only\" <|split_2d|>\"III only\" <|split_2d|>\"I and III\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "I and III",
      "incorrect_answers": [
        "I only",
        "II only",
        "III only"
      ]
    }
  },
  {
    "prompt": "A microcomputer used for data acquisition and control is required to digitize and process four analog input signals and to output their average continually; i.e., in real time. The time for an external analog-to-digital converter (which is triggered by a CPU instruction) to digitize one input is 12 microseconds, and only one digitization occurs at a time. Five CPU instructions, including the triggering instruction, must be executed for each signal digitized. Ten CPU instructions are executed in order to average each set of four samples and output this value. The time to convert the output from digital to analog form is to be ignored. If it is assumed that suitable data buffering is employed, then the maximum average instruction execution time that allows the microcomputer to keep up with the input-output data rates, is<|start_2d|>\"0.8 microseconds\" <|split_2d|>\"1.2 microseconds\" <|split_2d|>\"1.6 microseconds\" <|split_2d|>\"2.4 microseconds\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "1.6 microseconds",
      "incorrect_answers": [
        "0.8 microseconds",
        "1.2 microseconds",
        "2.4 microseconds"
      ]
    }
  },
  {
    "prompt": "Suppose that a certain software product has a mean time between failures of 10,000 hours and has a mean time to repair of 20 hours. If the product is used by 100 customers, what is its availability?<|start_2d|>\"80%\" <|split_2d|>\"90%\" <|split_2d|>\"98%\" <|split_2d|>\"99.80%\" <|end_2d|>Answer: ",
    "prompt_metadata": {
      "label": "99.80%",
      "incorrect_answers": [
        "80%",
        "90%",
        "98%"
      ]
    }
  }
]