Semi-random processes involve an adaptive decision-maker, whose goal is to achieve some predetermined objective in an online randomized environment. They have algorithmic implications in various areas of computer science, as well as connections to biological processes involving decision making. In this paper, we consider a recently proposed semi-random graph process, described as follows: we start with an empty graph on n vertices, and in each round, the decision-maker, called Builder, receives a uniformly random vertex v, and must immediately (in an online manner) choose another vertex u, adding the edge {u, v} to the graph. Builder's end goal is to make the constructed graph satisfy some predetermined monotone graph property.We consider the property P H of containing a spanning graph H as a subgraph. It was asked by N. Alon whether for any bounded-degree H, Builder can construct a graph satisfying P H with high probability in O(n) rounds. We answer this question positively in a strong sense, showing that any graph with maximum degree ∆ can be constructed with high probability in (3∆/2 + o(∆))n rounds, where the o(∆) term tends to zero as ∆ → ∞. This is tight (even for the offline case) up to a multiplicative factor of 3. Furthermore, for the special case where H is a spanning forest of maximum degree ∆, we show that H can be constructed with high probability in O(n log ∆) rounds. This is tight up to a multiplicative constant, even for the offline setting. Finally, we show a separation between adaptive and non-adaptive strategies, proving a lower bound of Ω(n √ log n) on the number of rounds necessary to eliminate all isolated vertices w.h.p. using a non-adaptive strategy. This bound is tight, and in fact O(n √ log n) rounds are sufficient to construct a K r -factor w.h.p. using a non-adaptive strategy.