3498 lines
No EOL
6.6 MiB
Executable file
3498 lines
No EOL
6.6 MiB
Executable file
[
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Ralph owns a furniture store that trades in second-hand furniture, lamps and musical instruments. He buys these items, repairs them where necessary and then resells them.</p>\n<p>He calculates the value of each item using the information below:</p>\n<ul>\n<li>type: furniture, lamp, musical instrument</li>\n<li>brand recognition: 1 (low), 2 (medium), 3 (high)</li>\n<li>condition: “very good”, “good”, “needs repair”</li>\n<li>estimated volume of item: maximum volume accepted is 2000 dm<sup>3</sup><br/>(note that 1 dm<sup>3</sup> = 1 litre).</li>\n</ul>\n<p>Ralph is going to use a spreadsheet to model this information.</p>\n</div><div class=\"specification\">\n<p>The spreadsheet model will inform Ralph as to whether he should buy an item. The decision to buy is based on the following rules:</p>\n<ul>\n<li>the default values for the items are; furniture $100, lamp $30, musical instrument $80</li>\n<li>multipliers are applied to these default values depending on the volume of the item; <br/>for volumes that are 500 dm<sup>3</sup> or above it is 0.7, for volumes less than or equal to 30 dm<sup>3</sup> it is 1.2, for any other volume it is 1.</li>\n</ul>\n<p>Ralph will not buy any item with a value calculated to be over $90.</p>\n</div><div class=\"specification\">\n<p>The model is also used to calculate his final selling price for each item. This price is calculated using the following rules:</p>\n<ul>\n<li>initial selling value is 5 times the original default value</li>\n<li>a multiplier of 1, 2 or 3 is applied to reflect the brand recognition (a “top brand” receives a multiplier of 3)</li>\n<li>another multiplier is applied to reflect the volume occupied. This multiplier is 5 when the volume is greater or equal to 500 dm<sup>3</sup>, 3 for volumes between 30 and 500 dm<sup>3</sup> and 1 for other volumes</li>\n<li>a further multiplier is applied depending upon the item’s condition. This multiplier is 2 or 3 when conditions are good or very good, but is 0.8 if the item is damaged.</li>\n</ul>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the following table showing the variables, each variable’s data type and range of values that would represent the information shown above.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using the above rules, construct the pseudocode that will help Ralph in deciding whether to buy an item.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> items that would have a calculated value of more than $90.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Calculate the selling price of a top brand guitar with a volume of 96 dm<sup>3</sup> that was damaged. You should show your working.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With the help of a diagram, suggest an appropriate design for a spreadsheet used to calculate the final selling price, following this model.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> tests that should be included in the test plan for this model.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>:<br/><em>Award <strong>[1]</strong> for each <strong>fully correct</strong> row indicating <span style=\"text-decoration:underline;\">variable name</span>, <span style=\"text-decoration:underline;\">type</span>, and <span style=\"text-decoration:underline;\">values</span> </em><em>(no marks for incomplete information, but do allow abbreviated strings)</em></p>\n<p><em>e.g.</em></p>\n<p><em><img src=\"\"/></em></p>\n<p><em><strong>Note</strong>: If a full column is missing, then award <strong>[1]</strong> for each correct column (for a max of <strong>[2]</strong>).</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong>:</em><br/><em>Award <strong>[1]</strong>: correct initialisation of <code>Initvalue</code>.</em><br/><em>Award <strong>[1]</strong>: correct calculation of Temp.</em><br/><em>Award <strong>[1]</strong>: correct comparison of Temp with 90.</em><br/><em>Award <strong>[1]</strong>: correct return/output.</em></p>\n<pre>proc Decide(Item, Vol)<br/>Var Temp<br/><strong>if</strong> Item = f then Initvalue = 100<br/><strong> else if</strong> Item = l then Initvalue = 30<br/><strong> else if</strong> Item = m then Initvalue = 80;<br/><strong>endif</strong><br/><strong>if</strong> Vol >= 500 then Temp = 0.7 * Initvalue // accept <,><br/><strong> else if</strong> Vol =< 30 then Temp = 1.2 * Initvalue<br/><strong> else</strong> Temp = Initvalue;<br/><strong>endif</strong><br/><strong>if</strong> Temp > 90 then<br/> return \"Reject\" // accept any 2 reasonable outputs<br/><strong> else</strong> return \"Accept\";<br/><strong>endif</strong></pre>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Any item of furniture with a volume <math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mo><</mo></math> 500 dm<sup>3</sup>;<br/>Any musical instrument with a volume <math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mo>≤</mo></math> 30 dm<sup>3</sup>;</p>\n<p><em>Example answers</em>:<br/>A piece of furniture with volume of 400 dm<sup>3</sup>;<br/>A piece of furniture with volume <math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mo><</mo></math> 30 dm<sup>3</sup>;<br/>A flute with volume of 1 dm<sup>3</sup>;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong>:</em><br/><em>Award <strong>[2]</strong> for completely correct answer (only the left or right-hand side needs to be shown).</em><br/><em>Award <strong>[1]</strong> for correctly writing just 4 factors from the left-hand side.</em></p>\n<p>5 * 80 * 3 * 3 * (80/100) = $2880</p>\n<p><em>Alternative expression for the left-hand side</em>:</p>\n<p>5 * (<code>Item.IType.Initvalue</code>) * (<code>Item.IType.IBrand</code>) * <br/>(<code>Item.IVol.Percentage</code>) * (<code>Item.ICond.Multiplier</code>)</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for some layout design.</em><br/><em>Award <strong>[1]</strong> for each of the following elements</em>:</p>\n<ul>\n<li>correct formula for <code>Itype</code>\n</li>\n<li>correct formula for <code>Ivol</code>\n</li>\n<li>correct formula for <code>Icond</code>\n</li>\n<li>correct formula for Selling Price.</li>\n</ul>\n<p><img src=\"\"/></p>\n<p><em>Example for <strong>[2]</strong>:</em><br/><em>Award <strong>[1]</strong> for the general layout.</em><br/><em>Award <strong>[1]</strong> for detail (Vlookup table, explanations)</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>:<br/>Type consistency, e.g. currency, integer, floating<br/>Range consistency, depending on the decision procedure,<br/>Value at the limits given by the specification (e.g. < or =<)</p>\n<p><em>Accept any testing that relates to</em></p>\n<ul>\n<li><em>normal data // <strong>Note</strong>: an example will get this mark</em></li>\n<li><em>extreme data,</em></li>\n<li><em>abnormal data.</em></li>\n</ul>\n<p><em><strong>Note:</strong> Answers must be more specific than alpha/beta testing, dry-run, etc</em>.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.4",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations",
|
||
"b-1-the-basic-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>In a small shop two people prepare and sell bread rolls. The space for preparing the bread rolls is small. This space includes a sink and a cash register. Each of the ingredients used to fill the bread rolls is kept in a separate bowl with its own fork or spoon. Sometimes the bowls need to be refilled.</p>\n<p>Preparing a bread roll requires the following steps:</p>\n<ul>\n<li>slice the bread roll</li>\n<li>spread its base with some sauce</li>\n<li>add lettuce</li>\n<li>fill with at most two chosen fillings</li>\n<li>cover the roll with the other half</li>\n<li>wrap it in paper.</li>\n</ul>\n<p>After that, the roll is ready for payment and collection.</p>\n<p>Even when the shop is busy, each person only prepares one bread roll at a time.</p>\n</div><div class=\"specification\">\n<p>A larger restaurant is already using simulation software for the preparation of their dishes.</p>\n<p>The restaurant has a menu with eight possible dishes. These dishes may require a number of steps such as cutting, mixing, boiling and grilling to prepare them, as well as different cooking times. The restaurant has a cook and an assistant who prepare <strong>one</strong> dish at the time.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> problems with this method of preparation that could affect the time it takes the two people to prepare an order.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how the two people could improve the efficiency of their work, without compromising on the quality of service to the customers.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the difference between a model and a simulation.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> elements that the simulation software might consider, in addition to the information already described above.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The simulation program will group all orders received in an interval of 10 minutes. The program will then produce a sequence of all the cooking steps so that these orders can be completed as quickly as possible. Once the kitchen has completed the orders for one interval, it is ready to accept orders for the next interval.</p>\n<p>Customers are impressed by the rapidity of service, but not by the quality of prepared food.</p>\n<p>Suggest <strong>two</strong> elements that the software simulation may have not considered that may lead to complaints from the customers.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong>:</em><br/><em>Award <strong>[1]</strong> for identifying a problem, <strong>[1]</strong> for an elaboration.</em><br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>There is no evidence that there are two knives to slice the bread roll;<br/>so one of them could already be delayed;</p>\n<p>There could be need of the same fillings;<br/>meaning that the two bread rolls will be prepared with a slight delay;</p>\n<p>One fork/spoon falls down and will need to be washed;<br/>there must be a policy on who will wash it;</p>\n<p>One ingredient is finished and needs replenishment;<br/>there must be a policy on who collects the new bowl;</p>\n<p>There can be concurrent access to the cash register<br/>there must be a policy on who goes first;</p>\n<p>No evidence that both persons have space/paper to wrap simultaneously on the table;<br/>There must be a policy on who goes first;</p>\n<p><em>Accept other reasonable answers</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>:</p>\n<p>Split the job in two separate sections;<br/>one guy handles all the food, the other guy takes order, wraps, handles money;<br/>to minimize possible clashes on resources;</p>\n<p>Grouping similar tasks together:<br/>Slice several bread rolls / stockpile bread rolls;<br/>To be filled on demand;</p>\n<p><em><strong>Note</strong>: Do not award marks for answers related to serving.</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>:<br/>A model is a / an accurate representation (either physical or digital) of a real-world entity;<br/>A simulation is an algorithm/method of implementing a model;<br/>By changing the various parameters/variables of the model;<br/>In order to investigate its subsequent behaviour;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>:<br/>The number of utensils;<br/>Washing times;<br/>Time spent arranging the food on a plate;<br/>The amount / quantity of ingredients<br/>The number of customers/orders waiting<br/>The number of servings for the dish they are currently preparing;</p>\n<p><em>Accept other reasonable answers.</em><br/><em>Accept application answers – option to include/exclude ingredients.</em></p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong>.</em><br/><em>Mark as <strong>[3]</strong> and <strong>[3]</strong></em>.</p>\n<p>The objective of reducing turn-around time,<br/>May lead to hastily prepared dishes,<br/>Which may be lacking in quality.</p>\n<p>Trying to cook a batch of orders in 10 minutes,<br/>May require the pans to be used for multiple dishes,<br/>Impacting the unique taste of these dishes.</p>\n<p>More appliances might need to be switched on, in case of large orders demand;<br/>For example, an oven, which take time to heat up;<br/>Causing some dishes to be undercooked;</p>\n<p>The number of customers/orders;<br/>May be too high;<br/>To be dealt with in 10 minutes;</p>\n<p>Being in charge of preparing a full dish, gives job satisfaction;<br/>Lack of satisfaction may lead to loss of interest in the job;<br/>affecting the quality of the cooking;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.5",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Jackson City University</em> has a Music Department that provides music lessons to students in a number of high schools in the city.</p>\n<p>The <em>Jackson City University</em> Music Department teachers visit the different schools in the city to teach students a range of musical instruments.</p>\n<p>The following diagram shows an unnormalized table of student data.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> benefit of normalizing a database.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> ways that incorrect data could be prevented from being added into the <em>School_phone_no</em> field.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline what would be necessary to make the above unnormalized table conform to 1st Normal Form (1NF).</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the 3rd Normal Form (3NF) of the unnormalized relation shown above.</p>\n<div class=\"marks\">[8]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the difference between 2nd Normal Form (2NF) and 3rd Normal Form (3NF).</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>Normalization leads to a reduction in the chance of data redundancy occurring;<br/>Because each item of data only occurs on one location in the database;<br/>Therefore this can reduce the possibility of update anomalies occurring;<br/>More efficient use of memory;</p>\n<p>Normalization reduces the likelihood of update anomalies occurring;<br/>Because each item of data only occurs on one location in the database;<br/>Therefore if the data is edited there is no chance that the data may exist in its original form anywhere else in the database;</p>\n<p>Normalization leads to smaller tables with less information in each row;<br/>This leads to a reduction of input/output transfers;<br/>Which means that the likelihood of CPU activities being suspended are reduced/the CPU is able to work at full capacity;</p>\n<p><em><strong>Note</strong>: Do not award marks between clusters.</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Use a text field for the School_phone_no with a length of 9 characters (<em>Accept limit check</em>);<br/>Use an input mask such as 000000000 to ensure only numbers can be entered;<br/>Use a validation rule to ensure the first three entries can only be “065”<br/><em>Accept format check</em>;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Some values are not atomic in the <strong>Student_Choice</strong> and <strong>School_phone_no</strong> fields/attributes;<br/>Repeat rows for students with multiple choices / phone numbers with one choice per row;<br/>Each record must have a unique key;</p>\n<p>For <strong>Student_Choice</strong> have three columns, Stud_Choice1, Stud_Choice2 and Stud_Choice3, with null values (or default values set to “none”) as appropriate or two columns for <strong>School_phone_no</strong>;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[8 max]</strong></em>.</p>\n<p><em><strong>Alternative 1</strong></em><br/>For a three table solution:</p>\n<p><strong>Student table</strong><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">primary key</span>: student_ID // Do not accept other suggestions for the primary key</em>.<br/><em>Award <strong>[1]</strong> for attributes relating to student e.g. </em></p>\n<p><em>First_Name</em><br/><em>Family_Name</em><br/><em>Date_of_birth</em></p>\n<p><em><strong>Note</strong>: Do not penalize additional attributes such as Student_choice</em>.</p>\n<p><strong>School table</strong><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">primary key</span>. Either school_Name <strong>or</strong> user defined key such as SchoolID // Do not accept a composite key</em>.<br/><em>Award <strong>[1]</strong> for attributes relating to school such as: </em></p>\n<p><em>School(School_Name)</em><br/><em>School_Post_code,</em><br/><em>School_phone_no</em>.</p>\n<p><em><strong>Note</strong>: Do not penalize additional attributes such as Student_choice</em>.</p>\n<p><strong>Student choice Table/Instrument table</strong><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">primary key</span>. Either user-defined <strong>or</strong> a composite key</em>.<br/><em>Award <strong>[1]</strong> for attributes relating to choice such as Student_choice/Instrument choice</em></p>\n<p><em>Award <strong>[1]</strong> for each foreign key up to a maximum of <strong>[2 max]</strong></em>.</p>\n<p><strong>Example of three table solution</strong><br/><em>STUDENT (<span style=\"text-decoration:underline;\">Student ID</span>, First_Name, Family_Name, Date_of_Birth)</em><br/><em>SCHOOL (<span style=\"text-decoration:underline;\">School_Name</span>, School_PostCode, School_Phone_no)</em><br/><em>STUDENT CHOICE (<span style=\"text-decoration:underline;\">Choice ID</span>, Student_ID*, School_Name*, Choice)</em></p>\n<p><em><strong>Alternative 2</strong></em><br/>For a four table solution</p>\n<p><strong>Student table</strong><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">primary key</span>: student_ID // Do not accept other primary keys</em><br/><em>Award <strong>[1]</strong> for attributes relating to student e.g. </em></p>\n<p><em>First_Name</em><br/><em>Family_Name</em><br/><em>Date_of_birth</em></p>\n<p><em><strong>Note</strong>: Do not penalize additional attributes such as Student_choice.</em></p>\n<p><strong>School table</strong><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">primary key</span>. Either school_Name <strong>or</strong> user defined key such as SchoolID // Do not accept a composite key</em><br/><em>Award <strong>[1]</strong> for attributes relating to school such as: </em></p>\n<p><em>School(School_Name)</em><br/><em>School_Post_code</em><br/><em>School_phone_no</em></p>\n<p><em><strong>Note</strong>: Do not penalize for additional second School_Phone_no field</em>.</p>\n<p><strong>Student choice Table/Instrument table</strong><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">primary key</span>. Either Lesson_ID <strong>or</strong> Instrument_ID // Do not accept a composite key.</em><br/><em>Award <strong>[1]</strong> for attributes relating to choice such as Student_choice/Instrument choice</em>.</p>\n<p><strong>Details Table/Lessons Table</strong><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">primary key</span>. Any ID or composite.</em><br/><em>Award <strong>[1]</strong> for the correct foreign key in this table.</em></p>\n<p><em><strong>Note</strong>: This is the only table in which marks can be awarded for the use of a composite [primary] key</em>.</p>\n<p><strong>Example of four table solution</strong><br/><em>STUDENT (<span style=\"text-decoration:underline;\">Student_ID</span>, First_Name, Family_Name, Date_of_Birth)</em><br/><em>SCHOOL (<span style=\"text-decoration:underline;\">School_Name</span>, School_PostCode, School_Phone_no)</em><br/><em>STUDENTCHOICE(<span style=\"text-decoration:underline;\">Lesson_ID</span>,Instrument) </em><br/><em>DETAILS (<span style=\"text-decoration:underline;\">Lesson_ID</span>*, <span style=\"text-decoration:underline;\">Student_ID</span>*, <span style=\"text-decoration:underline;\">School_Name</span>*)</em></p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>2NF allows non-prime attributes to be functionally dependent on non-prime attributes which means there are transitive dependencies at 2NF;<br/>While 3NF allows non-prime attributes to be functionally dependent only on the primary / super key and is already in 2NF;<br/>Therefore it is not possible for update anomalies to occur when a database is in 3NF;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.3",
|
||
"topics": [
|
||
"option-c-web-science",
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"a-2-the-relational-database-model",
|
||
"a-1-basic-concepts"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Basking Coats</em> is a business that sells textile products such as shirts, coats and trousers. The company was formed in 1970 and has numerous shops in Europe and South-East Asia. To ensure their marketing is targeted at appropriate customers, <em>Basking Coats</em> has asked <em>Singalytics</em>, a data analytics company, to assist them in improving their marketing strategy.</p>\n</div><div class=\"specification\">\n<p>Extract, Transform, Loading (ETL) processes can be used to clean up data for use in a database warehouse. When ETL is carried out, certain precautions should be taken.</p>\n</div><div class=\"specification\">\n<p>Data in the <em>Singalytics</em> data warehouse is stored with a timestamp.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how deviation detection can be used to analyse this data.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why data warehouses tend to use unnormalized data sets.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> precautions to be taken before extraction is carried out on the database.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why data warehousing is time dependent.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why <em>Basking Coats</em> could use association analysis to improve the marketing of its products.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p><em>Basking Coats</em> has decided to use an object-oriented database rather than a relational database to store its data.</p>\n<p>Explain why <em>Basking Coats</em> would use an object-oriented database rather than a relational database to store its data.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Deviation detection is a statistical technique;<br/>Appropriate marketing of product;<br/>Which is used to detect outlying data that does not fit the assumed model;<br/>Therefore it can be used to predict the trends and patterns of demand for certain consumer goods in the future;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>To speed query execution, which can be especially important in data warehouses used by <em>Singalytics</em>;<br/>May effectively be used in data warehouses as they contain pre-joined tables that package data for common uses;<br/>If the data is all present in a single table, there will be no need for joins, hence the selects can be done very quickly;<br/>A single table with all the required data allows much more efficient index usage;<br/>If there is heavy read load and when the application is read intensive;<br/>If the columns are indexed properly, then results can be filtered and sorted by utilizing the same index;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>To retrieve all the required data from the source system with as little resources as possible;<br/>Designed in a way that it does not affect the source system;<br/>In terms or performance/ response time/ locking;<br/>Makes it accessible for processing on the data;<br/>Ensuring that historical data being extracted can be read by the current systems;<br/>Ensuring the different data formats being extracted can all be converted or scrubbed to become readable by the system and able to be formatted;<br/>Ensuring that the data is relevant to what the user wishes to extract and utilise;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>The content in the data warehouse is only valid for a time period;<br/>Because the data undergoes changes dynamically;<br/>A data warehouse's focus on change over time is time variant;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.</p>\n<p><em>Award <strong>[2 max]</strong> for the explanation and <strong>[2 max]</strong> for the example(s)</em>.</p>\n<p><strong>Associations</strong>:<br/>Correlate the presence;<br/>of a set of items with another range of values for another set of variables;<br/>Breaks up data sets by variables such as gender, location, age;<br/>It may be used to detect patterns independently from the geographic region,<br/>females buy more dark colour trousers than males;</p>\n<p><em><strong>Examples</strong></em>:<br/>when a female retail shopper buys a cotton shirt, she is likely to buy a stole.<br/>Associations of the type Full arm formal shirts => Dark colour trousers; Full arm formal shirts => cufflinks may produce enough confidence and support to be valid association rules of interest;<br/>If the application area has a natural classification of the item sets into hierarchies,<br/>discovering associations within the hierarchies is of no particular interest;<br/>Specifically its associations across hierarchies;</p>\n<p><em><strong>Note:</strong> For generic responses award <strong>[2 max]</strong></em>.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6 max]</strong></em>.</p>\n<p><em>Award <strong>[3 max]</strong> for the feature(s) and <strong>[3 max]</strong> for supporting </em><em>explanation/examples</em>.</p>\n<p><strong>Features</strong>:<br/>Enhanced modelling capabilities;<br/>Extensibility/support new data types;<br/>Object DBMS stores more complex data and relationships;<br/>Improved performance;<br/>Reusability;<br/>Eliminates need for user defined keys;<br/>Eliminates need for Joins;</p>\n<p><em><strong>Examples</strong></em>:<br/>Inheritance property, we can re-use the attributes (size, fabric) and functionalities;<br/>It reduces the cost of maintaining the same data multiple times;<br/>All this information is encapsulated and, there is no fear being misused by other objects. If we need any new feature we can easily add new class inherited from parent class and that adds new features;<br/>Reduces the overhead and maintenance costs;<br/>So it becomes more flexible if any changes and apparel business changes with fashion needs;<br/>Codes are re-used because of the inheritance feature;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "18M.2.HL.TZ0.4",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-4-further-database-models-and-database-analysis"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Neural networks are often used to model the complex behaviour of systems. These networks must first be trained in order to establish a reliable model. One such method of training makes use of supervized learning algorithms.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the basic steps involved in supervized learning algorithms.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The following block diagram illustrates a neural network used by a supervized learning algorithm to calculate a resulting value RES, for a given set of inputs.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<p style=\"text-align:left;\">The neural network in the block diagram contains 60 nodes in the input layer (block I), 36 nodes in the hidden layer (block H) and 6 nodes in the outermost layer (block O). The solid black arrows indicate that <em>all</em> nodes in one layer are feeding all nodes in the successive layer. In particular, the value RES is calculated by using all nodes in O.</p>\n<p>Calculate the number of weights that the above neural network uses in producing a value for RES. Show the details of your calculation.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong>:</em><br/>Uses a (training) set of <span style=\"text-decoration:underline;\">input data and known response</span> values;<br/>To <span style=\"text-decoration:underline;\">compare the model's output</span> with actual values from the past which will give an error in the estimate;<br/>The model is then <span style=\"text-decoration:underline;\">changed</span> in order to minimize this error;<br/>This <span style=\"text-decoration:underline;\">process is iterated</span> until a sufficiently accurate model is produced;<br/>Which can then be <span style=\"text-decoration:underline;\">used to make predictions</span>/classifications;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for evidence of multiplication between layers.</em><br/><em>Award <strong>[1]</strong> for fully correct expression / answer</em>.</p>\n<p>60 * 36 + 36 * 6 + 6 * 1 = 2382</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "18M.2.HL.TZ0.8",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The electronic control unit (ECU) of a vehicle is an on-board computer that is constantly monitoring the performance of several components of a vehicle. For example, the ECU:</p>\n<ul>\n<li>controls the functioning of the lights, the brakes, the airbag, and the fuel-level signal</li>\n<li>permits the scale being changed in some digital displays, such as switching the speedometer from miles/hour to km/hour.</li>\n</ul>\n<p>The software embedded in an ECU receives input data from a variety of sources when it runs auto-diagnostic tests.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With relation to the activities that the software of an ECU has to perform, identify<strong> two</strong> of the sources that provide input data to the ECU.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With relation to the activities that the software of an ECU has to perform, suggest <strong>one</strong> reason why the auto-diagnostic program in the ECU depends upon the make and model of the vehicle.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Vehicles are tested for their exhaust gas emissions using simulation software at specialist garages. During a period of 5 minutes, a vehicle with the engine switched on is monitored for emissions of carbon dioxide (CO<sub>2</sub>) and fine particulates. The software uses 3D visualization techniques to display these parameters on a screen for the whole duration of the test.</p>\n<p>Explain how emissions of CO<sub>2</sub> and fine particulates could be represented in 3D by the software.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for each of the <strong>two</strong> requested elements that provide input</em>.</p>\n<p><em>Accept any ATD sensor explicitly stated by name.</em><br/><em>Accept: speedometer, fuel gauge, brake pads, human pushing a button.</em><br/><em>Do not accept: temp regulation unit (or any unit that is integrated in ECU).</em></p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>May depend on the car maker and patents may be involved;<br/>For example, internal communications protocols across different systems may not be revealed;</p>\n<p>Different vehicles have different uses;<br/>It doesn’t make sense to have the same firmware for different requirements;</p>\n<p>Different models operate at different parameters,<br/>Requiring different algorithms;</p>\n<p>Different Countries may have different regulations;<br/>Therefore country-specific ECUs for the same model/type of car;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong> for one example with explanations</em>.</p>\n<p><em><strong>Example answers</strong></em>:<br/>The quantity and/or direction of diffusion of CO<sub>2</sub> and fine particulates can be mapped using colour plots;<br/>Over the whole duration of the test in a 3D space;<br/>Choosing a colour in an intuitive way;<br/>To show how the density evolves over time;</p>\n<p><em><strong>Examples</strong></em>:<br/>Plotting 3D points for CO<sub>2</sub> with vectors x,y,z ; // can be given BOD<br/>Where x = time;<br/>y = density of CO<sub>2</sub>;<br/>z = temperature;</p>\n<p><em><strong>Note</strong>: Do not accept generic answers that describe the process of 'rendering'</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.6",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-1-the-basic-model",
|
||
"b-3-visualization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A school teacher decides to write a program to store class records and marks. Part of this program involves using a sort algorithm. The algorithm shown is a selection sort and to test it, the teacher has set up an array <code>VALUES[]</code> with 5 elements of test data.</p>\n<pre>LIMIT = 4<br/><br/>loop COUNTER1 from 0 to LIMIT – 1<br/>MINIMUM = COUNTER1<br/><br/> loop COUNTER2 from COUNTER1 + 1 to LIMIT<br/> if VALUES[COUNTER2] < VALUES[MINIMUM] then<br/> MINIMUM = COUNTER2<br/> end if<br/> end loop<br/><br/> if MINIMUM ≠ COUNTER1 then<br/> TEMPORARY = VALUES[MINIMUM]<br/> VALUES[MINIMUM] = VALUES[COUNTER1]<br/> VALUES[COUNTER1] = TEMPORARY<br/> end if<br/><br/>end loop</pre>\n</div><div class=\"specification\">\n<p> <img src=\"\"/><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the table below to trace the algorithm using the data set:<br/>20, 6, 38, 50, 40</p>\n<p><img src=\"\"/></p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the algorithm in the flow chart, construct this algorithm in pseudocode so that it performs the same function.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the type of sort in the algorithm constructed in b(i).</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm fragment to output the data in the array <code>VALUES[]</code></p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><img src=\"\"/></p>\n<p><em>Award <strong>[5 max]</strong></em>.<br/>Both <code>COUNTER1</code> and <code>COUNTER2</code> correct;<br/><code>MINIMUM</code> column correct;<br/>Final <code>VALUES[] </code>0, 1, 2 correct;<br/>Final <code>VALUES[]</code> 3, 4 correct;<br/><code>TEMPORARY</code> column correct;</p>\n<p><em>Note to examiners</em>:<br/><em>Allow follow through (FT)</em>.<br/><em>In case of different representation of values in columns COUNTER1 and COUNTER2, then FT, award marks for the correct values of the variables MINIMUM and TEMPORARY</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Use of correct nested loops;<br/>Correct use of flag;<br/>Inner loop checking adjacent cells;<br/>Values being swapped if necessary;</p>\n<p><em>Example algorithm 1</em>:</p>\n<pre>LIMIT = 4<br/>FLAG = TRUE<br/>loop while FLAG = TRUE<br/> FLAG = FALSE<br/> loop COUNTER from 0 to LIMIT - 1<br/> if VALUES[COUNTER] > VALUES[COUNTER + 1] then<br/> TEMPORARY = VALUES[COUNTER]<br/> VALUES[COUNTER] = VALUES[COUNTER + 1]<br/> VALUES[COUNTER + 1] = TEMPORARY<br/> FLAG = TRUE<br/> end if<br/> end loop<br/>end loop</pre>\n<p><em><strong>A recursive solution is allowed at HL. SL candidates who submit an above level recursive solution should also receive credit</strong></em>.</p>\n<p><em>Version 1 – basic recursive solution</em></p>\n<p><em>Award <strong>[3 max]</strong></em>.<br/>BUBBLESORT defined as a procedure with correct pass through parameters and end/return statement;<br/>Correct loop with values swapped if necessary inside procedure;<br/>Recursive call of BUBBLESORT with parameters passed;<br/>Correct condition for recursive call;</p>\n<p><em>Example algorithm 2</em></p>\n<pre>LIMIT = 4<br/>BUBBLESORT(VALUES, LIMIT)<br/> loop COUNTER from 0 to LIMIT - 1<br/> if VALUES[COUNTER] > VALUES[COUNTER + 1] then<br/> TEMPORARY = VALUES[COUNTER]<br/> VALUES[COUNTER] = VALUES[COUNTER + 1]<br/> VALUES[COUNTER + 1] = TEMPORARY<br/> end if<br/> end loop<br/> if LIMIT – 1 > 1 then<br/> call BUBBLESORT(VALUES, LIMIT - 1)<br/> end if<br/>end BUBBLESORT</pre>\n<p><em>Version 2 – more efficient recursive solution</em></p>\n<p><em>Award <strong>[3 max]</strong>.<br/></em>BUBBLESORT defined as a procedure with correct pass through<br/>parameters and end/return statement;<br/>Correct loop with values swapped if necessary inside procedure;<br/>Recursive call of BUBBLESORT with parameters passed;<br/>Correct condition for recursive call;<br/>Correct use of flag;<em><br/></em></p>\n<p><em>Example algorithm 2</em></p>\n<pre>LIMIT = 4<br/>BUBBLESORT(VALUES, LIMIT)<br/> FLAG = FALSE<br/> loop COUNTER from 0 to LIMIT - 1<br/> if VALUES[COUNTER] > VALUES[COUNTER + 1] then<br/> TEMPORARY = VALUES[COUNTER]<br/> VALUES[COUNTER] = VALUES[COUNTER + 1]<br/> VALUES[COUNTER + 1] = TEMPORARY<br/> FLAG = TRUE<br/> end if<br/> end loop<br/> if LIMIT – 1 > 1 and FLAG = TRUE then<br/> call BUBBLESORT(VALUES, LIMIT - 1)<br/> end if<br/>end BUBBLESORT</pre>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Bubblesort;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Award <strong>[2 max]</strong>.<br/>Use of (any type of) loop;<br/>Correct output statement;</p>\n<p><em>Example algorithm</em>:</p>\n<pre>loop COUNTER from 0 to LIMIT<br/> output VALUES[COUNTER]<br/>end loop</pre>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Those candidates who are proficient in programming easily got full marks. The others did not complete the exercise or completed it incorrectly.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19M.1.HL.TZ0.15",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An image processing system analyses colour images of architectural landscapes. The system compares any new images with existing ones stored in a knowledge base. The purpose of the system is to extend the knowledge base with images of the same scenes taken either from different perspectives or at different times of the year or with different weather conditions.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how cluster analysis can be used to achieve the aims of the system that is described above.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Discuss the appropriateness of using genetic algorithms to compare the processed images with those stored in the knowledge base.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong>.</em><br/>Cluster analysis will attempt to <span style=\"text-decoration:underline;\">group</span> together images;<br/>Into groups that <span style=\"text-decoration:underline;\">have certain similarities</span>;<br/>This will be achieved by <span style=\"text-decoration:underline;\">looking at characteristics</span>;<br/><span style=\"text-decoration:underline;\">Such as</span> the presence of horizontal/vertical lines/windows/spires etc.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong>:</em><br/><em>Award <strong>[2]</strong> + <strong>[2]</strong> + <strong>[2]</strong></em>.</p>\n<p><em>Award <strong>[2]</strong> for a description of GA, such as:</em><br/>GA uses a <span style=\"text-decoration:underline;\">fitness function</span> (based on stored data);<br/>To validate/discard the “adequacy” of some detected features;</p>\n<p><em>Award <strong>[2]</strong> for one reason for appropriateness with amplification.</em><br/>The features in images have been extracted in previous processing;<br/>And can be represented in a suitable way to be used with genetic algorithms;</p>\n<p><em>Award <strong>[2]</strong> for one reason against appropriateness with amplification.</em><br/>One has to decide which features shall drive the recognition process;<br/>Choosing the wrong feature may lead to incorrect results;</p>\n<p>If the GA merges similar features to build broad classes;<br/>Then the recognition may not be precise enough;</p>\n<p>If the GA focuses on several small details taken in isolation;<br/>A limited number of features may be recognised;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "18M.2.HL.TZ0.9",
|
||
"topics": [
|
||
"option-a-databases",
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"a-4-further-database-models-and-database-analysis",
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A two-dimensional array <math style=\"font-family: 'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>CUSTOMERS</mi><mo> </mo><mo>[</mo><mo> </mo><mo>]</mo></math> is used to store customer details for a mail order company such that each row of the array represents a customer record and each column represents a specific field. The fields currently in use are: <code>LASTNAME, FIRSTNAME, ADDRESS1, ADDRESS2, ADDRESS3, CITY, POSTCODE</code>.</p>\n<p>The array currently holds 512 records.</p>\n</div><div class=\"specification\">\n<p>The company wishes to print a number of mailing labels, such as the one shown below, that will go to all customers called <math style=\"font-family:'Courier New'\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>Jones</mi></math> who live in <math style=\"font-family:'Courier New'\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>Cardiff</mi></math>.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>A singly linked list has been created including the following surnames; <code>Bale, Cousens, Davies, Pugh, Williams</code>.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the pseudocode that will find how many customers live in the city of <code>Cardiff</code> and display the results.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm that will enable the company to print the mailing labels for all customers called <code>Jones</code> who live in <code>Cardiff</code>.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the steps to insert <code>“Jones”</code> into this singly linked list. You may draw a labelled diagram in your answer.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> example of where a circular linked list would be used in preference to a linear linked list.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>.<br/>Initialization of TOTAL before loop and output of result after loop;<br/>Use of any loop with correct limits;<br/>Correct row and column subscripts of two-dimensional array;<br/>Correct comparison in if statement;<br/>Totalling within if statement, if statement inside loop;</p>\n<p><em>Note to examiners: Do not accept flowcharts</em>.</p>\n<p><em>Example algorithm 1</em>:</p>\n<pre>SEARCH = \"Cardiff\"<br/>TOTAL = 0<br/><br/>loop COUNTER from 0 to 511<br/> if SEARCH = CUSTOMERS[COUNTER][5] then<br/> TOTAL = TOTAL + 1<br/> end if<br/>end loop<br/><br/>output \"The number of customers is \", TOTAL</pre>\n<p><em>Example algorithm 2</em></p>\n<pre>TOTAL = 0<br/>loop COUNTER from 0 to CUSTOMERS.length()-1<br/> if CUSTOMERS[COUNTER][5].equals( \"Cardiff\")<br/> //accept CUSTOMERS[COUNTER][5]== \"Cardiff\"<br/> then TOTAL = TOTAL + 1<br/> end if<br/>end loop<br/>output TOTAL</pre>\n<p><em>Note to examiners</em>:<br/><em>The array structure is not given in the question</em>.</p>\n<p><em>If array subscripts begin with 1, then award 1 mark for </em><br/><code>loop COUNTER from 1 to 512</code> <br/><em>and 1 mark for</em> <br/><code>CUSTOMERS[COUNTER][6]</code></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>.<br/>Use of any loop with correct limits;<br/>Correct row and column subscripts of two-dimensional array;<br/>Correct comparison in if statement<br/>Output of all row elements(fields)<br/>Output correctly formatted</p>\n<p><em>Note to examiners: Accept flowcharts</em>.</p>\n<p><em>Example algorithm 1</em>:</p>\n<pre>SEARCH1 = \"Jones\"<br/>SEARCH2 = \"Cardiff\"<br/>loop COUNTER from 0 to 511<br/> if CUSTOMERS[COUNTER][0] = SEARCH1 then<br/> if CUSTOMERS[COUNTER][5] = SEARCH2 then<br/> output CUSTOMERS[COUNTER][1] \" \" CUSTOMERS[COUNTER][0]<br/> output CUSTOMERS[COUNTER][2]<br/> output CUSTOMERS[COUNTER][3]<br/> output CUSTOMERS[COUNTER][4]<br/> output CUSTOMERS[COUNTER][5]<br/> output CUSTOMERS[COUNTER][6]<br/> end if<br/> end if<br/>end loop</pre>\n<p><em>Example algorithm 2</em>:</p>\n<pre>R=0<br/>loop while R <= 511<br/> if CUSTOMERS[R][0]==\"Jones\" and CUSTOMERS[R][5]== \"Cardiff\"<br/> then<br/> output CUSTOMERS[R][1], CUSTOMERS[R][0]<br/> loop K from 2 to 6<br/> output CUSTOMERS[R][K]<br/> end loop<br/> end if<br/> R=R+1<br/>end loop</pre>\n<p><em>Note to examiners</em>:<br/><em>Since “Jones” can be either a first or last name, accept</em><br/> <code>CUSTOMERS[COUNT][1] == SEARCH1</code><br/><em>and the first output line</em><br/> <code>output CUSTOMERS[COUNT][0], CUSTOMERS[COUNT][1]</code></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>.<br/><em>Accept correct answers given as diagrams or written in text applying the following marking points</em>:</p>\n<p><em>Award <strong>[5 max]</strong> if candidate explained the steps to insert </em><code>“Jones”</code><em> into sorted list </em><em>at correct place</em>.<br/><em>Award <strong>[1]</strong> for each of the following steps, up to [5]</em></p>\n<p>Create a new node with data field <code>Jones</code> and pointer field;<br/>Start searching from the beginning of the list;<br/>Find the location/position where the new node is to be inserted (<code>Jones</code> to be inserted after <code>Davies</code>);<br/>Set the pointer in the new node (containing Jones) to the pointer in the node containing Davies (to point to the node containing <code>Pugh</code>); <br/>Set the pointer in the node containing <code>Davies</code> to point to the new node (<code>Jones</code>);</p>\n<p><em>Award <strong>[3 max]</strong> if candidate explained only the steps to insert </em><code>“Jones”</code><em> at the end of the list</em>.<br/><em>Award <strong>[1]</strong> for each of the following steps</em></p>\n<p>Create a new node with data field <code>Jones</code> and pointer field NIL;<br/>Start searching from the beginning of the list to find the last node (<code>Williams</code>);<br/>Set the pointer in the last node (containing <code>Williams</code>) to point to the new node (<code>Jones</code>);</p>\n<p><em>Award <strong>[3 max]</strong> if candidate explained only the steps to insert “Jones” at the beginning of the list</em>.<br/><em>Award <strong>[1]</strong> for each of the following steps, up to <strong>[3]</strong></em></p>\n<p>Create a new node with data field <code>Jones</code> and pointer field;<br/>Set the pointer in the new node (containing <code>Jones</code>) to the external pointer (which points to the beginning of the list/to the first node in the list (<code>Bale</code>));<br/>Set the external pointer to point to the new node (<code>Jones</code>);</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award marks for the use of circular lists (rather than linked lists) in an application (accept examples);</em><br/><em>in which any node can be a starting point / which traverses the whole list by </em><em>starting from any point;</em><br/><em>to repeatedly go around the list;</em></p>\n<p>Used to allow multiple applications to run in a PC;<br/>The operating system cycles through each one in time giving each a slice of time to execute;</p>\n<p>Used for the implementation of a (circular) queue;<br/>The end of the queue points to the beginning, eliminating the need to maintain both front and rear pointers;</p>\n<p>Used in multiplayer gaming environment;<br/>The OS cycles through one player at a time using time slicing;</p>\n<p>A media playlist that repeats (endlessly);<br/>The last song (node) points to the first song;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Those candidates who are proficient in programming easily got full marks. The others did not complete the exercise or completed it incorrectly.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Part (c) seems to have split the cohort; strong candidates often responded with full and correct answers, however there were many responses that were completely wrong.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not many candidates were able to outline a good example of the use of a circular list in preference to a linear linked list in Part(d).</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19M.1.HL.TZ0.17",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Neural networks.</p>\n<p>Genetic algorithms and neural networks are being used in a variety of scenarios. For example, a genetic algorithm may be used to organize timetables for trains whereas a neural network may be used to predict fluctuations between the exchange rates of different currencies.</p>\n</div><div class=\"specification\">\n<p><strong>Figure 1</strong> shows an example of a neural network. It includes inputs, a hidden layer and outputs.</p>\n<p style=\"text-align: center;\"><strong>Figure 1: A neural network</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"specification\">\n<p>Many toy companies are considering the use of machine learning using either supervised learning or unsupervised learning. <em>MAGS</em>, a large IT software company, has recently developed <em>A Doll Called Alicia</em> that allows children to interact with it.</p>\n</div><div class=\"specification\">\n<p><em>A Doll Called Alicia</em> uses machine learning to ensure the child can have the best possible communication with the doll.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the difference between a genetic algorithm and a neural network.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> ways in which the neural network could be modified that may improve its performance.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the difference between supervised learning and unsupervised learning.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the machine learning capabilities of <em>A Doll Called Alicia</em> may lead to instances when the child and the doll cannot communicate effectively.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Companies such as <em>MAGS</em> are considering products that use unsupervised learning rather than supervised learning.</p>\n<p>Explain the benefits of unsupervised learning in developing products such as <em>A Doll Called Alicia</em>.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>A genetic algorithm works in the same way as an evolutionary process whereby it starts with a large population;<br/>And uses an iterative process where the fitter solutions are selected and input into the next cycle until the exit criteria are satisfied;</p>\n<p>Whereas neural networks attempt to mimic the process of the brain;<br/>And can be used/trained to recognize patterns;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Increase the number of inputs;<br/>Increase the number of hidden layers;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>Supervised learning is when the outcome related to a given input is already known;<br/>And so, the “learner” can recognize objects and name them based on the labels already given;</p>\n<p>Whereas unsupervised learning is when no examples of outcome are given to help with the learning;<br/>And so, the “learner” must deduce its own solutions e.g. classifying similar objects by colour or shape;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>The language of the child may not have been programmed into the doll;<br/>The child may not speak clearly;<br/>The child’s language may not be sufficiently developed to apply syntax correctly;<br/>The child may refer to something not in Alicia’s “recorded” content, or that Alicia has not previously “learnt”;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/>Unsupervised learning can be used for bridging the causal gap between input and output observations;<br/>Instead of finding the causal pathway from inputs to outputs;<br/>By building the model upwards from both sets of observations;<br/>In the hope that the gap is easier to bridge in the higher levels of abstraction;<br/>Possible to learn larger and more complex models;<br/>e.g. the connection between two sets of observations;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to provide a reasonable description of differences between a genetic algorithm and neural network.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The majority of the candidates answer this question correctly.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The majority of the candidates were able to provide a reasonable description of supervised and unsupervised learning. However, a few of them were unable to develop the responses beyond the generic points.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The majority of the candidates were unable to provide a reasonable response for this question. The responses were mostly limited to a few generic points.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates reasonably answered this question. However, the majority of the responses lacked variety in points specific to the question. The responses also lacked further explanation and were mostly limited to the identification of points and some description.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19M.2.HL.TZ0.8",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><strong>Figure 2</strong> below shows a web graph that is a simplified representation of the World Wide Web.</p>\n<p style=\"text-align: center;\"><strong>Figure 2: a simplified representation of the World Wide Web</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"specification\">\n<p>Web crawlers move through the web, indexing pages to provide information for search engines. When a web crawler arrives at a page it uses several criteria to decide whether to index that page or not.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the nodes that represent web pages in the strongly connected core (SCC).</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the nodes that represent web pages connected by a tube.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why web page E would be given a higher ranking than web page C using the PageRank algorithm.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> criteria that may be used by a web crawler to decide whether to index a web page or not.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The following information shows the number of active users (in millions) on different social media sites.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<p>Discuss whether the application of power laws is appropriate to predict the future number of active users on these social media sites.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>D, E, F, G;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>H & K;<br/><em>Accept H & L & K</em>;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Both pages have the same number of in-links (i.e. 2);<br/>However, the links to page E come from pages that have a greater number of in-links than the pages that link to C / E is connected with SCC while C has two in-nodes / in-links;<br/>The PageRank algorithm counts links to pages recursively;<br/>A PageRank algorithm will give a greater weighting to the pages that link to E;<br/>Therefore, the algorithm will place E higher up the ranking than C;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Whether there are any meta-tags present that restrict / guide indexing (e.g. a “robot exclusion protocol”);<br/>Whether there is a robots.txt file linked to the page that gives instructions to the web crawler;<br/>Whether the page has broken / dead links;<br/>Whether the page content / meta information matches any specialism/type sought by the web crawler (e.g. some crawlers specifically target academic content);<br/>There is no header with meta-tags;<br/>Whether the page has ever been indexed before;<br/>Whether the page has changed since it was last indexed;<br/>How long ago / how frequently the page has been indexed (web-crawlers will tend not to index pages too frequently as this increases load on the web server);</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>.</p>\n<p><strong>Reasons why power laws may be appropriate</strong><br/>The number of users shown for each site appears to follow the general pattern of a power law distribution / is consistent with the general principles of power laws (the “rich get richer”);<br/>It's likely/reasonable to assume that sites with large numbers of users will tend to attract more new users than sites with fewer users;<br/>This may be particularly true of social media sites where a high number of existing users may equate to a more diverse/engaging/attractive experience for new users;</p>\n<p><strong>Reasons why power laws may not be appropriate</strong><br/>However, correlation does not equal causation. / Just because the sites appear to exhibit a power law distribution, it doesn't mean that their growth is governed by a power law;<br/>Other factors may be more significant (e.g. the demographic / region a social media site attracts, changing fashion, the policies of the sites themselves);<br/>Sites that were very popular in the past but diminished/died-out may suggest that power laws are not the only / main factor influencing future development (e.g. MySpace);</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates answered this correctly.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates answered this correctly.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates answered this correctly but some missed making clear reference to the actual links in the question.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates answered this correctly though a few missed covering all the specifics of the question.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates did not structure the answers so they could not meet the requirement of the specifics of this question.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19M.2.HL.TZ0.12",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-5-analysing-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A mobile phone has been developed with its own dedicated operating system and is to be used as part of a smart home system in Singapore. The smart home system includes a centralized air conditioning system, a burglar alarm and a surveillance system.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> functions of an operating system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> benefit of using a dedicated operating system on the mobile phone instead of a generic operating system.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how sensors and microprocessors are used to ensure that the air conditioning system is able to maintain a constant temperature in the smart house.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The developers of the smart home system are considering developing a smart home system that uses a distributed control system to manage the temperature.</p>\n<p>Contrast the use of a distributed air conditioning system with a centralized air conditioning system for maintaining a constant temperature in the smart home.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Managing memory;<br/>Managing peripherals;<br/>Processor management;<br/>Scheduling;</p>\n<p><em>Note to examiners: allow any valid feature of an operating system</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.</p>\n<p><em>Example 1</em><br/>A dedicated operating system for a mobile phone will take up less storage space than a full-sized operating system;<br/>This will allow the device to function more quickly;<br/>Because it doesn’t contain features that aren’t needed;</p>\n<p><em>Example 2</em><br/>A dedicated operating system for a mobile phone can be customized;<br/>Benefits the end users;<br/>As they deal with a familiar interface;</p>\n<p><em>Example 3</em><br/>The dedicated OS is designed specifically for the mobile phone (hardware equipment);<br/>This avoids compatibility issues;<br/>While a generic operating system is designed for multiple types of hardware (which can lead to compatibility / various issues);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/>A desired temperature is input/pre-set by the user;<br/>Sensors detect temperature;<br/>And regularly/continuously send (temperature) readings to the microprocessor;<br/>The microprocessor compares the actual readings with the pre-set (by the user) / input temperature;<br/>If the temperature is too hot/too cold the microprocessor sends signal to actuator;<br/>To adjust temperature (no need for complex details regarding actions of a heating/cooling system);</p>\n<p><em>Note to examiners: Award <strong>[1]</strong> for evidence of the use of analogue-to-digital converter (sensors) and/or digital-to-analogue convertor(actuators)</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/><em>Award [1] for each contrast/comparison, up to [3]</em>.</p>\n<p>Centralized system allows control at a central point, which is then transmitted to the various rooms whilst distributed system allows individual control of settings at each unit / room so is more flexible // Centralized system will have same or constant temperature throughout the home whilst distributed system allows individual control of setting at each room;</p>\n<p>Easier to control settings centrally whilst distributed system is more complicated to control remotely (due to limited / no connectivity of the control system);</p>\n<p>Centralized system is more difficult to install due to the connectivity required between the various components whilst distributed system is easier to install due to fewer connection issues;</p>\n<p>If a computer system / or any connection fails in the centralized system, the whole system is not able to function correctly whilst the distributed system as whole would still function correctly;</p>\n<p>Centralized system is cheaper / has lower operational cost whilst distributed system is expensive as it requires additional hardware / software;</p>\n<p>Centralized systems are difficult to expand whilst distributed systems are easily expandable because self-sufficient systems can be added or removed at any point in time without affecting the overall system;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>All parts were mostly well answered although many candidates lost marks for repetition and using vague common-sense terminology, rather than technical and complete terminology.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19M.1.HL.TZ0.16",
|
||
"topics": [
|
||
"topic-6-resource-management",
|
||
"topic-7-control"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management",
|
||
"topic-7-1-control"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Machine translators are regularly used to translate text from one language to another. In spite of the advances that have been made in this field, the output may still need to be proofread by a human.</p>\n<p>Describe <strong>two</strong> problems that these translators may encounter when translating from one language to another.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.<br/>Not all text can be translated literally;<br/>Humans can bend the rules to make produce sense in the target language;</p>\n<p>Machine translators can only use the data that has been programmed into them;<br/>Cannot translate anything outside their knowledge base, e.g. obscure/new words/phrases;</p>\n<p>Knowing which tone/register to use depends upon experience;<br/>That machine learning algorithms do not yet have;</p>\n<p>There are several 1000 different languages;<br/>Linking all of them all is too big a task;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.2.HL.TZ0.10",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> roles that a computer can perform in a network.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Client;<br/>Server/email server/DNS server/file server;<br/>Router;<br/>Firewall;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were generally able to identify roles that a computer can perform in a network. However, some candidates incorrectly described actions that a computer performs in a network rather than stating actual roles.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.1",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Home banking allows individuals to perform operations over the Internet on their own bank accounts.</p>\n</div><div class=\"specification\">\n<p>Access to a bank’s home banking services requires, as a first step, identification and authentication of the user. Individuals log on the bank web site, and enter their own personal space by providing their full account number and a personal code that the bank gave them. The processing of this information takes place on the server side.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the relationship between the Internet and the world wide web (WWW).</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the choice of browser should not affect a customer’s ability to access their bank account details.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>two</strong> features that make HTTPS more suitable than HTTP in the context of home banking.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why server-side processing is used in this case.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The 20 most recent account transactions can be displayed on screen in a webpage that uses XML. A print-out of <strong>all</strong> transactions of the past three months may be obtained by clicking an onscreen button on the webpage. The print-out is landscape oriented and shows many more columns than are displayed on the screen.</p>\n<p>Describe how this processing takes place with reference to the use of XML and XSLT.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>.</em></p>\n<p><em>Award<strong> [1 max]</strong> for Internet and <strong>[1 max]</strong> for WWW</em>.</p>\n<p>Internet is a network of (networks of) computers that can communicate one with each other;<br/>To exchange/access information through the WWW;</p>\n<p>The WWW is a way to access/share/exchange information using software applications;<br/>Using the Internet as a physical medium;</p>\n<p>Internet allows the transmission of data;<br/>That constitute the information that applications on the WWW may want to share/access/exchange;</p>\n<p>The WWW provides, through hyperlinks, a level of connectivity of resources (logical connectivity);<br/>Which can be physically sparse, but connected in a network in the Internet;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>:</p>\n<p><em>Award <strong>[1]</strong> for defining the term “standards” and award <strong>[1]</strong> for a development up to <strong>[2 max]</strong></em>;</p>\n<p><em>Award <strong>[1]</strong> for defining the term “protocol(s)” and award <strong>[1]</strong> for a development up to <strong>[2 max]</strong></em>;</p>\n<p>Standards are applied by the browser;<br/>For interpreting the HTML (XML);<br/>So that the all information will appear, and also (more or less) as expected;</p>\n<p>Protocols are used;<br/>To build up the communication at different levels of the architecture;<br/>All browsers will rely upon the same internet protocols (TCP/IP);<br/>That is essential for interoperability in transmission/communication;<br/>So that the IP address is retrieved (via the DNS server);</p>\n<p><em>Award <strong>[2 max]</strong> for a generic response</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>:<br/>HTTPS <span style=\"text-decoration:underline;\">authenticates</span> the web site;<br/>HTTPS <span style=\"text-decoration:underline;\">encrypts</span> the data that need to be transferred;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>:<br/>The bank needs to store all passwords in its server, including the credentials given to the users;<br/>So that the comparison with the individual’s entry happens in the bank with the local database;<br/>To the purpose of guaranteeing security;<br/>And to possibly perform other operations (tracking log-ins or transactions);</p>\n<p>The bank cannot send out password to be processed on the client’s side;<br/>This will not be a guarantee for security for the bank/it may introduce vulnerabilities/sensitive data cannot be sent out in the public domain;<br/>Hence the comparison with the individual’s entry must happen in the bank with the local database;</p>\n<p><em><strong>Note:</strong> Do not award marks between clusters</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>:<br/>XML is used to create/organize the data on the internal database;<br/>By clicking the virtual button a script is run that transforms the information on the database into the print-out form;<br/>Stylesheet in <span style=\"text-decoration:underline;\">XSLT</span> transforms XML into an output form;<br/>The script contains instructions on how to access the database (which fields are relevant) and how to present the information for the final form for the printer;</p>\n<p>By clicking the virtual button a script is run;<br/>Which uses XML to retrieve/select the required data from the internal database/server;<br/>Which is displayed using XSLT into an appropriate output form (on the screen);<br/>The script also contains instructions for the correct printout of data;</p>\n<p><em><strong>Note:</strong> Do not award marks between clusters.</em></p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.7",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Full details of the customers are stored as objects of the Customer class. This class is partially shown below:</p>\n<pre><strong>public class</strong> Customer<br/>{<br/><strong> private</strong> String memberId;<br/><strong> private</strong> String email; //email address (assume only 1 per customer)<br/><strong><br/> public</strong> Customer(String a, String b)<br/> {<br/> memberId = a;<br/> email = b;<br/> }<br/><strong> <br/> public</strong> String getMemberId()<br/> {<br/><strong> return</strong> memberId;<br/> }<br/><strong><br/> public</strong> String getEmail()<br/> {<br/><strong> return</strong> email;<br/> }<br/>}</pre>\n<p>The objects can be accessed through the linked list <code>allCustomers</code> which is declared in the main (driver) class as follows:</p>\n<p><code>LinkedList<Customer> allCustomers = new LinkedList<Customer>()</code></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why a linked list structure has been chosen for <code>allCustomers</code>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method<code> goldMails()</code> that will return an <code>ArrayList</code> containing the email addresses of all current “Gold” members. You should make use of any previously defined methods.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><span style=\"text-decoration:underline;\"><em>Example 1</em><em>:</em></span><br/>The link list will enable space to be allocated dynamically/will only take up the space required;<br/>Because the number of customers is unknown / customers may join or leave the loyalty scheme during the year;<br/><span style=\"text-decoration:underline;\"><em>Example 2</em><em>:</em></span><br/>Customers / objects / nodes can be easily added or deleted;<br/>So customers may join or leave the loyalty scheme during the year;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<pre><strong>public</strong> ArrayList goldMails()<br/>{<br/> ArrayList al = new ArrayList(); // Allow use of <String> identifier<br/> <strong>int</strong> s = allCustomers.size();<br/> <strong>int</strong> x = 0;<br/> <strong>while</strong>(!(allPoints[x] == null)) // Allow(allPoints[x]!=null)<br/> {<br/> <strong>if</strong> (allPoints[x].isGold())<br/> {<br/> String a = allPoints[x].getMemberId();<br/> <strong>for</strong> (<strong>int</strong> y = 0; y < s; y++)<br/> {<br/> String b = allCustomers.get(y).getMemberId();<br/> <strong>if</strong> (a.<strong>equals</strong>(b)) // allow =<br/> al.add(allCustomers.get(y).getEmail());<br/> }<br/> }<br/> x = x + 1<br/> }<br/> <strong>return</strong> al;<br/>}</pre>\n<p><em>Award marks as follows:</em><br/>Declaring a new <code>ArrayList</code> (with or without the String identifier);<br/>Looping through the <code>allPoints</code> array;<br/>Testing for “Gold”;<br/>Loping through the <code>allCustomers</code> linked list (using the size or an iterator);<br/>Correct check for identical ids;<br/>Adding the email to the <code>ArrayList</code>;<br/>Returning the arraylist;</p>\n<p><em><strong>Note</strong><strong>:</strong></em></p>\n<ul>\n<li><em>Do not allow any methods that are not part of the LinkedList or ArrayList library classes – e.g. the length function for the linked list is invalid.</em></li>\n<li><em>Do not penalize more than once for omitting the “gets”.</em></li>\n<li><em>Allow the for loop: <code>for</code> (<code>Customer currCust : allCustomers</code>).</em></li>\n<li><em>Allow for loop instead of a while loop.</em></li>\n</ul>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "18M.2.HL.TZ0.18",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Describe <strong>one</strong> method of implementation for a new computer system.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em></p>\n<p>Parallel;<br/>old system and new system are operated at the same time until the current system is proved to be successful;</p>\n<p>Pilot;<br/>the new (whole) system is operated in one branch/part of the organization before it is rolled out to the whole organization;</p>\n<p>Direct;<br/>the new system replaces the old system in an immediate switchover;</p>\n<p>Phased;<br/>the new system in phases / stages, gradually replaces parts of the old system until the current system is completely replaced by the new system;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>The vast majority of candidates were able to name a method of implementation for a new computer system and then went on to describe it, to achieve both marks. Some candidates, however, successfully named a method, but the description given could have applied to any method of implementation, so it was not specific enough for the second mark.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.2",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Draw the logic circuit represented by the following truth table.</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em></p>\n<p><em><strong>Note</strong>: There could be many answers that are correct</em>.</p>\n<p><em><strong>Example 1</strong></em></p>\n<p style=\"text-align:center;\"><em><strong><img src=\"\"/></strong></em></p>\n<p style=\"text-align:left;\">Correct inputs and XOR gate;<br/>NOT gate, correct final output and link from XOR gate;<em> <strong><br/></strong></em></p>\n<p style=\"text-align:left;\"><em><strong>Example 2</strong></em></p>\n<p style=\"text-align:left;\"><em><strong><img src=\"\"/></strong></em></p>\n<p style=\"text-align:left;\"><em><strong><img src=\"\"/></strong></em></p>\n<p style=\"text-align:left;\"><em><strong>Award [2] max.<br/></strong></em></p>\n<p style=\"text-align:left;\"><em>2 marks, 1 mark for each correct input in OR gate</em><br/><em><strong>Note</strong>: in this example the two inputs in OR gate are (NOT A AND NOT B )and (A AND B).</em><br/><em><strong>1</strong> mark for drawing any 3 gates (complete with inputs and outputs)</em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>A wide range of correct logic circuits were seen in answer to this question, including logic gates from the syllabus – the XOR and NOT gates, as well as above level responses, including the XNOR gate. Some candidates incorrectly used regular OR or NOR gates in their solutions.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.3",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Many city authorities have realised the opportunities that social media and collective intelligence can provide.</p>\n<p>Narayan City is considering using data gathered from citizens using traffic apps on their GPS-enabled mobile devices to help plan future changes to the layout of the road network in and around the city.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage for Narayan City of using collective intelligence to solve complex problems such as changing the layout of roads.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Many social networking sites allow users to classify their posts and responses, for example by adding one or more “hashtags”.</p>\n<p>To what extent does the increasing number of social networking sites and the creation of folksonomies contribute to web users modifying their online behaviour?</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Enables Narayan City to gather data from many more sources than would be possible through the use of traditional data-gathering methods;<br/>This will enable far more information to be gathered far more quickly than using traditional methods;</p>\n<p>Data is generated proactively by citizens' actions;<br/>Therefore, data more likely to reflect what citizens actually do rather than what they might claim they do;<br/>Improves the accuracy of the data;</p>\n<p>Existing strategies used by citizens can be incorporated into future planning;<br/>for example, using side-roads to optimize journey times/timing of journeys to avoid major congestion;<br/>Thus, helping to ensure that future plans are optimized / tailored to citizens’ needs;</p>\n<p>Data gathering and analysis can be automated;<br/>Therefore, it is very cost effective;<br/>Thus, it is able to be scaled / increased without major impacts on budget;</p>\n<p>Data monitoring and collection is real-time;<br/>Therefore, the effect of implementing plans will be reflected by visible changes in use patterns / journey times / routes taken;<br/>Thus, the city council can get reliable feedback/evaluation of how effective their plans are;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.</p>\n<p><strong>Possible changes in user behaviour</strong></p>\n<ul>\n<li>users can create their own hashtags, allowing the opportunity for issues/topics to be classified that subsequently rise in prominence/trend among a wider range of social media users/increases the chance of users' concerns being noticed and addressed;</li>\n<li>contrasting/conflicting hashtags can spark debate and discussion among users, allowing users to be exposed to perspectives and arguments that they would otherwise miss / be unaware of;</li>\n<li>Users interact with content related to their interests / views by following hashtags / social media accounts they know align with their interests / views</li>\n<li>Hashtags / social media accounts provide opportunity / platform / communication channels to connect with people for collaboration</li>\n<li>Folksonomies / hashtags / social media / web 2.0 has given all users opportunity to create instead of simply seeking information;</li>\n<li>trending hashtags may make users with opposing points of view less willing to expose their dissent / more likely that users just follow the trend;</li>\n<li>Social media allows people to be anonymous and hence more likely to attack/hurt others</li>\n<li>users including certain hashtags may find themselves open to attack/abuse from other human users / automated bot accounts (e.g. “trolling”);</li>\n<li>hashtags are open to misuse and manipulation (e.g. \"bot\" accounts flooding social media with tagged posts / users stuffing posts with multiple lines of the same hashtag to create a false \"trend\");</li>\n<li>users who follow/search on popular hashtags may find themselves \"bubbled\" – i.e. they are only ever exposed to viewpoints that reflect their own existing perspectives;</li>\n<li>Content people share is moving towards viral / inappropriate content to attract attention</li>\n<li>Followers of popular accounts / hashtags tend to be influenced by the views / content of the account / hashtag (e.g. popular YouTube accounts may start advertising products)</li>\n</ul>\n<p><em>Accept other reasonable answers that convey similar ideas</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates answered this correctly.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates answered this correctly.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "19M.2.HL.TZ0.13",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-6-the-intelligent-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> reasons why patches may be necessary for an operating system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> methods that can be used to obtain these patches.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Allows bugs/error in operating system to be repaired;<br/>Allows new features to be added to operating system (such as security updates, improving functionality, improving usability, etc.);<br/>Allows compatibility issues to be improved;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Automatic patches/updates sent (via internet);<br/>User requested updates (via internet);<br/>Patches sent on CD/DVD/memory stick;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to identify at least one reason why patches may be necessary for an operating system, with a large proportion correctly naming two reasons.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates correctly identified one or two methods of obtaining patches, for example, by downloading them or installing them from an external device. However, many candidates incorrectly gave the same method twice, for example, by suggesting two methods of downloading patches.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.4",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following recursive method.</p>\n<p><code><strong>public void</strong> recursionEx(<strong>int</strong> x)</code><br/><code>{</code><br/><code><strong> if</strong>(x != 0)</code><br/><code> {</code><br/><code> System.out.println(x);</code><br/><code> recursionEx(x - 1);</code><br/><code> System.out.println(x);</code><br/><code> }</code><br/><code>}</code></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> essential features of a recursive algorithm.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the following table to show the output when the method is called by: <code>recursionEx(3)</code>;</p>\n<p><img src=\"\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain what would happen if the method was called by <code>recursionEx(-3)</code>.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> features which should be included in either program code or UML diagrams to help programmers understand and modify programs in the future.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The method calls itself;<br/>With a changing parameter;<br/>There is a base (terminating) case;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><img src=\"\"/></p>\n<p><em>Award marks as follows:</em><br/>Outputting 6 values;<br/>Correct parameter list<br/>First 3 output numbers correct;<br/>Last 3 output numbers correct;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>An infinite loop / program will never end/terminate;<br/>Will eventually cause the program to crash;<br/>As it runs out of memory for the parameters stored / Stack overflow;<br/>As the base case is never reached;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Comments can be added;<br/>Use of meaningful names;<br/><span style=\"text-decoration:underline;\">Correct</span> indentation;<br/>Relationships/dependencies shown between class (UML) diagrams;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18M.2.HL.TZ0.19",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The organizing school arranges for visiting students to stay with a host family. The information about each of the visiting students is stored in a file. The student records are sorted by name. Some of the other variables included are school, gender, age and host family name, as shown in the UML diagram below.</p>\n<p><img src=\"\"/></p>\n<p>A program needs to be written to match visiting students with host families. The matching process requires data to be manipulated extensively (adding, editing, deleting). The file will be read into RAM.</p>\n<p>This program will be used for different events with different numbers of visitors. Therefore, it will be implemented using a dynamic data structure.</p>\n</div><div class=\"specification\">\n<p>It has been decided to use a single linked list named <code>guests</code> to store and manipulate the <code>Visitor</code> objects.</p>\n</div><div class=\"specification\">\n<p>Consider the following diagram which represents the list <code>guests</code>.</p>\n<p><img src=\"\"/></p>\n<p>The following recursive method has been written to act on the list <code>guests</code>.</p>\n<pre><strong>public void</strong> recursive(<strong>int</strong> k, <strong>char</strong> a)<br/>{<br/><strong> if</strong> (k == guests.size())<br/> {<br/><strong> output</strong> (\"no such record\");<br/> }<br/><strong> else<br/></strong> {<br/> Visitor current = guests.get(k);<br/><strong> if</strong> ((current.getGender() == a) <strong>&&</strong> (current.getAge() > 15))<br/> {<br/><strong> output</strong> current.getName();<br/> }<br/><strong> else</strong><br/> {<br/> recursive(k + 1,a);<br/> }<br/> }<br/>}</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>object reference</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> reason why a linked list may be more suitable than a binary tree in this particular situation.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the code needed to instantiate an object <code>guests</code> of the <code>LinkedList</code> class.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the code for the method<code> penultimate()</code> that returns the second to last element in the linked list <code>guests</code>. You may assume that <code>guests</code> is locally accessible.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using the data provided in the diagram, trace the call <code>recursive(0,'F')</code>, clearly showing the levels of recursion.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> reason why the use of a recursive method may be inappropriate for linked lists.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Due to unforeseen circumstances, schools may cancel their participation in an event at the last minute. Therefore, a method is needed to remove all the visiting students of one school from the linked list <code>guests</code>.</p>\n<p>Construct the method <code>removeSchool</code> that takes the name of a school as parameter and removes all students of that school from the list <code>guests</code>.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>A reference is a variable whose value points to the location of an object (in memory); </p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>The ease of which pointers or references can be manipulated in a linked list;</em><br/><em>Allows easier addition/deletion of objects (compared to a binary tree);</em><br/><em>It can be difficult to manipulate pointers or references in a binary tree;</em><br/><em>Which makes it more difficult to add or delete objects in a binary tree;</em> </p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <em>Allow missing final parentheses</em>.<br/><code>LinkedList<Visitor> guests = <strong>new</strong> LinkedList<Visitor>()</code>;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for correct signature.</em><br/><em>Award <strong>[1]</strong> for using <code>size()</code> or finding the correct size of the linked list *</em><br/><em>Award <strong>[1]</strong> for correctly returning the penultimate element.</em><br/><em>Award <strong>[1]</strong> for correctly returning null if there is no penultimate element in the list.</em></p>\n<pre><strong>public</strong> Visitor penultimate(LinkedList guests) // parameter<br/>is optional<br/>{<br/> Visitor result = <strong>null</strong>;<br/><strong> if</strong>(guests.size() > 1) {<br/> result = guests(guests.size()-2);<br/> }<br/><strong> return</strong> result;<br/>}</pre>\n<p><em>*Note to examiners – allow a method that will iterate through the class as long as a valid LinkedList class methods are used.</em></p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for showing the second call to the method</em><br/><em>Award <strong>[1]</strong> for showing the third call to the method (and no subsequent calls)</em><br/><em>Award <strong>[1]</strong> for including the correct test outcome</em><br/><em>Award <strong>[1]</strong> for correct output</em></p>\n<pre>recursive(0,'F')<br/> k = 0<br/> current is Ana<br/> test incorrect<br/> recursive(1,'F')<br/> k = 1<br/> current is Ben<br/> test incorrect<br/> recursive(2,'F') <br/> k = 2<br/> current is Defne<br/> test correct<br/> output Defne Tasci</pre>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>For a large linked list, this would require a large number of recursive calls / become very memory intensive;</em><br/><em>Which may cause stack overflow;</em></p>\n<p><em>A linked list only allows for sequential access;</em><br/><em>Therefore, using recursion would not lead to any gains in efficiency;</em></p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for the correct initialisation of index.</em><br/><em>Award <strong>[1]</strong> for correct loop/iterator declaration and initialisation</em><br/><em>Award <strong>[1]</strong> for the correct assignment to current.</em><br/><em>Award <strong>[1]</strong> for the correct comparison of school (allow use of =)</em><br/><em>Award <strong>[1]</strong> for the correct remove (allow correct use of next pointer)</em><br/><em>Award <strong>[1]</strong> for the decrementing index after remove.</em><br/><em>Award <strong>[1]</strong> for correct increment of index / use of <code>iterator.next()</code>. Within context.</em></p>\n<p><em>Example answers</em>:</p>\n<pre><strong>public void</strong> removeSchool(String school) {<br/><strong> int</strong> index = 0;<br/> Visitor current;<br/><strong> while</strong>(index < guests.size()) {<br/> current = guests.get(index);<br/><strong> if</strong>(current.getSchool().equals(school)) {<br/> guests.remove(index);<br/> index--;<br/> }<br/> index++;<br/> }<br/>}<br/><strong><br/>public void</strong> removeSchool(String school) {<br/><br/> Visitor current;<br/><strong> for</strong>(<strong>int</strong> index = 0; index < guests.size();index++) {<br/> current = guests.get(index);<br/><strong> if</strong>(current.getSchool().equals(school)) {<br/> guests.remove(index);<br/> index--;<br/> }<br/> }<br/>}<br/><strong><br/>public void</strong> removeSchool(String school) {<br/> Iterator<Visitor> itr = guests.iterator();<br/> Visitor current;<br/><strong> while</strong>(itr.hasNext()){<br/> Visitor current = itr.next();<br/><strong> if</strong>(current.getSchool().equals(school)) {<br/> itr.remove();<br/> }<br/> }<br/>}</pre>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not many candidates related this term to a location in the memory.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A binary tree may be ideal when searching for items, but when extensive editing is required then the ability of a linked list to easily manipulate its pointers makes this structure the preferred option.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Reasonably well answered.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>When answering questions regarding a library class then the use of the correct methods are expected. Not many candidates were familiar with the use of the size method.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a quite straightforward trace of a recursive algorithm which most candidates completed well.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates alluded to the excessive use of memory if recursion was used.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates made a reasonable attempt but too many tried to use generic methods instead of ones specifically pertaining to this class.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19M.2.HL.TZ0.17",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A group of art students have taken three examinations in the school year. Each of the three examinations has a maximum mark of 100. Each student’s total mark for the year is the sum of the marks from the three examinations.</p>\n<p>The students have passed unless their marks meet one or both of the following failing conditions:</p>\n<ul>\n<li>Scoring less than 30 marks on <strong>any</strong> one of the three examinations.</li>\n<li>Scoring a total mark that is less than 150.</li>\n</ul>\n<p>Consider the following relation created by the teacher of this group of students.<br/><br/></p>\n<p><strong>CLASS_TABLE</strong></p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the relation CLASS_TABLE distinguish between data and information.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>entity</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the entity for this example relation.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify an appropriate data type for Student_ID.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the role of data validation and data verification.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how Total could be validated.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the steps in a query that will output the names of all students who earned the maximum mark on Exam_Two.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">f.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the steps in a query that will output the Student_IDs of all candidates who passed.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">f.ii.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for stating what data is</em>.<br/><em>Award <strong>[1]</strong> for stating what information is</em>.<br/><em>Award <strong>[1]</strong> for stating the difference using an example</em>.</p>\n<p><em><strong>Example answer 1</strong></em><br/>Data is a raw fact, for example, “Joe Skrin” is data/a string;<br/>Whilst information is data which has meaning;<br/>In this table “Joe Skrin” is the name of an art student/who had an examination/ who passed an examination;</p>\n<p><strong>Example answer 2</strong><br/>For example, number 99 is data;<br/>In this database, total 99 is information;<br/>Because it has meaning, it represents a student’s mark/it shows that the student failed;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>An entity is some unit of data that can be classified and has stated relationships to other data units;<br/>A real-world object with attributes that is represented as data in a database;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>In relation to given example, the entity is a single student about whom data can be stored as a record in this relation;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>String/varchar/char/alphanumeric;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>. Award <strong>[1]</strong> for stating the purpose of data verification and <strong>[1]</strong> for further explanation, up to <strong>[2 max]</strong>. Award <strong>[1]</strong> for stating the purpose of data verification and <strong>[1]</strong> for further explanation, up to <strong>[2 max]</strong></em>.</p>\n<p>Data verification is a process that ensures the accuracy of data;<br/>(Accurate data is important because strategies devised based on incorrect data lead to inconsistent decision making;)<br/>Data verification is conducted using proofreading/double entry checks/new data cleansing software and technologies have been developed to automate the data verification process;</p>\n<p>Data validation ensures the data is logical and reasonable;<br/>Data validation is a computer-generated process using codes to validate a range of data;</p>\n<p>Data verification and data validation (applied in combination) provide quality assurance/make sure that processes and strategies are not driven in the wrong direction;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.</p>\n<p><em><strong>Example answer 1</strong></em> (<em>assuming the value of the Total is calculated</em>)<br/>The calculated value for the total mark must be an integer;<br/>In the range from 0 to 300;<br/>(If it is not, an error message could be output;)</p>\n<p><em><strong>Example answer 2</strong></em> (<em>assuming the value of the Total is entered</em>)<br/>The entered value for the total mark must be an integer;<br/>In the range from 0 to 300;<br/>The sum of marks on the three exams can be calculated and should be equal to the entered value for Total;<br/>(If it is not, an error message could be output;) </p>\n<p><em><strong>Example answer 3</strong></em><br/>Total is a validated field;<br/>Therefore, if all the individual test fields are validated, the Total value will automatically be within the specified range;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for selecting the correct field from the table and <strong>[1]</strong> for a correct comparison, up to <strong>[2 max]</strong></em>.</p>\n<pre>SELECT Student_Name FROM Class_Table<br/>WHERE Exam_Two == 100</pre>\n<p><em><strong>Note</strong>: Accept logically equivalent answers</em>.</p>\n<div class=\"question_part_label\">f.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for selecting the correct field from the table.</em><br/><em>Award <strong>[1]</strong> for each of the correct comparisons, up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for using logical operators correctly.</em></p>\n<p><strong><em>Example answer 1</em></strong></p>\n<pre>SELECT Student_ID FROM Class_Table<br/>WHERE Exam_One >= 30 and Exam_Two >= 30 and<br/> Exam_Three >= 30 and Total >= 150</pre>\n<p><strong><em>Example answer 2</em></strong></p>\n<pre>SELECT Student_ID FROM Class_Table<br/>WHERE not (Exam_One < 30 or Exam_Two < 30 or<br/> Exam_Three < 30 or Total < 150)</pre>\n<p><strong><em>Note</em></strong>:<em> Accept logically equivalent answers.</em></p>\n<div class=\"question_part_label\">f.ii.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.ii.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.2",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-1-basic-concepts",
|
||
"a-2-the-relational-database-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Calculate the denary (base 10) equivalent of the hexadecimal number BF.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>11 × 16 + 15;<br/>191;</p>\n<p><em>Allow solution via binary route 1 mark for working, 1 mark for answer</em>.<br/><em>Allow both marks if correct answer given</em>.</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were required to convert a hexadecimal number to its denary equivalent. A range of different correct methods for doing this was seen, with candidates receiving the appropriate credit. However, some candidates found this question difficult and were unable to provide a correct answer or demonstrate a method of solution.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.5",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>RunAndBeyond</em> is a sports knowledge website, offering expert knowledge and technical tips on sport disciplines. Official teams and associations are invited to include some of their own multimedia digital resources to <em>RunAndBeyond</em>.</p>\n<p>A team of triathletes, finding their sport discipline under-represented in the website, wants to contribute content for <em>RunAndBeyond</em>. The team intends to use a wiki in collaborating online with other similar interested groups in triathlon when creating and updating their own resource.</p>\n</div><div class=\"specification\">\n<p>The triathlete’s online resource provides a variety of references through external links, and one of them points to:</p>\n<p style=\"text-align: center;\">ftp://files.tri-events.cc/site/index.php/en/general-info</p>\n</div><div class=\"specification\">\n<p>There are also external links on the website to videos and some of these are transferred using lossy compression. When these videos are transferred, they can either be streamed or downloaded for future viewing.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how a wiki can support the ongoing collaboration in producing the triathletes’ resource.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the reason why the above link is a URL.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the processing that takes place when the line of code above is executed.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Suggest why lossy compression should be the compression technique used.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The <em>RunAndBeyond</em> website continually automatically updates its content regarding a live sporting event.</p>\n<p>Suggest how a dynamic web page would function in providing this service to the user.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.</p>\n<p><em><strong>Note</strong>: An expansion from <strong>the technical/computational perspective only</strong> (not sociological one) is expected about aspects of the chosen method of online interaction</em>.</p>\n<p><span style=\"text-decoration:underline;\">Aspects that can gain credit</span>:<br/>Editing, permissions layer, ownership, tracking of updates, security (open to vandalism/non-monitored contributors), open source (interoperability).</p>\n<p>Software for wikis provides <span style=\"text-decoration:underline;\">collaborative</span> editing sharing of information of content, directly from the browser;<br/><span style=\"text-decoration:underline;\">Updates are usually tracked</span> in wikis (also to be removed afterwards) as they come from different authors / usually non-moderated / added content can also be removed later on (also by others);<br/>The evolution of a wiki is more immediate and spontaneous because updates are immediately visible;<br/>The wiki can easily be vandalized with incorrect/unauthoritative information, but it can also be quickly amended/corrected if this is realized quickly;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[1 max]</strong></em>.<br/>It specifies how to access the resource/show the path/contains domain name, with the ftp protocol;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>:<br/>It sends a GET/PHP request to the server tri-events.cc;<br/>To execute en/general-info (index.php);<br/>And the result of this execution is made available to the client /browser (with ftp);<br/>(It specifies to use the ftp protocol to send the request and to return the resource;)</p>\n<p><em><strong>Note:</strong> Do not accept DNS</em>.</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>Lossy compression results in files of smaller size;<br/>It may be needed for video <span style=\"text-decoration:underline;\">streaming</span> because the server provides execution through scripting;<br/>And guaranteeing streaming without interruptions is a priority;<br/>It may be a choice for <span style=\"text-decoration:underline;\">downloading</span> video for local execution to manage outgoing traffic on popular servers/increases the speed (using smaller files);</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.</p>\n<p>Award <strong>[1 max]</strong> for identifying a technology that is needed award up to <strong>[3 max]</strong> for an extension describing how the technology is used and interacts with other components.</p>\n<p><em><strong>Example 1</strong></em>:<br/>An interactive web page that has an <span style=\"text-decoration:underline;\">auto-refresh/automatic update extension</span>;<br/>So that every N seconds a script is executed to reload the page;<br/>The web page is linked to an underlined database/data source<br/><strong>OR</strong> interrogates specific databases/news databanks;<br/>That are distributed and collectively provide regular updates;<br/>And they can be displayed back using the script;</p>\n<p><em><strong>Example 2</strong></em>:<br/>A dynamic web page equipped with a <span style=\"text-decoration:underline;\">RSS feed</span>;<br/>That collects/aggregates news from sources that cover that live event;<br/>The feed is in form of an update in XML;<br/>Therefore, it can be used to feed an underlining (distributed) database or the web page/uses syndication/can be immediately interpreted by the browser;<br/>And it can then be processed by some script to be displayed back in the original web page;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.8",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-3-distributed-approaches-to-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> reasons why fibre optic cable would be preferred over wireless connectivity.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Fibre optics allow faster transmission speeds;<br/>Fibre optic cables are more secure/harder to break into;<br/>Fibre optic cable transmission is more reliable/less likely to suffer interference;<br/>Fibre optics allow transmission over longer distance;<br/>Fibre optics allow greater bandwidth;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>This question was answered very well with the vast majority of candidates able to give two reasons why fibre optic cables would be preferred over a wireless connection.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.6",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Artificial neural networks (ANNs) are being used in a variety of applications, including pattern recognition, game playing, classification and data mining.</p>\n</div><div class=\"specification\">\n<p>An ANN is being trained to recognize handwritten numbers by identifying them as a digit from 0 to 9.</p>\n</div><div class=\"specification\">\n<p>Assume that each digit to be identified is input as an image made up of 30 × 30 pixels.</p>\n</div><div class=\"specification\">\n<p>A simplified version of an ANN is shown below.</p>\n<p><img src=\"\" style=\"display: block; margin-left: auto; margin-right: auto;\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> reason why ANNs are suitable for solving the types of problems found in these areas.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe an appropriate set of data that could be used to train the network.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the number of neurons that would be in the input layer.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the number of neurons that would be in the output layer.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the way in which the output from neuron D will be determined.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The network is set up with initial values. The outputs are compared with the desired outputs.</p>\n<p>Identify the steps that now take place to train the network.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The functions/mathematical relationships in these types of problems;<br/>Which are required for use with traditional algorithms/non-ANN algorithms;<br/>And are difficult/impossible to define;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Many sets of digits;<br/>Using different pens/colours/thicknesses etc.;<br/>Written by different people;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>900;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>10;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>The product of;<br/>The weights and the input values;<br/>Will be summed for neurons A, B and C;<br/>From this will be subtracted a bias/constant / This will be compared to a bias/constant/ A function will be applied;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[5 max]</strong></em>.<br/>The difference between the actual and desired outputs;<br/>Which is the value of the cost function;<br/>Leads to adjustments in the weights;<br/>Of the neurons in the hidden layer(s);<br/>The process is repeated;<br/>Until the cost function reaches an acceptable value;<br/>Or a certain number of iterations are made;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "17N.2.HL.TZ0.8",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Distinguish between a <em>variable</em> and a <em>constant</em>.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>The value of a variable can change while value of a constant does not change; <br/>During program execution/ during run-time / while stored in the memory;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates generally achieved at least one mark for this question by recognising that a variable’s value would change but that the value of a constant would not. Those who were able to expand that point and say where this would happen, for example, during the execution of a program, also achieved the second mark.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.7",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Define the term <em>peripheral</em>.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>A piece of hardware / a hardware device that is <span style=\"text-decoration:underline;\">externally</span> connected or attached / <span style=\"text-decoration:underline;\">remotely</span> connected or attached (to the computer system);</p>\n<p><em>Example answer</em><br/>A peripheral is an external (computer) device that is connected to a computer, such as a keyboard;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were generally able to name a peripheral device, but were less able to provide a complete definition, often failing to mention that it is ‘externally’ connected, or similar.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.1",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>List the output from the given algorithm for the following input. </p>\n<p>2, 6, 8, 9, 12, 15, 18, 20</p>\n<pre>loop for Count from 0 to 7<br/> input NUMBER<br/> if NUMBER div 2 = NUMBER / 2 then<br/> if NUMBER div 3 = NUMBER / 3 then<br/> output NUMBER<br/> end if<br/> end if<br/>end loop</pre>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em><br/>6;<br/>12;<br/>18;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were generally able to dry run the given algorithm and give the values of the various calculations, but unfortunately, not everyone identified the values that would actually be output, namely those divisible by both 2 and 3, but instead listed all the numbers from the input. The full range of marks was seen for this question.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.8",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Define the term <em>data packet</em>.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1 max]</strong></em><br/>A unit of data made into a single unit (that travels along a given network path);<br/>A data packet travels through a network as a unit i.e. with all parts kept together;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates generally understood what is meant by data packet and gave a sufficient response to achieve the mark.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.9",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> features of a graphical user interface (GUI).</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Menus;<br/>Dialogue boxes;<br/>Windows;<br/>Icons;<br/>Pointers;<br/>Buttons;</p>\n<p><em>Note to examiners: allow other correct user interface features</em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates offered a wide range of responses giving many correct features of a graphical user interface, including, for example, menus, toolbars, pointers and icons.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.2",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following example relation. It holds data about a number of teachers and students from different schools who volunteer to support the local community on particular days.</p>\n<p><strong>SCHOOL_VOLUNTEERS_TABLE</strong> (School_Name, <span style=\"text-decoration: underline;\">Code</span>, Address, <span style=\"text-decoration: underline;\">Date</span>, Num_Volunteers)</p>\n<p><img src=\"\"/></p>\n<p>The key attributes are underlined.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State what is meant by redundant data in databases.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> issue that can be caused by redundant data in a database.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> characteristics of the 1st Normal Form (1NF) which are evident in this relation.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why a compound key is used for the SCHOOL_VOLUNTEERS_TABLE relation.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The following shows the normalized SCHOOL_VOLUNTEERS_TABLE relation:</p>\n<p>SCHOOLS_TABLE<br/><span style=\"text-decoration:underline;\">Code</span>, School_Name, Address</p>\n<p>VOLUNTEERS_TABLE<br/><span style=\"text-decoration:underline;\">Code</span>, <span style=\"text-decoration:underline;\">Date</span>, Num_Volunteers</p>\n<p>Discuss whether these relations are in third normal form (3NF).</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>Redundant data means data that is held in two different places within a database;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying an issue caused by data redundancy and <strong>[1]</strong> for a brief explanation up to <strong>[2 max]</strong></em>.</p>\n<p>It could give the system unwanted/unexpected results;<br/>due to the use of inaccurate data;</p>\n<p>It may lead to additional storage requirements;<br/>As data is used more times than necessary;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>Each attribute has a single value/is atomic;<br/>All values for a given attribute are of the same data type;<br/>Each attribute is unique;<br/>This is a unique key;<br/>There are no repeating fields;<br/>There are no two identical tuples in this relation;<br/>Order of attributes/tuples is not significant for the relation;<br/>Key (Date + Code) is unique for each tuple;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying why a compound key is used for the <code>SCHOOL_VOLUNTEERS</code> relation and <strong>[1]</strong> for a brief explanation up to <strong>[2 max]</strong></em>.</p>\n<p>The alternative is to use an autonumber field;<br/>But this would use additional storage space;</p>\n<p>Are used because it is not possible to designate a primary key from a single field;<br/>Neither the code nor the date field on their own uniquely identify a record;<br/>Is based on two primary keys in other tables;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[5 max]</strong></em>.</p>\n<p><em><strong>Example answer 1</strong></em><br/>2NF = 3NF if there are no transitive relationships/if any non-key attributes are more dependent on another non-key attribute than the key field;<br/><code>Schools_Table</code> could be the above if a school had more than 1 address;<br/>Then the <code>Address</code> would depend upon the <code>School_Name</code>;<br/>And the <code>Schools_Table</code> code would be split as follows:<br/>(<code>Code, School_Name</code>)<br/>(<code>School_Name, Address</code>);<br/>If the school had only 1 address then 2NF = 3NF;<br/>The <code>Volunteers_Table</code> has no transitive dependencies;<br/>There is no redundant data;</p>\n<p><em><strong>Example answer 2</strong></em><br/>A relation is in 3NF if it is in 2NF and it contains no transitive dependencies;</p>\n<p>Assuming that schools name is not unchangeable;<br/><em><strong>OR</strong></em> there are two schools with different names and same addresses;<br/><em><strong>OR</strong></em> two schools with same name and different addresses;<br/>Then the school name cannot be treated as a key;</p>\n<p>From the 2NF (two created relations above) the functional dependencies are not evident in the relation <code><strong>School_Table</strong> (School_Name, Code, Address)</code>:</p>\n<p>The relation given above (in 2NF) is also in 3NF;<br/><code><strong>School_Table</strong> (School_Name, Code, Address)</code><br/><code><strong>Volunteers_Table</strong> (Code, Date, Num_Volunteers)</code></p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.3",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>database transaction</em>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the importance of durability in a database transaction.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> different types of relationships within databases.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the nature of the data dictionary.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify four responsibilities of a database administrator.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follow up to <strong>[2 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for: </em><em><br/>a unit of work/logical action;</em><br/><em>performed on a database;</em><br/><em>independent of other transactions; </em><br/>changes state of the database;</p>\n<p><em><strong>Example answer 1</strong></em><br/>A database transaction is a logical unit that is independently executed;<br/>For data retrieval or updates;</p>\n<p><em><strong>Example answer 2</strong></em><br/>A database transaction is a unit of work;<br/>That is either executed in full or not executed at all;</p>\n<p><em><strong>Example answer 3</strong></em><br/>A database transaction is a way of representing a state change;<br/>And has four properties, known as ACID;</p>\n<p><em><strong>Example answer 4</strong></em><br/>A database transaction usually means a sequence of steps, treated as a unit;<br/>For the purposes of satisfying a client’s request;</p>\n<p><em><strong>Example answer 5</strong></em><br/>A database transaction is a process carried out on a database;<br/>Which may change its state, for example: moving money between bank accounts;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>.</em></p>\n<p><em><strong>Example answer 1</strong></em><br/>Durability is important because transaction data changes must be available;<br/>Even in the event of database failure;</p>\n<p><em><strong>Example answer 2</strong></em><br/>Durability means that if the system says the transaction has been committed;<br/>The client does not need to worry about it because transactions that have been committed will survive permanently;</p>\n<p><em><strong>Example answer 3</strong></em><br/>Durability in databases is an important property because it ensures transactions are saved permanently;<br/>And do not accidentally disappear or get erased;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>. </em><br/>One to one;<br/>One to many;<br/>Many to one;<br/>Many to many;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for stating what a data dictionary is and up to <strong>[3 max]</strong> for describing its contents</em>.</p>\n<p>It is a set of tables/a database that provides information/meta-data about the database;</p>\n<p><em>A data dictionary contains</em><br/>The definitions of records/entities in the database;<br/>How much space has been allocated for and is currently used;<br/>Default values for columns/attributes;<br/>Integrity constraint information;<br/>Names of (database) users, their privileges and roles;<br/>Auditing information such as who has accessed or updated data records;<br/>etc. (any other general database information);</p>\n<p>They do <span style=\"text-decoration:underline;\">not</span> contain any actual data from the database, it contains only information for managing it (without a data dictionary a DBMS cannot access data from the database);<br/>Data dictionaries are usually hidden from users to prevent them from (accidentally) deleting/changing/destroying its contents;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>To direct and perform all activities related to a database system;<br/>Installing and configuring software;<br/>Creating new databases;<br/>Designing the database schema and creating any necessary database objects;<br/>Ensure database security is implemented to safeguard the data;<br/>Back up and recover the database;<br/>Work closely with application developers and system administrators to ensure all database needs are being met;<br/>Apply patches or upgrades to the database as needed;<br/>Training employees who use the database;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.1",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-1-basic-concepts",
|
||
"a-2-the-relational-database-model",
|
||
"a-3-further-aspects-of-database-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>one</strong> common feature found in the user interface of application software to improve its usability.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1 max]</strong></em><br/>Toolbars;<br/>Menus;<br/>Dialogue boxes;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates seemed to misunderstand what was required as a feature of the user interface for application software, which would be, for example, a menu or a toolbar, and gave answers such as colour, or answers related to accessibility, such as large fonts.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.10",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline <strong>one</strong> method of collecting information from stakeholders concerning the requirements for a new system.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Surveys;<br/>(General) questions distributed to many stakeholders as a written or online document;</p>\n<p>Interviews;<br/>(Specific) questions asked of nominated stakeholders in an individual setting;</p>\n<p>Direct observations;<br/>Observer watches stakeholders performing their current tasks;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates named one of the recognised methods of collecting information at the start of the system design phase, notably questionnaires, interviews or observation; but not all correct answers were given an appropriate expansion for the second mark.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.3",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct the truth table for the following logic circuit:</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em><br/>1 mark: 1–2 correct rows;<br/>2 marks: 3–4 correct rows;<br/>3 marks: 5–6 correct rows;<br/>4 marks: 7–8 correct rows;</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were able to construct correct truth tables and populate them sufficiently well to achieve some or all of the marks. Some candidates populated the inputs in a random fashion, rather than the standard method. This sometimes led to repeated lines or missing lines, causing the candidate to lose marks.</p>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.11",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A shop sells only fruits and vegetables. Data about the products sold is held in the relation Greengrocer as follows:</p>\n<p style=\"text-align: center;\"><strong>GREENGROCER</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align: left;\">Prod_ID is the primary key.</p>\n<p style=\"text-align: left;\">The relation above would be represented using the following notation:<strong><br/></strong></p>\n<p style=\"text-align: left;\"><strong>Greengrocer (Prod_ID, Prod_Name, Prod_Price, Supp_Name, Supp_Contact, Supp_Phone)</strong></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify an appropriate data type for Prod_Price.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the steps in a query to output the names of all products supplied by <em>Veggy Co</em>. with prices in the range from 4.00 to 10.00 inclusive.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the redundant data in this relation.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the problems that may arise for the following function performed on the given relation. In your answer, you should give an appropriate example: Inserting a new tuple with an item that is supplied by existing supplier.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the problems that may arise for the following function performed on the given relation. In your answer, you should give an appropriate example: Deleting a tuple from the relation.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the problems that may arise for the following function performed on the given relation. In your answer, you should give an appropriate example: Modifying a specific attribute value in the tuple.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the database in the 3rd normal form (3NF) using the notation</p>\n<p><strong>Greengrocer (Prod_ID, Prod_Name, Prod_Price, Supp_Name, Supp_Contact, Supp_Phone)You must show all your workings.</strong></p>\n<p>You must show all your workings.</p>\n<div class=\"marks\">[8]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[1 max]</strong></em>.<br/>Real number/float;<br/><em>Accept currency</em>.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for selecting correct field from the relation.</em><br/><em>Award <strong>[1]</strong> for correct supplier name comparison.</em><br/><em>Award <strong>[1]</strong> for correct checking the price range.</em><br/><em>Award <strong>[1]</strong> for correct logical operations.</em></p>\n<p><em>Example answer 1:</em></p>\n<pre>SELECT Prod_Name FROM Greengrocer<br/>WHERE Supp_Name == 'Veggy Co.' AND Prod_Price >= 4.00 AND<br/>Prod_Price <= 10.00</pre>\n<p><em>Example answer 2:</em></p>\n<pre>SELECT Prod_Name FROM Greengrocer<br/>WHERE NOT (Prod_Price <4.00 OR Prod_Price >10) AND<br/>Supp_Name == 'Veggy Co.'</pre>\n<p><em>Example answer 3:</em></p>\n<p><code>SELECT Prod_Name FROM Greengrocer</code><br/><code>WHERE NOT (Prod_Price <4 OR Prod_Price >10 OR Supp_Name !=</code><code></code><br/>'Veggy Co.' )</p>\n<p><em>Accept logically equivalent answers.</em></p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>. <br/>Redundant data unnecessarily repeats in a relation;<br/>Supplier data (name, phone, contact) are repeated;<br/>For every item that is supplied by the same supplier;</p>\n<p><strong>For example</strong>,<br/>Items P118, P122 and P220 have the same supplier (Veggy Co)<br/>Items P219, P111, P121 and P211 have the same supplier (Fruit and Veggie)</p>\n<p><em><strong>Note</strong>: Accept any correct example from the table given, such is the following</em>:</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for explaining a problem that may arise (such as inconsistency, inaccuracy / unnecessary additional/repeated work needed when updating)</em>.<br/><em>Award <strong>[1]</strong> for including example with reference to the relation given</em>.</p>\n<p><em>Example answer</em>:<br/>When inserting a tuple supplied by the existing supplier, for example, inserting:</p>\n<p><img src=\"\"/></p>\n<p>All data about supplier should be accurately entered;<br/>And consistent with the data about this supplier in all other tuples;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for explaining a problem that may arise (such as inconsistency, inaccuracy)</em>.<br/><em>Award <strong>[1]</strong> for including example with reference to the relation given</em>.</p>\n<p><em>Example answer</em>: <br/>Deleting a tuple could remove data which is not intended to be lost;<br/>For example; deleting the following tuple.</p>\n<p><img src=\"\"/></p>\n<p>Which is the only tuple in the relation which holds data about New Fruits suppliers (all data about this supplier will be lost);</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for explaining a problem that may arise (such as inconsistency, inaccuracy/unnecessary additional/repeated work needed when updating.</em><br/><em>Award <strong>[1]</strong> for including example with reference to the relation given</em>.</p>\n<p><em>Example answer</em>: <br/>Modifying/changing the phone number for Fruit and Veggie. would require that each and every tuple containing item supplied by Fruit and Veggie should be modified (unnecessary work);</p>\n<p><img src=\"\"/></p>\n<p>Otherwise the data in the relation would be inaccurate (for example, would contain different/incorrect phone numbers for the same supplier);</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">c.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[8 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for explaining/clearly showing each of the steps.</em><br/><em>Award <strong>[1]</strong> for identifying two entities (Product and Supplier) in Greengrocer.</em><br/><em>Award <strong>[1]</strong> for choosing/identifying a primary key in relation Supplier.</em><br/><em>Award <strong>[1]</strong> for clearly showing that the relation must be in 1NF and then could be put to 2NF.</em><br/><em>Award <strong>[1]</strong> for showing that each tuple in 2NF has a primary key.</em><br/><em>Award <strong>[1]</strong> for showing that in 2NF all attributes are on the whole dependent of the primary key.</em><br/><em>Award <strong>[1]</strong> for introducing new relations or using a foreign key.</em><br/><em>Award <strong>[1]</strong> for showing that the relation must be in 2NF and then could be put to 3NF.</em><br/><em>Award <strong>[1]</strong> stating that there are no transitive dependencies in 3NF.</em></p>\n<p><em><strong>Note</strong>: Because there is significant inconsistency in textbooks’ accounts of precisely what constitutes 1NF and 2NF, award marks depending on the explanation. Please see the two different example answers</em>.</p>\n<p><em><strong>Example answer 1</strong></em>:<br/>Given relation<br/><strong>Greengrocer(Prod_ID, Prod_Name, Prod_Price, Supp_Name, Supp_Phone,Supp_Contact)</strong></p>\n<p>There are two entities in this relation (Product and Supplier).</p>\n<p><strong>Product(Prod_ID, Prod_Name, Prod_Price)</strong><br/><strong>Supplier(Supp_ID, Supp_Name, Supp_Phone, Supp_Contact)</strong></p>\n<p>Primary key (Supp_ID) in relation Supplier is added to make sure that it is unique because it might be that two suppliers have the same name.</p>\n<p><strong>Product(Prod_ID, Prod_Name, Prod_Price, Supp_ID)</strong><br/><strong>Supplier(Supp_ID, Supp_Name, Supp_Phone, Supp_Contact)</strong></p>\n<p>To construct to 2NF relation must be in 1NF;<br/>Each tuple in 2NF must have a primary key;<br/><strong>And</strong> all attributes in the 2NF must be dependent on the whole of the primary key.</p>\n<p>New relation is introduced.</p>\n<p><strong>Product(Prod_ID, Prod_Name, Prod_Price)</strong><br/><strong>Supplier(Supp_ID,Supp_Name,Supp_Phone,Supp_Contact)</strong><br/><strong>ProdSupp(Prod_ID, Supp_ID)</strong></p>\n<p>There are two different contacts with the same name (Mia Abiss) at the two different companies.<br/>Assuming that each contact has a unique phone number, a new relation could be introduced in which Supp_Phone is a key.</p>\n<p>Supplier(Supp_ID, Supp_Name)<br/>SupplierContact(Supp_Phone, Supp_Contact)<br/>Product(Prod_ID, Prod_Name, Prod_Price)<br/>ProdSupp (Prod_ID, Supp_ID)</p>\n<p>The relation is in the 2NF <strong>and</strong> there are no attributes which are not dependent on the key.<br/>There are <strong>no</strong> transitive dependences so it is in the 3NF.</p>\n<p><em><strong>Example answer 2</strong></em>:<br/>The table is already in 1NF because all values are atomic. There are no “fake” attributes/columns, like Supp_Phone1, Supp_Phone2;<br/>So there are no repeating groups, either obvious or created by repeating columns for what is really the same attribute;<br/>To be in 2NF, in addition to being in 1NF;<br/>Every non-prime attribute must be dependent on the whole of every key;<br/>To be in 3NF, in addition to being in 2NF;<br/>All the attributes in a relation must be determined only by the key(s);<br/>And there should not be any transitive dependences;</p>\n<p>There are two entities (Supplier and Product);<br/>Supp_ID should be introduced;</p>\n<p>Supplier(Supp_ID, Supp_Name, Supp_Phone, Supp_Contact)<br/>Product(Prod_ID, Prod_Name, Prod_Price, Supp_ID*)</p>\n<p>Where underlining marks primary key(s) and *foreign key(s);</p>\n<p>There are two different contacts with the same name(Mia Abiss)at the two different companies.</p>\n<p>A new relation introduced in which Supp_Phone is a key;</p>\n<p>SupplierContact(Supp_Phone, Supp_Contact, Supp_ID*)<br/>Supplier(Supp_ID, Supp_Name)<br/>Product(Prod_ID, Prod_Name, Prod_Price, Supp_ID*)</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.3",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A school currently has a cabled network but wants to add wireless networking across the whole campus.</p>\n</div><div class=\"specification\">\n<p>There are concerns that unauthorized people could access the data on the wireless network.</p>\n</div><div class=\"specification\">\n<p>The school has decided to implement a virtual private network (VPN) to provide access to its network.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> hardware components the school will need to implement the wireless network.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> advantages to the students of the new wireless network.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> methods the school could employ to prevent network data from being accessed over their wireless system.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> technologies the school would require to provide a VPN.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> benefit to the staff of using a VPN to remotely access the school network.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em></p>\n<p>(Wireless) router;<br/>A central hub for all the computers to connect to;<br/>Enables wireless network packet forwarding and routing;</p>\n<p>Wireless Network Interface Card (NIC);<br/>To allow the computer to ‘talk to’ the (wireless) router;</p>\n<p>Wireless access points;<br/>allow Wi-Fi devices to connect to a wired network;</p>\n<p>Wireless repeaters;<br/>To expand the reach of the network;</p>\n<p>Mark as 2 and 2.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em><br/>The ability to use their own devices at school;<br/>The ability to access the school network from anywhere in the school;<br/>No cables laid, so reduces the risk of tripping over cables;<br/>Numbers of connections are not limited to cable ports, so greater numbers of students can connect at any given time; </p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em></p>\n<p>Use of encryption;<br/>So that data cannot be understood if it is intercepted;</p>\n<p>Use of user authentication/usernames and passwords;<br/>To prevent unauthorized access to the system;</p>\n<p>Setting up a file of accepted MAC addresses;<br/>To only allow access to the network by registered mobile devices;</p>\n<p>Hide network ID;<br/>So that the wireless network is not publicly seen;</p>\n<p>Mark as 2 and 2.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em><br/>Client VPN software (to make a secure remote connection);<br/>VPN-aware routers and firewalls (to permit VPN traffic to pass);<br/>VPN appliance/server (to handle incoming VPN traffic);<br/>Encryption protocol IPSec or SSL; </p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/>Enhanced security of data;<br/>for example, using encryption;<br/>This prevents unauthorised access;</p>\n<p>Remote access to data and resources (from any location);<br/>Normal access of materials on the network;<br/>as though the user was using the network on site;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates mostly only gained half of the available marks for this question. This was achieved by either naming two appropriate hardware components, but not describing them sufficiently for the expansion marks, or by only naming one correct component with a good description. It is important to note that for this question, candidates needed to identify additional components needed to implement the wireless network within the already existing school network. Therefore, equipment already in place, such as servers, would not gain credit.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates mostly identified one or two advantages to students of the new wireless network. Occasionally, candidates gave the same answer twice, mostly in relation to accessing the network from anywhere.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were able to identify and expand at least one method of preventing network data from being accessed over the wireless system. Some responses were not sufficiently detailed for both marks.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates found it difficult to identify two technologies that would be required by the school to provide a Virtual Private Network; however, a significant number did name one.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates answered this question well with responses related to one of the two suggested answers of enhanced security or remote access to network resources, or in some cases, a combination of the two.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.12",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline why a prototype would be used to demonstrate the proposed system to the client.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>To provide feedback on the efficiency or design of the product;<br/>To give an idea or feel of the final product;<br/>To encourage dialogue between the developers and the client;<br/>Clients can identify errors or omissions in the design;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates were able to achieve at least one mark, generally for ‘providing feedback’ or for ‘clients to identify errors in the system’, but not all responses had sufficient detail to achieve both marks.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.4",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A web application (app) runs on mobile devices such as smartphones and tablets. It allows users to locate their position in real time on a map, as they walk around a city, as well as the surrounding attractions. The app uses icons to represent tourist attractions such as art galleries and museums. When the user clicks on the icon, further details are shown, such as opening times. The app includes some use of client-side scripting.</p>\n</div><div class=\"specification\">\n<p>Many art galleries have websites that can be found by search engines. White hat techniques and practices allow website developers to optimize the search process. It is good practice to maintain the source code of websites up-to-date with actual information.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the functioning of this app. Include specific references to the technology and software involved.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the use on mobile devices, outline a feature of this application that may rely on client-side scripting.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>two</strong> metrics used by search engines.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why maintaining a clean HTML source code of a website by removing old information optimizes the search process.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The evolution of the web, architectures, protocols and their uses has led to increasingly sophisticated services that run on peer-2-peer (P2P) architectures.</p>\n<p>Explain how a P2P network can provide more reliability than a client-server model.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for showing understanding of the need <strong>of each</strong> of the following: GPS, mapping software, underlying distributed information</em>.</p>\n<p>The GPS of the device gives its current location (coordinates);</p>\n<p>Coordinates sent out through the Internet (with 3G/4G/5G/Wifi/using the specific features of the mobile device OS);</p>\n<p>Coordinates are linked to map software (e.g. Googlemaps) to retrieve current’s device position and neighbourhood information (using thematic databases);</p>\n<p>And integrated with further annotations (relative to museums) that can be provided by third-party services;<br/><em><strong>OR</strong></em> by information incrementally gathered from users;<br/><em><strong>OR</strong></em> by further databases (GIS services);<br/><em><strong>OR</strong></em> by interrogating an (incremental) database accessible from the server where the app has been downloaded from, for its first installation;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>.</em></p>\n<p><em>Award <strong>[1]</strong> for identifying a feature and award <strong>[1]</strong> for reasonable expansion of the feature up to <strong>[2 max]</strong></em>.</p>\n<p><em><strong>Example 1</strong></em>:<br/>The <span style=\"text-decoration:underline;\">design of the front-end</span> (the user interface) with the specific mobile device;<br/>So that the commands are specific (and built-in) within the device, to support interactive use;<br/>(With the effect that the app can be used across a range of devices and mobile operating systems;)</p>\n<p><em><strong>Example 2</strong></em>:<br/>To <span style=\"text-decoration:underline;\">personalize the app with a “history”</span> on the client’s side, after the first use of the application;<br/>So that only the new information added in the database (underlying sources used by the app) can be fetched by the client’s script;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Number of hits;<br/>Popularity of linking pages;<br/>Amount of links to the same page departing from the source page;<br/>Trustworthiness of the linking domain;<br/>Relevance of content between source and target page;<br/>Time to download;<br/>…(there are others).</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[5 max]</strong></em>.<br/>Old information is more likely to be retrieved by web crawlers;<br/>But this requires time to crawl;<br/>But this interferes with the response time for the current search;<br/>And it may even be penalised by policies in search engines;<br/>Without returning currently relevant information;<br/>Example of old information are old or broken links/orphan pages/old text masked by comments in the HTML code, and it can be revised from time to time;<br/>Cleanly written code allows for a more efficient search process;<br/>Which facilitates correct indexing;</p>\n<p><em><strong>Note:</strong> Award <strong>[2 max]</strong> for a generic response.</em></p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>In P2P all machines can interchangeably be client as well as server (no division of client-server);<br/>Data and services can be replicated across sites, and be retrieved from them;<br/>Services are virtualized/reside on virtual machines;</p>\n<p>Therefore, if one node is unavailable the service can still be provided by resorting to other nodes;<br/><em><strong>OR</strong></em><br/>System updates can be made while not interrupting the provision of the service<br/><em><strong>OR</strong></em><br/>The failure of a node does not imply the failure of the entire network</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.9",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-2-searching-the-web",
|
||
"c-3-distributed-approaches-to-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A water authority supplies water to its customers. The amount of water supplied to each customer is measured by a meter. There are two types of meter; an old meter and a new meter.</p>\n<p>The water authority also provides sewage services. This is when waste water is returned from the customers’ houses to a central processing plant. Only the new meter is able to estimate the amount of waste water returned.</p>\n<p>The authority reads the meters annually and the charges for these services are sent to the customers.</p>\n<p>The annual charges to customers are calculated using a model that takes into account the following variables:</p>\n<p><code>METER_TYPE</code> <br/>The type of meter which can be either old or new.</p>\n<p><code>WATER_IN</code><br/>The reading displayed on <span style=\"text-decoration: underline;\">both</span> meters (the reading is a 6-digit display in litres) which is used to measure the volume of water supplied.</p>\n<p><code>WATER_OUT</code><br/>The reading displayed on the <span style=\"text-decoration: underline;\">new</span> meter only (the reading gives a 6-digit integer display in litres) which is used in estimating the volume of waste water returned to the sewage system.</p>\n<p><code>INFRA_CHARGE</code><br/>The cost of maintaining the infrastructure for supplying water and providing the sewage service. This is an annual charge of $204.80. This amount is reduced by 10 % if a new meter is used.</p>\n</div><div class=\"specification\">\n<p>The digital displays on each meter function as follows:</p>\n<ul>\n<li>The digital display on each meter increments by one every time a litre of water passes.</li>\n<li>If the display reaches its maximum value it resets to 0 and then continues to function as before.</li>\n</ul>\n</div><div class=\"specification\">\n<p>The rules for calculating the annual bill for each household are as follows:</p>\n<ul>\n<li>The price for each litre of water supplied is $1.90.</li>\n<li>The total annual bill is the sum of the charge for the water supplied and the infrastructure charge.</li>\n<li>If the household has a new meter and at least 95 % of the water supplied is returned to the sewage system, then the infrastructure charge for that household is reduced by 10 %.</li>\n</ul>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the possible range of values <strong>and</strong> their data type for each of the above variables.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how the yearly supply of water is calculated.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the pseudocode that will calculate the annual bill for a household based on the information given above. You should introduce any new variables where necessary.</p>\n<div class=\"marks\">[7]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> possible measures that customers could take to reduce their infrastructure charge.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for <strong>correctly</strong> indicating <span style=\"text-decoration:underline;\">type</span>, and <span style=\"text-decoration:underline;\">values</span> expected, for each variable up to <strong>[3 max]</strong></em>;</p>\n<p>“<code>MeterType</code>”, String/char; “old”,”new”;<br/>“<code>WaterVol</code>”, Integer; 0–999999;<br/>“<code>InfraCharges</code>”, Currency/Float /Double; 184.32–204.80;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Making use of both the previous and new readings;<br/>Calculating the difference between them;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[7 max]</strong> as follows</em>:<br/>Involving previous readings;<br/>Calculation of water supplied <strong>[2]</strong> – allow <strong>[1]</strong> if correct apart from the reset;<br/>Separate code for use of new meter;<br/>Correct reduction of infrastructure charge <strong>[2]</strong> – allow <strong>[1]</strong> for an attempt to calculate this;<br/>Calculation of final bill;</p>\n<p><em><strong>Example</strong></em>:</p>\n<pre>householdBill(OLD_WATER_IN, OLD_WATER_OUT) // the previous <br/> // meter readings<br/>INFRACHARGE = 204.80<br/> if WATER_IN > OLD_WATER_IN // allows for possible <br/> // resetting of meter <br/> //reading to 0<br/> WATER_SUPPLIED = WATER_IN – OLD_WATER_IN<br/> else<br/> WATER_SUPPLIED = 1000000 – OLD_WATER_IN + WATER_IN<br/> end if<br/><br/>if METER_TYPE = \"new\" // possible reduction in sewage charges <br/> // if new meter is used<br/> if WATER_OUT > OLD_WATER_OUT<br/> WATER_RETURNED = WATER_OUT – OLD_WATER_OUT<br/> else<br/> WATER_RETURNED = 1000000 – OLD_WATER_OUT + WATER_OUT<br/> end if<br/> if WATER_RETURNED > 0.95 * WATER_SUPPLIED<br/> INFRACHARGE = INFRACHARGE * 0.9<br/> end if<br/>end if<br/><br/>BILL = WATER_SUPPLIED * 1.9 + INFRACHARGE</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Changing to a new meter (if they have an old one);<br/>Not using the supplied water for watering the garden etc.;<br/>Diverting rain water into the waste/sewage system;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.4",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-1-the-basic-model",
|
||
"b-2-simulations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>State the hexadecimal equivalent of the following binary number:</p>\n<p>11011111</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>DF;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Generally, well answered, but a significant number of candidates gave their answers in decimal rather than hexadecimal.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.5",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Computer simulations are often used in situations where practical experimentation is, for some reason, not possible. One of these reasons could be an ethical issue.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between a computer model and a computer simulation.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> reasons why some systems are difficult to model successfully.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With clear reference to the ethical issue, describe <strong>one</strong> example where practical experimentation would not be possible for ethical reasons.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>three</strong> other advantages, apart from ethical reasons, of simulating a computer model rather than constructing a physical one.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>A computer model is a representation of a system;<br/>Made up of variables and formulae/mathematical representation;<br/>Whereas a computer simulation is a process that uses the model;<br/>In order to see the outcome(s) when different values are used for the variables (in the model);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Either all of the variables are not known/difficult to define;<br/>Or the relationships between them cannot be expressed accurately/mathematically;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em><strong>Example</strong></em><br/>Experiments on living animals in a high school science class;<br/>Such as effects of altering diet;<br/>It is not ethically acceptable to harm animals (for such purposes);<br/><em><strong>Note</strong>:</em> <em>Accept reasonable examples, provided they are sufficiently explained</em>.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/><em>Computer models/simulations allow the designers to</em>:<br/>Make alterations and quickly see the outcomes;<br/>Repeat tests several times over;<br/>Model dangerous situations safely;<br/>Learn from “what if?” scenarios;<br/>Saves costs if several different models have to be built; </p>\n<div class=\"question_part_label\">c.ii.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.ii.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.4",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations",
|
||
"b-1-the-basic-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Medical students require extensive training in preparation before they qualify as a surgeon. Part of this training involves the use of simulation software.</p>\n</div><div class=\"specification\">\n<p>The simulation software projects the surgery scenario onto a touchscreen display. Students wear “smart” gloves to hold tools for performing the virtual operation on the touchscreen monitor. The touchscreen display shows realistic surgical tools.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage and <strong>one</strong> disadvantage of training medical students with simulation software.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> technical aspects that the gloves have to address so that they can be used in this way for the simulation of operations.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>visualization</em>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The medical school is considering updating its simulation software, which currently displays the simulation in 2D, to one that displays it in 3D.</p>\n<p>Discuss whether this change to a 3D display would improve the quality of the training.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong> as follows:</em><br/><em>Award <strong>[1 max]</strong> for identifying an advantage and <strong>[1 max]</strong> for an expansion.</em><br/><em>Award <strong>[1 max]</strong> for identifying a disadvantage and <strong>[1 max]</strong> for an expansion.</em></p>\n<p><em>Advantages (requires an expansion)</em>:<br/>They may see a complex situation numerous times / gain confidence in using the surgical tools;<br/>Without putting patients at risk / or keep practicing until they feel confident that they will be able to get it right in reality;</p>\n<p><em>Disadvantages (requires an expansion)</em>:<br/>They don’t have real-life experience;<br/>Therefore, we don’t know whether they will faint at the sight of blood;</p>\n<p>They may be trained just on the software (a unique body shape);<br/>But body shapes are different and students might find themselves at odds;</p>\n<p>They do not get an idea of how hectic the theatre can be/space available/interferences among people;<br/>And this training alone will be useless;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong>:</em><br/>It needs sensors to assess the <strong>pressure</strong> of the hand on the instrument;<br/>Its <strong>positioning with respect to the touchscreen</strong> needs to be tracked (for example by an external camera);<br/>Its <strong>inclination</strong> with respect to the touchscreen needs to be tracked;<br/>The <strong>change of tools</strong> held should be quickly reflected in the image that is displayed (affects communication);<br/>The <strong>specific tool</strong> needs to be recognized;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The representation of (abstract) data;<br/>In a way that is understandable by humans;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6 max]</strong></em>.<br/><em>Award <strong>[1 max]</strong> for identifying an advantage of the use of 3D and <strong>[1 max]</strong> for an expansion up to <strong>[3 max]</strong> for discussing the advantages of the use of 3D;</em><br/><em>Award <strong>[1 max]</strong> for identifying a disadvantage of the use of 3D and <strong>[1 max]</strong> for an expansion up to <strong>[3 max]</strong> for discussing the advantages of the use of 3D;</em><br/><em>Award <strong>[1 max]</strong> for a considered conclusion;</em></p>\n<p><em>Note to examiners: To achieve <strong>[6]</strong> a conclusion must be provided.</em><br/><em>If there is no conclusion the maximum mark is 5</em>.</p>\n<p>A 3D simulation will be more realistic;<br/>As depth can be shown;<br/>Patient’s body can be rotated; // allow up to <strong>[2]</strong> for example;</p>\n<p>But, a 3D simulation takes more time to render / more calculations have to be made;<br/>So, may not be displayed in real time;<br/>It is more demanding on memory / may exceed available memory;</p>\n<p>For an application, as serious as medical training, adequate hardware and software should be made available so that 3D simulations can be carried out;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.6",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-3-visualization",
|
||
"b-2-simulations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct the truth table from the following logic circuit.</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><img src=\"\"/></p>\n<p><em>Award <strong>[3 max]</strong></em>.<br/><em>Award <strong>[3]</strong> for all 8 correct rows</em>.<br/><em>Award <strong>[2]</strong> for 7 correct rows</em>.<br/><em>Award <strong>[1]</strong> for 5,6 correct rows</em>.</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates demonstrated that they were able to represent a logic circuit as a truth table, but a common error was to provide a truth table with insufficient rows, so not all combinations of input were covered, thereby losing marks.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.6",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A hotel chain has a loyalty scheme in which customers are awarded 1000 points for each day they stay in one of their hotels. With these points, customers can achieve one of three status levels: Gold, Silver or Bronze. The level will determine the extra services to which they are entitled.</p>\n<p>The total number of points collected during the <strong>current</strong> year will determine which of the three status levels they are assigned for the <strong>following</strong> year: For example <strong>only</strong> the points collected in 2018 will determine the status level for 2019.</p>\n<p>Occasionally, new customers receive additional <strong>bonus</strong> points as part of a promotion.</p>\n<p>The <code>Points</code> class keeps details of the points and status levels of each customer.</p>\n<pre><strong>public class</strong> Points<br/>{<br/><strong> private</strong> String memberId; // id of the hotel customer<br/><strong> private int</strong> totalPoints; // this year's points<br/><strong> private int</strong> bonusPoints; // any bonus points given to this year's new member<br/><strong> private</strong> String statusNow; // current(this year's)status<br/><strong> private</strong> String statusNextYear; // following year's status<br/><strong> private</strong> Visits[] allVisits = <strong>new</strong> Visits[366];//details of each visit<br/> // during this year<br/><strong> int</strong> y; // number of visits this year<br/><strong><br/> public</strong> Points(String id) // constructor for new member<br/> {<br/> memberId = id;<br/> bonusPoints = 0;<br/> y = 0;<br/> statusNow = \"Bronze\";<br/> }<br/><br/> //constructor for new member given bonus points (valid for current year only)<br/><strong> public</strong> Points(String id, <strong>int</strong> bp)<br/> {<br/> memberId = id;<br/> bonusPoints = bp; // multiples of 1000 - maximum number is 5000<br/> y = 0;<br/> statusNow = \"Bronze\";<br/> }<br/> <br/> // all the accessor and mutator methods are present but not shown<br/><strong><br/> public</strong> Visits getAllVisits(int v)<br/> {<br/><strong> return</strong> allVisits[v];<br/> }<br/><strong><br/> public void</strong> addVisit(Visits v) // adds a new Visit object to the array<br/> {<br/> allVisits[y] = v;<br/> y = y + 1;<br/> }<br/><br/> isGold() {code missing}<br/> calculateTotalPoints(){code missing}<br/> daysMissing(){code missing}<br/>}</pre>\n</div><div class=\"specification\">\n<p>The instance variables in the <code>Points</code> class are preceded by the modifier <code>private</code>. The choice of modifier affects the way in which these variables are accessed or used.</p>\n</div><div class=\"specification\">\n<p>The customers will be assigned one of three levels for the following year (Gold, Silver or Bronze) depending upon the current year’s total points as follows.</p>\n<ul>\n<li>Bronze = less than 10 000 points</li>\n<li>Silver = 10 000 or more but less than 50 000</li>\n<li>Gold = 50 000 or more.</li>\n</ul>\n<p>In 2018, Tim became a member for the first time and was awarded a bonus of 1000 points. So far, in 2018, Tim has stayed three times at one of these hotels. The first visit lasted 2 days, the second visit lasted 1 day and the third visit lasted 6 days.</p>\n</div><div class=\"specification\">\n<p>The different <code>Points</code> objects are stored in an array which is declared globally in the main (driver) class as follows: <code>Points[] allPoints = new Points[10000]</code>;</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With the use of <strong>two</strong> examples other than <code>private</code>, outline how the choice of this modifier affects the way in which these variables are accessed or used.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the <strong>two</strong> methods with the same name in the <code>Points</code> class, explain the OOP feature that makes it possible to successfully implement either of these methods.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the status level that Tim has been assigned, for 2019, following these visits.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State how an individual object can be identified using this array.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The attribute <code>statusNow</code> is assigned its correct value at the beginning of every year for existing members. It cannot be changed during the year.</p>\n<p>Construct the method <code>isGold()</code> in the <code>Points</code> class, which will return whether the current status is “Gold”.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><code>public</code>;<br/>Allows access to variables from outside of the class/unlimited access;</p>\n<p><code>protected</code>;<br/>Allows access to variable from within the package (project) in which they are created/subclasses;</p>\n<p><code>final</code>;<br/>Prevents variables from being modified;</p>\n<p><code>static</code>;<br/>Refers to variables that act on the class as a whole (and not on individual objects);</p>\n<p><em><strong>Note</strong><strong>:</strong></em></p>\n<ul>\n<li><em>Accept at most one example pertaining to methods.</em></li>\n<li>\n<em>Do not accept two examples pertaining to the same modifier</em>.</li>\n</ul>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The OOP feature shown in the constructors (accept the 2 signatures) is overloading (accept polymorphism);<br/>The constructor methods have a different number / type of parameters / different parameters;<br/>The method calling the constructor / compiler will determine which of these methods is selected;<br/>By matching up with the parameters;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Silver;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Through the use of the (appropriate) array index / appropriate code description;</p>\n<p><span style=\"text-decoration:underline;\"><em>Example</em></span>:</p>\n<p><code>Individual object = allVisits[individual object’s location]</code></p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<pre><strong>public</strong> boolean isGold()<br/>{<br/><strong> return</strong> (statusNow.<strong>equals</strong>(\"Gold\"); // allows =<br/>}</pre>\n<p><em>Award marks as follows:</em><br/>Signature;<br/>Correct comparison (allow use of <code>getStatusNow()</code>);<br/>Return (that matches the signature – allow FT);</p>\n<p><em><strong>Note</strong><strong>:</strong></em></p>\n<ul>\n<li><em>Allow the equivalent use of IF/THEN statements.</em></li>\n<li><em>Do not accept parameters to be passed.</em></li>\n<li>\n<em>Do not allow the use of</em> <em><code>totalPoints</code>.</em>\n</li>\n</ul>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.10",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-3-program-development",
|
||
"d-2-features-of-oop"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p><em>Google Translate</em> is an algorithm whose function is to translate text from one language to another. One of the resources that it uses is the body of documents produced by the United Nations which are routinely translated by humans into various languages.</p>\n<p>Discuss the reasons why <em>Google Translate</em> takes a probabilistic approach in preference to a cognitive rule-based approach.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award marks as follows up to <strong>[5 max]</strong></em>.<br/><em>Award<strong> [2 max]</strong> for an outline of how the statistical/probabilistic approach works (award </em><em><strong>[1]</strong> for a less complete response)</em>.<br/><em>Award <strong>[2]</strong> for an outline of how the rule-based/cognitive approach works (award <strong>[1]</strong> for a less complete response)</em>.<br/><em>Award <strong>[1]</strong> for a reasonable conclusion that explains why the former approach is chosen</em>.</p>\n<p><em><strong>Example answer</strong></em><br/>The statistical model involves comparing the text to be translated against previously stored sets of text pairs (e.g. English and its French equivalent) and then selecting the most probable translation;<br/>The cognitive model involves establishing all the rules of each of the languages and then breaking down each section of text to establish its grammatical structure and then replacing the text with text that has an equivalent structure from the other language;<br/>The second approach has not proved particularly successful for two reasons. The first is that the process of establishing a clear set of rules is extremely labour intensive.<br/>The second is that the process can be ruined by the problems of context, double meanings and non-standard language;<br/>The first approach was taken because the company has stored an enormous set of validated text in different languages and the increase in processing power which allows this corpus to be searched and processed;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.2.HL.TZ0.9",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline the purpose of the memory address register (MAR) in the central processing unit (CPU).</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>The MAR holds the memory location of data/instructions;<br/>…that need to be accessed (read/write) (fetch/store);</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates mostly achieved at least one mark here, but a common error noted was some candidates wrote that the ‘MAR stored data’ rather than the address of the data.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.7",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>With reference to the bowtie model of the web, consider the following graph. It represents a snapshot of popular sites about a specific topic.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>After two months, the graph has evolved into the one shown below.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>We can interpret the graph as follows:<br/>Each node represents a document and each outgoing arrow represents a hyperlink in the document.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the nodes in the strongly connected core.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the set of OUT nodes.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why the edge between node 2 and node 1 is a tendril.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> reasons why an edge may disappear in the new graph, for example the edge between node 5 and node 4.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State how many hyperlinks are in the document corresponding to node 6.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Power laws are often used to model phenomena occurring in very large networks and predict their evolution. Power laws may be suitably applied in different cases, in the context of the World Wide Web.</p>\n<p>With reference to the relation between the number of documents in the web and the number of hyperlinks in each of them, suggest how power laws may help to explain the shape of the World Wide Web.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for all three correct</em>.<br/>3, 5, 6</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for both correct.</em><br/>4, 8</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>No;<br/>Because 2 reaches the node 3 that is in the SCC;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>There is no longer a <span style=\"text-decoration:underline;\">link</span> between 5 and 4;<br/><em>because</em><br/>5 has deleted its link / 5 no longer finds 4 interesting/relevant;<br/>4 has changed its URL;<br/>4 has removed itself from the internet;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>4</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[5 max]</strong></em>.<br/><em>Award up to <strong>[1]</strong> for showing understanding of what a power law is, <strong>[2]</strong> for </em><em>addressing both ideas of incremental web and preferential connectivity (award </em><em>only <strong>[1]</strong> if one is addressed), and <strong>[2]</strong> for discussing them in context <strong>AND </strong></em><em>mentioning some element of the web graph</em>.</p>\n<p>(<span style=\"text-decoration:underline;\">Incrementality of web</span>): Number of nodes in the web increases (nodes are not deleted) / New nodes (documents) have hyperlinks that connect to existing nodes in the web;</p>\n<p>(<span style=\"text-decoration:underline;\">preferential connectivity</span>): This connectivity happens following some preferential element/affinity/alikeness (e.g. common theme) and over time it induces an aggregation of nodes;</p>\n<p>(<span style=\"text-decoration:underline;\">Incrementality and preferential connectivity</span>): Have the consequence that the <strong>SCC</strong> grows;</p>\n<p>(Nodes are not deleted, but) some of the hyperlinks in documents may be changed/deleted/break over time, this may produce <strong>isolated nodes</strong>;</p>\n<p>(<span style=\"text-decoration:underline;\">Power law – proportionality</span>): Relates two quantities, x and y, when y is proportional to x^c, for some constant c;</p>\n<p>The probability for a <strong>new</strong> document N to be connected to some document M (with a certain out-degree) is proportional/depends on the probability that the hyperlinks in N to connect to M (i.e. the sum of the out-degrees of the nodes reached from N, recursively);</p>\n<p>Therefore, a few nodes receive many in-links (because many nodes link to them directly or indirectly based on preference), whereas nodes that have a few in-links are probably new;</p>\n<p>Niche themes/new themes with new language/obsolete themes (when theme is a preference) typically bypass the SCC, making <strong>tendrils and tubes</strong>;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "17N.2.HL.TZ0.13",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-5-analysing-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The online edition of a newspaper includes a collection of audio podcasts. These podcasts are interviews with artists and scientists and last for up to 10 minutes. They may have been provided by other broadcasters and agencies.</p>\n</div><div class=\"specification\">\n<p>At any time, no more than eight podcasts are available on the online edition of the newspaper.</p>\n</div><div class=\"specification\">\n<p>The podcasts can either be downloaded or streamed.</p>\n</div><div class=\"specification\">\n<p>The podcast can be stored online using either lossy or lossless compression.</p>\n</div><div class=\"specification\">\n<p>A person is streaming one of these podcasts at home. However, he is experiencing buffering problems, where the podcast keeps stopping and starting.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> actions relating to the source of these podcasts that should be taken by the newspaper before publishing them.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> technical reason for restricting the number of podcasts to eight.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>one</strong> format for an audio file.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare these <strong>two</strong> approaches for a person who downloads or streams these podcasts.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> reason for this problem.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>These podcasts are normally displayed on the website in the chronological order in which they were added, with the most recent on top. However, users who regularly access the site for science podcasts, may see them presented in a different order, with all the scientific ones on top.</p>\n<p>With reference to the technology involved, explain how this is made possible.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Provide a reference to the source/provider;<br/>Obtain permission from the interviewee;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>To better control access to their servers;<br/>Because it could be cause of bottleneck on the server / to reduce/minimize risks of DDoS;</p>\n<p>To better manage the UI;<br/>So that the offer of podcasts is well visible also from small devices;</p>\n<p>To have a smaller system that is easier to maintain;<br/>That can be maintained more effectively also remotely by one person;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[1 max]</strong></em>.<br/>(accept for general sound format:) MP3, FLAC, WAV, WMA;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[5 max]</strong></em>.<br/><em>Award up to <strong>[4 max]</strong> for comparing lossless and lossy</em>.<br/><em>Award <strong>[1]</strong> for a conclusion with reference to the scenario</em>.</p>\n<p>In terms of audio quality for spoken language there is not much difference in using lossy or lossless compression/ lossless compression does not really bring benefit to the spoken audio;</p>\n<p>A minor benefit could be in using lossy compression in relation to transmission while downloading (and also in streaming);</p>\n<p>And it is relevant, in general, in a situation with low bandwidth;</p>\n<p>However, these files are small in size anyway, because their duration is limited to 10 minutes;</p>\n<p>And this suggests that for the specific nature and size of the files (spoken and 10 minutes duration) lossy might be slightly preferable for some users for downloading without compromising on quality of audio.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying a reason why buffering may occur and <strong>[1] </strong>expansion/example up to <strong>[2 max]</strong></em>.</p>\n<p>Too many people are using their own Internet access point at home simultaneously;<br/>Possibly on different devices, including tablets, smartphones on WiFi;</p>\n<p>There is low bandwidth because it is peak time;<br/>Possibly too many people are downloading simultaneously;</p>\n<p>Old router/modem/computer / outdated software may slow performance;<br/>Computer that is not protected by antivirus may have performance affected by malware;<br/>Performance;</p>\n<p>There are too many applications running simultaneously on the computer;<br/>So, memory is insufficient and one should close some applications;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/><em>Award up to <strong>[2 max]</strong> for the use of dynamic scripting. <br/>Award up to <strong>[2 max]</strong> for the means of tracking a person’s preferences.</em></p>\n<p><strong>Dynamic web pages / scripting</strong><br/>Podcasts are associated to XML objects;<br/>So, that the list of podcasts can be processed by scripts that can re-arrange the order of the XML objects;<br/>To present them in a way that takes into account the previous uses from the user;<br/>By monitoring their preferences, over time;</p>\n<p><strong>Tracking a person’s preferences</strong><br/>For example, counting the clicks and themes to extract regularities / support data analytics;<br/>That can be identified for example by the IP of their device when this is not anonymised;<br/>And also stored in the history of the browser/by use of cookies;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.7",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-4-the-evolving-web",
|
||
"c-1-creating-the-web",
|
||
"c-3-distributed-approaches-to-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>State the part of the central processing unit (CPU) that is responsible for carrying out calculations.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>Arithmetic and Logic Unit/ALU; </p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>A well answered question.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.8",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A company has 600 employees whose names are currently stored using a collection called <code>NAMES</code>. The names are stored as surname, first name. For example: Smith, Jane, Uysal, Rafael, Ahmed, Ishmael, Jonsonn, Sara, …</p>\n</div><div class=\"specification\">\n<p>The names in the collection are kept in a random order. However, it would be more useful if they were kept in alphabetical order.</p>\n</div><div class=\"specification\">\n<p>The company’s staff list is now organized in the arrays in alphabetical order.</p>\n<p>A binary search was used to find a specific name in the array.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a pseudocode algorithm that will store the surnames in one array and first names in another.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a pseudocode algorithm that will sort the surnames into alphabetical order using the <em>bubble</em> <em>sort</em> method. The order of the first names must also be changed so that they keep the same index as their corresponding surname.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the process a binary search would follow to find a record in the surname array.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> benefit of using sub-programmes to implement your algorithms from parts (a) and (b).</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em><br/>Collection method <code>NAMES.getNext() / NAMES.getData()</code> correctly used;<em><strong><br/></strong></em>Correct loop;<br/>Correct use of index (in both arrays);<br/>Correct assignment in array for surnames;<br/>Correct assignment in array for first names;</p>\n<p><strong>Note</strong>:<br/>Award 1 mark in case that string methods are used to separate ‘name’ and ‘surname’ in the data item.</p>\n<p><em>Example answer 1</em>:</p>\n<pre>NAMES.resetNext() // reset and<br/>SURNAME[600] //initialization of arrays<br/>FIRSTNAME[600] //may not appear in candidates’ responses<br/>COUNTER = 0<br/>loop while NAMES.hasNext()<br/> SURNAME[COUNTER] = NAMES.getNext()<br/> FIRSTNAME[COUNTER] = NAMES.getNext()<br/>COUNTER = COUNTER + 1<br/>end loop</pre>\n<p><em>Example answer 2</em></p>\n<pre>NAMES.resetNext()<br/>loop COUNTER from 0 to 599<br/> SURNAME[COUNTER] = NAMES.getNext()<br/> FIRSTNAME[COUNTER] = NAMES.getNext()<br/>end loop</pre>\n<p><em>Example answer 3 (assumes that items in the collection are objects- two attributes: surname and first name)</em></p>\n<pre>I = 0<br/>loop while NAMES.hasNext()<br/> X= NAMES.getData()<br/> SURNAME[I] = X.surname<br/> FIRSTNAME[I] = X.firstname<br/> I = I + 1<br/>end loop</pre>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max] </strong></em><br/>Correct outer loop;<br/>Correct inner loop;<br/>Checking of surname order;<br/>Swapping surnames if necessary;<br/>Swapping corresponding names;<br/>Correct use of flag;</p>\n<p><em>Example 1</em>:</p>\n<pre>loop I from 0 to 599<br/> loop C from 0 to 598-I //accept 598<br/> if SURNAME[C] > SURNAME[C + 1] then<br/> TEMP1 = SURNAME[C]<br/> TEMP2 = FIRSTNAME[C]<br/> SURNAME[C] = SURNAME[C + 1]<br/> FIRSTNAME[C] = FIRSTNAME[C + 1]<br/> SURNAME[C + 1] = TEMP1<br/> FIRSTNAME[C + 1] = TEMP2<br/> end if<br/> end loop<br/>end loop</pre>\n<p><em>Example 2</em>:</p>\n<pre>FLAG = TRUE<br/>loop while FLAG = TRUE<br/> FLAG = FALSE<br/> loop COUNTER from 0 to 598<br/> if SURNAME[COUNTER] > SURNAME[COUNTER + 1] then<br/> TEMP1 = SURNAME[COUNTER]<br/> TEMP2 = FIRSTNAME[COUNTER]<br/> SURNAME[COUNTER] = SURNAME[COUNTER + 1]<br/> FIRSTNAME[COUNTER] = FIRSTNAME[COUNTER + 1]<br/> SURNAME[COUNTER + 1] = TEMP1<br/> FIRSTNAME[COUNTER + 1] = TEMP2<br/> FLAG = TRUE<br/> end if<br/> end loop<br/>end loop</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em></p>\n<p><em><strong>Example 1</strong></em>:<br/>Calculate the index of the middle point in the array SURNAME: (first + last)/2;<br/>Compare surname found with the one stored at middle point;<br/>If greater than the value at the middle point, search the upper half of the array (right side) by calling the binary search method again with a new first index (first = middle + 1);<br/>If smaller than the value at the middle point, search the lower half of the array (left side) by calling the binary search method with a new last (last = middle −1);<br/>if found algorithm terminates;</p>\n<p><em><strong>Example 2</strong></em>:<br/>Find the centre point of the array SURNAME[ ];<br/>Compare surname to be found with the current name in SURNAME[ ];<br/>If correct surname found => STOP;<br/>Else if surname to be found is greater than the current name in SURNAME[ ]eliminate lower half of array from search and repeat algorithm;<br/>Else if surname to be found is less than the name in SURNAME[ ] eliminate upper half of array from search and repeat algorithm;</p>\n<p><em>Note: Allow a mark for provision for name not found</em>;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em></p>\n<p><em>1 mark for a benefit (such as reusability, modularity, maintainability, readability)</em><br/><em>1 mark for an expansion</em>.</p>\n<p>Example answer:<br/>These sub-programs (sorting/searching) could be used in (many) other programs;<br/>Which saves programmer’s time/ effort;</p>\n<p> </p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates who realised that the data from the collection was to be accessed sequentially with the first item stored in one of two arrays, the second item in the second array, the third item in the first array, and so on, until the collection was empty, scored high marks for this question. Some candidates did not correctly apply standard collection methods so lost marks.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates who scored highly in part a. also scored highly for this part. However, this question did see the full range of possible marks awarded. Candidates who were unable to complete the whole algorithm correctly generally achieved some of the marks, typically for performing correct swaps during the sort, or for correctly initialising and implementing one or both of the loops.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question required a description for the binary search algorithm and was generally well answered with a high proportion of candidates achieving full marks. A small number of candidates incorrectly described a sorting algorithm, while others incorrectly described a linear search.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates achieved at least one of the marks for this question, with many acquiring both marks. Candidates most frequently recognised that the sub-programs could be re-used in other programs, therefore saving programming time.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.13",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-1-general-principles",
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Compilers translate source code into object code. Identify <strong>two</strong> other operations performed by a compiler.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Pre-processing;<br/>Lexical analysis;<br/>Parsing;<br/>Semantic analysis;<br/>Syntax analysis;<br/>Linking;<br/>Optimisation;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>A good range of the possible correct answers for this question was seen, but the most common correct answer was ‘syntax analysis’. However, a high proportion of the answers for this question were too general, or they repeated the example given in the question.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.9",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The average weekly consumption for a family of four is 2700 litres of water. This includes the water needed for domestic cleaning, personal hygiene, cooking and drinking.</p>\n<p>An online software tool is available to help families calculate how much water they are using for regular activities that require the supply of water. The software tool includes a model which estimates the water usage. A simulation can be run using this model.</p>\n</div><div class=\"specification\">\n<p>The data given below estimates the amount of water (in litres) needed for different household activities:</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>By using the data in the table, a family uses a spreadsheet to run some simulations of how to distribute the use of water.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the scenario described above, explain the difference between a model and a simulation.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the choice of data in the table may affect the quality of the simulation.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how a simulation in a spreadsheet can be organized so that the family can ensure a consumption of no more than 2700 litres per week.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The same spreadsheet is used by a group of four young people who share a house. The simulation, however, does not reflect their actual situation and the weekly target is often exceeded.</p>\n<p>Identify <strong>two</strong> reasons why the simulation may not reflect the actual situation in this case.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The model is a static description of some rules;<br/>In this case a list of appliances and their water consumption (min or max);<br/>Whereas the simulation is the use of that model;<br/>With input from real parameters (such as those that families may input);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>There may be missing data:<br/>For example, watering plants (allow any suitable example);<br/>The consequences, e.g. the totals will be underestimated;<br/>The data may be inaccurate;<br/>For example, the shower times may exceed the stated;<br/>The consequence, e.g. the results of the simulation may not be valid;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The answer shows the use of columns and rows;<br/>The data from part (b) is included together with the addition of a <code>TimesPerWeek</code> variable;<br/>Weekly total formula for each variable is included;<br/>Overall weekly total has correct formula;<br/><code>TimesPerWeek</code> is adjusted until target is met;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/><em>Individual and individualistic use</em>:<br/>They don’t know each other, and they do their laundry separately, not full load;<br/>They don’t cook together and consume more water consequently;<br/>Somebody washes the car every week without telling the others;</p>\n<p><em>Special occasions</em>:<br/>Some of them may be athletes and need to wash the sport gear separately;<br/>Somebody invites friends over night/for dinner and the water consumption increases;</p>\n<p><em>Technical reasons</em>:<br/>There are water leaks in the house and they are not aware about them;<br/>The counter was manipulated by the landlord years ago;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.5",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> ways that user documentation may be provided.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>On a CD/DVD/Blu-ray disc;<br/>Through embedded help files;<br/>Online/website;<br/>Physical/printed media;</p>\n<p><em>Note to examiners: accept answers relating to methods of supplying or media used to present user documentation. Do not accept answers related to training</em>.</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were able to name at least one and often two methods for the provision of user documentation.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.10",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The details of hotel stays during the current year are stored in the variable <code>allVisits</code> which is an array of the Visits class. <code>allVisits</code> is used in determining the total points awarded in the current year.</p>\n<p>The <code>Visits</code> class is outlined below:</p>\n<pre><strong>public class</strong> Visits<br/>{<br/><strong> private</strong> String hotelCode; // id of the hotel<br/><strong> private</strong> <strong>int</strong> days; // number of days of the visit<br/><strong><br/> public</strong> Visits(String h, <strong>int</strong> d)<br/> {<br/> hotelCode = h;<br/> days = d;<br/> }<br/><strong> <br/> public int</strong> getDays()<br/> {<br/><strong> return</strong> days;<br/> }<br/>}</pre>\n</div><div class=\"specification\">\n<p>The main (driver) class manages the <code>Points</code> and <code>Visits</code> classes. It contains the following code:</p>\n<pre>Points[] allPoints = <strong>new</strong> Points[10000]; // declared globally<br/><br/>allPoints[0] = <strong>new</strong> Points(\"m100\");<br/>allPoints[1] = <strong>new</strong> Points(\"m101\",5000);<br/>allPoints[2] = <strong>new</strong> Points(\"m102\",2000);<br/><br/>Visits v1 = <strong>new</strong> Visits(\"h003\", 3);<br/>Visits v2 = <strong>new</strong> Visits(\"h013\", 1);<br/>Visits v3 = <strong>new</strong> Visits(\"h013\", 2);<br/>Visits v4 = <strong>new</strong> Visits(\"h005\", 6);<br/><br/>allPoints[0].addVisit(v1);<br/>allPoints[0].addVisit(v2);<br/>allPoints[0].addVisit(v3);<br/>allPoints[0].addVisit(v4);<br/>allPoints[1].addVisit(v1);<br/>allPoints[1].addVisit(<strong>new</strong> Visits(\"h004\",6));</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a UML diagram for the <code>Visits</code> class.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the output given by the following statement:</p>\n<p><code>System.out.println(allPoints[2].getMemberId())</code>;</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the output given by the following statement:</p>\n<p><code>System.out.println(allPoints[0].getBonusPoints())</code>;</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the output given by the following statement:</p>\n<p><code>System.out.println(allPoints[1].getAllVisits(1).getDays())</code>;</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method <code>calculateTotalPoints()</code>, in the <code>Points</code> class, which will calculate and return the total number of points awarded so far in the current year.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for three compartments, <strong>[1]</strong> for correct + and −, and <strong>[1]</strong> for correct contents</em>.</p>\n<p><img src=\"\"/></p>\n<p><em><strong>Note</strong><strong>:</strong></em></p>\n<ul>\n<li><em>Allow variations in the format, but must use + / −.</em></li>\n<li>\n<em>Accept additional getters/setters, but the given content must be present</em>.</li>\n</ul>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>m102;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>0;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>6;</p>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><span style=\"text-decoration:underline;\"><em>Example 1</em><em>:</em></span></p>\n<pre><strong>public int</strong> calculateTotalPoints()<br/>{<br/><strong> int</strong> totalPoints = 0;<br/><strong> for</strong> (<strong>int</strong> x = 0; x < y; x++)<br/> {<br/> totalPoints = totalPoints + allVisits[x].getDays();<br/> }<br/> totalPoints = totalPoints * 1000 + bonusPoints;<br/><strong> return</strong> totalPoints;<br/>}</pre>\n<p><em>Award marks for <strong>correctly</strong> including the following</em>:<br/>Signature + matching return;<br/>Loop through the number of visits (y); // <em>do not allow length statements;</em><br/>Any use of <code>allVisits</code> array;<br/>Correct update of <code>totalPoints</code> (with or without bonusPoints);<br/>Inclusion of bonus points <span style=\"text-decoration:underline;\">outside</span> of the loop (or if the loop is absent);</p>\n<p><span style=\"text-decoration:underline;\"><em>Example 2</em><em>:</em></span></p>\n<pre><strong>public int</strong> calculateTotalPoints()<br/>{<br/><strong> int</strong> totalDays = 0;<br/><strong> for</strong> (<strong>int</strong> x = 0; x < y; x++)<br/> {<br/> totalDays = totalDays + allVisits[x].getDays();<br/> }<br/> totalPoints = totalDays * 1000 + bonusPoints;<br/><strong> return</strong> totalPoints;<br/>}</pre>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.11",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-1-objects-as-a-programming-concept",
|
||
"d-3-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A manufacturing company that produces several products is using spreadsheet software to model its finances. This includes calculations that will estimate different quantities including the profit that the company will make in future years.</p>\n<p>The model involves the use of spreadsheet software which will be organized using different sheets for different areas of the company’s finances. Previously less sophisticated methods were used to keep track of costs and sales.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>By including examples where appropriate, describe a basic structure for this model.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Suggest how the reliability of the model could be tested.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The company has established certain profit targets that it wishes to achieve over the next three years.</p>\n<p>Explain how this model can be used to investigate different strategies that will reach these targets.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6 max]</strong></em>.<br/>Different sheets will be dedicated to different categories, e.g. salaries, running<br/>expenses, sales, different products, different months etc.;<br/><em><strong>Note</strong>: Award <strong>[2 max]</strong> for identifying at least two categories</em>.</p>\n<p>Each sheet will contain a list of items for that category including associated values;<br/>Formulas will be included as necessary;<br/>Each sheet/category will include a formula that totals the values in that category;<br/>Intermediate values will be calculated, e.g. tax to be paid;<br/>The final profit will be determined from the previous totals;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Figures from previous years can be entered into the model;<br/>With the results checked against the previously calculated results;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>Different (“what-if”) scenarios can be run;<br/>In which the values of different variables are changed;<br/>For example, the number of items sold / the increase in the level of salaries;<br/><em><strong>Note</strong>: Award <strong>[2 max]</strong> for identifying at least two items</em>.</p>\n<p>Selling prices/other (acceptable) parameters can be adjusted to achieve the desired profit;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.5",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-1-the-basic-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline <strong>one</strong> reason why protocols are used in communications between computers.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>To provide a set of rules/procedures;<br/>To enable two or more different electronic devices/computers/entities to understand each other during data transfer / enable successful communication;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were generally able to state that protocols are needed to provide rules and many candidates went on to give an appropriate expansion for the second mark.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.11",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> characteristics of a personal area network (PAN).</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Smallest type of network;<br/>Consists of connected devices in close proximity to the individual using them;<br/>Connected via Bluetooth/wireless;<br/><em>Suitable example</em>: smartphone to car connection;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates generally recognised that a PAN made use of Bluetooth or wireless, or that it covered a very small area. Unfortunately, answers with more than one marking point being covered were rare.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.12",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Explain how data is transmitted by packet switching. </p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>A message/the data is broken into a number of parts;<br/>Which are sent independently;<br/>…over the optimum route for each packet;<br/>The individual parts are reassembled at the destination;<br/>Each packet contains the (IP) address of both the sender and recipient; </p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates demonstrated that they understood what packet switching was but didn’t always provide sufficient distinct information to achieve full marks. However, the vast majority of candidates achieved at least two marks.</p>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.13",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A large mail order company is concerned about the security of its stored data.</p>\n</div><div class=\"specification\">\n<p>The company decides to improve its service by introducing a new user interface for its customers and has developed this interface to the point that it needs to be tested by users who are outside of the company.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> possible causes of data loss.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> backup strategies that may be used to limit data loss.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why beta testing is used to gather feedback for the new user interface.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> consequence of not involving end-users in the design and testing stages.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> features that could be used to improve the accessibility of the new user interface.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>Malicious activities;<br/>An unauthorized user gaining access to data and deleting/altering it;</p>\n<p>Natural disasters / earthquake / storm / power loss;<br/>Causing the system to crash and destroy data;</p>\n<p>Malware/viruses/spyware/worms;<br/>Which infiltrate and damage the data;</p>\n<p>Human error;<br/>Accidental deletion/overwriting of files;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>Copies of backup could be kept off-site/cloud backup;<br/>Unlikely that the other site would be affected by the natural disaster/can be reloaded/reinstalled if needed;</p>\n<p>Incremental backup only backs up data that has changed;<br/>Therefore, requiring less storage capacity / can be completed more quickly than a complete backup;</p>\n<p>Failover system/mirrored system/disk mirroring;<br/>A duplicate copy to be used in the event the main system fails;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Testers outside the organization use the operating system in a “real world” setting;<br/>Enables feedback to be given to the developers;<br/>So that the software can be improved/corrected/debugged;<br/>Before it is finally released;<br/>“Real world” testers may find more bugs as the system is used in ways not originally intended / tested;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>The software may not work as expected / may not be better than the existing software / may not meet user requirements / expectations;<br/>The software may be missing some key features;<br/>The software may not be user friendly;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Touch screens;<br/>Voice recognition;<br/>Text-to-speech;<br/>Braille keyboard<br/>A colour-blind option<br/>Large font option; </p>\n<p><em>Note to examiners: allow other correct accessibility features</em></p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were usually able to name two causes of data loss, however, their expansions were not always as specific or relevant as they could be, to achieve full marks. For example, the question was about data loss and the minimisation of this through the use of backup. Therefore, responses involving data being stolen would not be appropriate.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were able to name and correctly expand at least one appropriate backup strategy, however, candidates should be careful in this type of question that their responses are appropriate to the scenario and that both methods quoted are different, for example, an organisation in which data was constantly changing, such as the case here, would not be relying on hard copy as a method of backup. In addition, storing backup data offsite, or storing data on a cloud-based system are really the same marking point.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally demonstrated their understanding of what beta testing is and where it fits in the development process, they should, however, be careful to not give generic responses and make sure that their answers match the scenario. Some candidates lost out by simply restating aspects given in the question.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally recognised that not involving end-users in design and testing may mean that the final product did not meet user requirements, but not many were able to expand on this sufficiently to gain the extra mark by saying, for example, it may have missing features.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>There are many correct possible answers to this question, including touch screens, braille keyboards and text-to-speech systems. A surprisingly large number of candidates failed to recognise that this was being asked, and gave incorrect answers, such as GUI, or left it blank.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.14",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations",
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>BesTea</em> is a company that sells tea and tea-related accessories online. Users browsing the website encounter the following URL:</p>\n<p style=\"text-align: center;\">https://www.BesTea.com/customer/pages/delivery</p>\n</div><div class=\"specification\">\n<p>A person enters the URL for <em>BesTea</em> into their browser.</p>\n</div><div class=\"specification\">\n<p>The logos of the credit and debit cards accepted by <em>BesTea</em> are displayed as images in the footer of all of its web pages.</p>\n</div><div class=\"specification\">\n<p>The <em>BesTea</em> website includes a shopping basket facility that enables users to make purchases.</p>\n<p>The following fragment of PHP code is present in the script that allows users to place a completed order:</p>\n<pre><?php<br/> …<br/>$_SESSION['sessionUserID'] = new_random_number();<br/>$query = $db -> query (\"SELECT * FROM users_db WHERE id = \" <br/>.$_SESSION['sessionUserID']);<br/>$userRecord = $query -> fetch_record();<br/>…<br/>></pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how this URL provides security in communication over the Internet.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the steps that the Domain Name System (DNS) server will take in order to locate the correct IP address for this request from the browser.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how the footer of a web page can be made identical across all pages of a website.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Suggest the function of this fragment of code.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Users may perform several actions on their shopping baskets. These actions require interaction with a central database of products. Each record in this database includes the identifier, the name and the price of one of these products.</p>\n<p>Consider the following fragment of code:</p>\n<pre><<br/>$basket = new Basket<br/> …<br/><br/>If $_REQUEST['action'] == 'removeBasketItem' && !empty($_REQUEST['id']){<br/>remove($basket, $_REQUEST['id']);<br/>header(\"view_basket.php\");<br/>}<br/>></pre>\n<p>From the code, identify the information that the user has provided.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>HTTPS authenticates the identity of the website;<br/>And encrypts data that are transmitted between web browser and web server/between two parties;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for step that the Domain Name System (DNS) server will take in order to locate the correct IP address for this request from the browser up to <strong>[4 max]</strong></em>.</p>\n<p>The DNS server configured to the browser’s computer / the ISP (Internet Service Provider) checks through its own database to see if the (domain) name is there;<br/>If it is, it will return the <span style=\"text-decoration:underline;\">corresponding</span> IP address to the browser;<br/>If it isn’t the request is passed onto the next DNS server (in the hierarchy);<br/>This continues until the (domain) name is found;<br/>Or the top level / authoritative DNS server if reached;<br/>When IP address is found, it is sent back to the original DNS server;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>The required layout style for the footer is saves as a CSS file;<br/>Each time the footer section/element appears it calls this CCS file;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each comment that indicates the function of the code up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> realising the modelling centred on a session (intuition of what <code>$_SESSION[]</code> is)</em><br/><em>Award <strong>[1]</strong> realising that session user identifier shall be unique. </em><br/><em>Award <strong>[1]</strong> realising the existence of users_db.</em><br/><em>Award <strong>[1]</strong> realising that this database is interrogated with this session identifier to retrieve all fields of the record;</em><br/><em>Award <strong>[1]</strong> to instantiate a variable <code>$userRecord</code>.</em></p>\n<p>The shopping basket is modelled centred on the “session”;<br/>A global array <code>$_SESSION</code> exists, holding a session identifier associated with any user;<br/>And a new <code>sessionUserID</code> is added to the array and instantiated by a unique value for identifier;<br/>That is generated by the function new <code>random_number()</code>;<br/>This element of the array <code>$_SESSION[]</code> is used to retrieve in the user db (users database) the entire record for the user;<br/>Relative to the user and specific to that particular session;<br/>And used to instantiate the variable <code>$userRecord</code> for further processing;<br/>For example the final billing or confirmation of payment/dispatch.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<pre><em>Award up to <strong>[2 max]</strong></em>.<br/>The <span style=\"text-decoration:underline;\">identifier</span> “id” that is passed in the variable $_REQUEST['id'];<br/>And the <span style=\"text-decoration:underline;\">specific action</span> that uses the value “<code>removeBasketItem</code>”;</pre>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.8",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An airport uses an object-oriented program to keep track of arrivals and departures of planes. There are many objects in this system and some are listed below.</p>\n<p><img src=\"\"/></p>\n<p>The code below outlines the <code>Arrival</code> class used in this program.</p>\n<pre><strong>public class</strong> Flight<br/>{ <strong>private</strong> String id;<br/><strong> public</strong> String getId() {<strong>return this</strong>.id;}<br/> // ... more variables, accessor and mutator methods<br/>}<br/><strong><br/>public class</strong> Arrival<br/>{ <strong>private</strong> Flight myFlight;<br/><strong> private</strong> String sta; // Scheduled Time of Arrival (\"hh:mm\")<br/><strong> private</strong> <strong>int</strong> runway;<br/><strong> private</strong> String gate;<br/><strong> private int</strong> delay;<br/><strong> private boolean</strong> landed;<br/><br/><strong> public</strong> Arrival(Flight myFlight, String sta)<br/> { <strong>this.</strong>myFlight = myFlight;<br/><strong> this.</strong>sta = sta;<br/><strong> this.</strong>runway = 0;<br/><strong> this.</strong>gate = <strong>null</strong>;<br/><strong> this.</strong>delay = 0;<br/><strong> this.</strong>landed = <strong>false</strong>;<br/> }<br/><br/><strong> public void</strong> addDelay(<strong>int</strong> newDelay)<br/> { <strong>this.</strong>delay = newDelay;<br/> }<br/><br/><strong> public</strong> String getETA()<br/> { // calculates the Estimated Time of Arrival (ETA) of the flight<br/> // by adding the delay to the sta and returning the result as a<br/> // String (\"hh:mm\")<br/> }<br/><br/><strong> public int</strong> compareWith(String flightID)<br/> { <strong>if</strong> (myFlight.getID().equals(flightID)) { <strong>return</strong> 0; }<br/><strong> else</strong> { <strong>return</strong> 1; }<br/> }<br/><br/><strong> public int</strong> compareWith(Arrival anotherArrival)<br/> { // missing code<br/> }<br/><br/> // ... plus accessor and mutator methods<br/>}</pre>\n</div><div class=\"specification\">\n<p>The code below outlines part of the <code>FlightManagement</code> class used in this program.</p>\n<p>For the purposes of this exam only arriving flights are being considered.</p>\n<pre><strong>public class</strong> FlightManagement<br/>{<br/><strong> private</strong> Arrival[] inbound; // array of inbound airplanes<br/><strong> private int</strong> last = -1; // index of last used entry<br/><strong><br/> public</strong> FlightManagement()<br/> { inbound = <strong>new</strong> Arrival[200];<br/> }<br/><strong><br/> public void</strong> add(Arrival newArrival)<br/> { // missing code that adds the newArrival to the array inbound<br/> // sorted by ETA, and updates last<br/> }<br/><br/> <strong>private int</strong> search (String flightID)<br/> { // missing code that searches the array inbound and<br/> // returns the index of the Arrival object with flightID<br/> }<br/><br/> <strong>public</strong> Arrival remove(String flightID)<br/> { Arrival result;<br/> <strong>int</strong> index = search(flightID);<br/> result = inbound[index];<br/><strong> while</strong> (index < last)<br/> { inbound[index] = inbound[index + 1];<br/> index++;<br/> }<br/> last--;<br/> <strong>return</strong> result;<br/> }<br/><br/> // ... many more methods<br/>}</pre>\n<p>The method <code>search</code> in the <code>FlightManagement</code> class searches the array <code>inbound</code> and returns the index of the <code>Arrival</code> object with the given <code>flightID</code>.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the general nature of an object.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> disadvantages of using Object Oriented Programming (OOP).</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage of using modularity in program development.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the relationship between the <code>Flight</code> object and the <code>Arrival</code> object.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a UML diagram to represent the <code>Arrival</code> object.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method <code>search</code> implementing a linear search. Use the first <code>compareWith()</code> method in the <code>Arrival</code> object.</p>\n<p>You may assume that an <code>Arrival</code> object with the given <code>flightID</code> exists in the array <code>inbound</code>.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage of using a binary search.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> disadvantage of using a binary search.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.ii.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[1]</strong> for each part of a suitable definition up to <strong>[2 max]</strong></em>.<br/>An object is an abstract entity;<br/>and its components are data and/or actions;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[1]</strong> for identifying each disadvantage and <strong>[1]</strong> for an elaboration of this disadvantage, up to <strong>[2 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.<br/>Unsuitable for minor projects;<br/>since OOP increases complexity for little gain;</p>\n<p>OOP programs are larger than other programs;<br/>and therefore slower;</p>\n<p>OOP programs take more effort to construct;<br/>because of the decomposition needed to achieve abstraction;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying an advantage and <strong>[1]</strong> for an elaboration of this advantage up to <strong>[2 max]</strong></em>.</p>\n<p><em><strong>Example answers</strong></em>:<br/>Faster development;<br/>Because different programming teams can work on different modules;</p>\n<p>Easier to debug;<br/>Because the smaller modules will have fewer mistakes than one big program;</p>\n<p>Easier to update (in the future);<br/>Because it is easier to update a module than the full program;</p>\n<p>Re-usability;<br/>Modules can be stored in libraries and reused for different programs;</p>\n<div class=\"question_part_label\">a.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[1]</strong> for any indication of aggregation</em>.</p>\n<p><em><strong>Example answer</strong></em>:<br/>The <code>Arrival</code> object has/stores a <code>Flight</code> object;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for including 3 distinct sections.</em><br/><em>Award <strong>[1]</strong> for including a component with all variables.</em><br/><em>Award <strong>[1]</strong> for including a component with all listed methods.</em><br/><em>Award <strong>[1]</strong> for indicating private/public using + / −.</em><br/><em>Don't penalize the absence of accessor and mutator methods.</em></p>\n<p><em><strong>Example answer</strong></em>:</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for a while loop.</em><br/><em>Award <strong>[1]</strong> for correctly testing the <code>flightID</code> using <code>compareWith()</code>.</em><br/><em>Award <strong>[1]</strong> for incrementing the loop counter.</em><br/><em>Award <strong>[1]</strong> for a return statement.</em></p>\n<p><em><strong>Example answer</strong></em>:</p>\n<pre><strong>private int</strong> search(String flightID)<br/>{ <strong>int</strong> i = 0;<br/><strong> while</strong> (inbound[i].compareWith(flightID) != 0)<br/> { i++; }<br/><strong> return</strong> i;<br/>}</pre>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for identifying an advantage of using a binary search and <strong>[1]</strong> for an elaboration of the advantage up to <strong>[2 max]</strong></em>.</p>\n<p>Binary search is much faster than sequential search;<br/>Because it halves the search range for every comparison;</p>\n<div class=\"question_part_label\">e.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for identifying a disadvantage of using a binary search and <strong>[1]</strong> for an elaboration of the disadvantage up to <strong>[2 max]</strong></em>.</p>\n<p>However, it is not applicable to unsorted data sets;<br/>Because the data must be sorted first which adds to computational cost;</p>\n<div class=\"question_part_label\">e.ii.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.ii.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.10",
|
||
"topics": [
|
||
"option-d-object-oriented-programming",
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-2-features-of-oop",
|
||
"d-1-objects-as-a-programming-concept",
|
||
"d-3-program-development",
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Weather forecasters use computer models which are able to simulate future weather patterns. These forecasts were originally limited to the near future. However, modern systems can now produce long range forecasts.</p>\n</div><div class=\"specification\">\n<p>The simulation of the weather forecasting models produces specific data which can be output in a variety of ways.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Suggest <strong>two</strong> reasons why these simulations have improved both in their accuracy and their range.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Suggest why forecasts become less accurate the more long range they become.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Discuss whether historical data can be accurately used to forecast future weather.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>visualization</em>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With the help of examples, discuss how the development in the way such data is visualized has made the results of these simulations more accessible to the general public.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.ii.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>Modern computer systems have become increasingly more powerful;<br/>Which allows more complicated systems to be simulated;<br/>In a short/acceptable period;<br/>The understanding of (the science of) weather has steadily improved/more historic weather patterns can be accessed;<br/>Allowing more accurate modelling to take place;<br/>More data can now be retrieved;<br/>Through satellites, ground stations etc.;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Only the major/known variables can be input into the model;<br/>Approximations have to be made to represent complex processes;<br/>These or other minor/unknown variables will not have a significant effect in the short term;<br/>But will have (unknown) effects in the long-term/small errors have a cumulative effect over the long-term/butterfly effect;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each valid point discussed, and a further <strong>[1]</strong> up to <strong>[5 max]</strong> for a good expansion of this point</em>.</p>\n<p>Investigate past weather patterns in order to see if past forecasts were correct or not and make adjustments to your model appropriately;<br/>Look at specific events in the past (e.g. appearance of El Nino) to see how they affected future weather patterns in different areas, and then apply this to new occurrences of these events;<br/>However, historical data does not take into account new factors, such as how carbon emissions are contributing to global warming;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The representation of (abstract) data;<br/>In a way that is understandable by humans;</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Standard simulations produce numerical values (which are not easily understood by the general public);<br/><em>Modern simulations include</em><br/>Graphics that are related to the data output;<br/>e.g. rain drops/a smiling sun;<br/>CGI/animation can produce motion;<br/>e.g. showing a belt of rain crossing the country;<br/>Which are more easily understood by the general public;</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.ii.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.6",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations",
|
||
"b-3-visualization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The following flowchart represents a standard algorithm:</p>\n<p><img src=\"\" style=\"display: block; margin-left: auto; margin-right: auto;\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the table that traces the algorithm in the flowchart using an input value of 19.</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the purpose of the algorithm.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the algorithm from the flowchart using pseudocode. Add additional pseudocode to ensure that input is validated to only allow positive integers to be entered.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Efficiency is an important consideration when designing algorithms to ensure they don’t waste computer resources such as memory or processing time.</p>\n<p>Suggest <strong>two</strong> design considerations that could be made to an algorithm that would make it more efficient.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em></p>\n<p><em><strong><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></strong></em></p>\n<p><em>Award up to <strong>[4 max]</strong></em>:<br/>Correct table with correct first row;<br/>Rest of NUMBER column correct;<br/>Rest of DIGIT column correct;<br/>Rest of OUTPUT column correct;</p>\n<p> </p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>Converts denary number to (reverse) binary.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max] </strong></em><br/>Validation to check for positive numbers;<br/>Validation to check for integers;<br/>Loop for validation rules;<br/>Loop structure to continue while NUMBER > 1;<br/>Correct calculations/outputs inside loop;<br/>Correct output of last digit outside loop;</p>\n<p><em>Example answer</em>:</p>\n<pre>input NUMBER <br/>loop while NUMBER <= 0 OR NUMBER ≠ NUMBER div 1 <br/> output \"Please input another number, your entry is invalid \" <br/> input number <br/>end loop <br/>loop while NUMBER > 1<br/> DIGIT = NUMBER mod 2<br/> output DIGIT<br/> NUMBER = NUMBER div 2<br/>end loop<br/>output NUMBER</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em><br/>The algorithm could use loops;<br/>To remove the necessity to process extra lines of code;</p>\n<p>Use of arrays/data structures;<br/>So data can be stored/re-used/re-entered;</p>\n<p>Use of flags;<br/>To stop a search routine when an item has been found so that all elements don’t have to be searched;</p>\n<p><em>Mark as 2 and 2</em><em> </em></p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>A mixed set of responses was seen for this question, which was a trace table for a given algorithm presented as a flowchart. Most candidates achieved at least one mark, but many marks were lost through incomplete trace tables, or candidates not writing the complete output that the algorithm would produce.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A significant minority of candidates recognised that the algorithm was converting a denary number to binary. Other candidates described the process, almost line by line, that the algorithm followed, which is not the purpose of the algorithm.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A mixed set of results was seen for this question with most candidates achieving some of the marks. Many of these candidates provided a working loop with the correct calculations and outputs inside and outside of the loop. Some of these candidates also demonstrated some of the validation that was required, either to only allow positive numbers into the algorithm or making sure the number was an integer. Very few candidates checked for both of these things, and even fewer allowed for the number to be re-input if it wasn’t a positive integer, but simply stopped the algorithm.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates performed less well on this question which required candidates to describe aspects of program design that would make an algorithm more efficient, such as use of loops to avoid repeated lines of code, or use of flags to stop a loop, to prevent unnecessary iterations.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "21M.1.SL.TZ0.14",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Smart technologies can be used to illuminate the night. Street light intensity and coverage can both be controlled, depending on physical parameters, such as the time of the day, or weather conditions.</p>\n<p>The amount of pedestrians in the street or their activities could be further parameters used by algorithms for these type of applications.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Discuss the technologies that ambient intelligence uses in this specific scenario.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With a focus on privacy, discuss how traffic data from WiFi communication through smartphones can be used in this scenario.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>Sensors;<br/>Used to receive input for a physical parameter, such as daylight;<br/>Transceivers/microcontrollers;<br/>Directly on the lamppost, to be controlled remotely;<br/>Wireless network/remote control antenna/RFID;<br/>Position in each lamp along a street (or just the first), to communicate with both the central service centre (or all neighbouring lamps having a RF and communicate pairwise);<br/>Internet/servers;<br/>To connect the monitoring centre to the lamps; </p>\n<p><em><strong>Note</strong>: Do not accept: </em>LED light and permanent supply of power, as they are not directly related to CS/IT.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[4 max]</strong></em>.<br/><em>Award up to <strong>[2 max]</strong> for describing how the smartphones/WiFi could be used for street illumination</em>.<br/><em>Award up to <strong>[2 max]</strong> for a discussion on privacy/monitoring based on the data/algorithms used</em>.</p>\n<p><em><strong>For example</strong></em></p>\n<p><em><strong>How smartphones/WiFi is used in the scenario</strong></em><br/>Hot-spot traffic may provide an indication of how large the crowd moving in the street/zone is;<br/>Hopping from one connection to another may provide an indication of how and where the crowd may move;<br/>Therefore, this data may contribute to optimize the algorithm, which in turn could impact on the cost of public illumination, so it is an advantage for the collectivity;</p>\n<p><em><strong>Discussion on privacy/monitoring</strong></em><br/>Data on hotspots are provided by telecom companies;<br/>These data should already be the result of some analysis and be stripped of any private (personal) information;</p>\n<p>However, the company that controls the illumination would still have information on where the crowd is (in addition to the telecom) and this poses an issue of crowd monitoring;</p>\n<p>Worse, hotspots integrated directly on lampposts would provide a very fine-grained anchoring net, and presence/movement of individuals rather than crowds could be monitored (not their private information, necessarily);</p>\n<p>In both cases, private data shall not be made available and authorities and protocols should be used to guarantee which level of service these ubiquitous solutions provide;</p>\n<p>Governments may obtain this information to track the whereabouts of individuals;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "17N.2.HL.TZ0.14",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-6-the-intelligent-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>WineForAll</em> is a retailer that sells wine in its stores. Each store sells wine from a number of vineyards.</p>\n<p>The following extract from the <strong>Wine</strong> file contains unnormalized data.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>record</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the steps to create a query to find the vineyards and names of fruity wines where the quantity in stock is between 25 and 35 bottles.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the steps to create a non-persistent derived field called <code>TotalPrice</code>, which would hold the total value of wine stored for each record.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why the inclusion of a derived field will not affect the normalization of a database.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the 3rd Normal Form (3NF) of the unnormalized <strong>Wine</strong> file.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why a single-field primary key is not always an appropriate solution for normalized databases.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>A record is one row in a table;<br/>All of the fields relating to item of information;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Fields and Table: Vineyard and NameOfWine FROM Wine;<br/>Criteria: StockQty >= 25 AND StockQty <= 35; <em>note: allow >25, <35</em><br/>Description: Fruit is extracted from the field.<br/>(<em>Do not award the mark if Description = Fruity</em>)</p>\n<p>SELECT Vineyard, NameOfWine FROM Wine<br/>WHERE (StockQty >= 25 AND StockQty <= 35)<br/>AND Description LIKE ‘*Fruity*’;</p>\n<p><em>Accept other versions including</em>:</p>\n<p>SELECT Vineyard, NameOfWine FROM Wine<br/>WHERE (StockQty BETWEEN 25 AND 35)<br/>AND Description LIKE ‘*Fruity*’;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>All three points needed for <strong>[2]</strong>. Two points needed for <strong>[1]</strong></em>.<br/>UnitPrice * StockQty;<br/>Totalprice named;<br/>WINE table named;</p>\n<p><em>Accept versions similar to the one shown below</em>:</p>\n<p>SELECT UnitPrice * StockQty AS totalprice<br/>FROM Wine;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>A derived field is created / does not exist in the table/ is temporary;<br/>So the rules of normalization do not apply / is not affected by duplication / redundancy;<br/>No new dependencies are created;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.</p>\n<p>Example of solution (accept different names for tables)</p>\n<p>Vineyard (<span style=\"text-decoration:underline;\">Vineyard</span>, Region)<br/>Wine (<span style=\"text-decoration:underline;\">WineID</span>, Wine, Vineyard<sup>(fk)</sup>, Year, Flavour, APV, UnitPrice)<br/>Stock (<span style=\"text-decoration:underline;\">StoreID</span>, <span style=\"text-decoration:underline;\">WineID</span><sup>(fk)</sup>, StockQty)</p>\n<p><strong>Vineyard table</strong> e.g. Vineyard (<span style=\"text-decoration:underline;\">Vineyard</span>, Region)<br/>Award <strong>[1]</strong> for primary key. Either Vineyard or VineyardID.</p>\n<p><strong>Wine table</strong> e.g. Wine (<span style=\"text-decoration:underline;\">WineID</span>, Wine, Vineyard<sup><span style=\"text-decoration:underline;\">(fk)</span></sup>, Year, Flavour, APV, UnitPrice)<br/>Award <strong>[1]</strong> for primary key WineID or composite Wine/Vineyard<br/>Award <strong>[1]</strong> for identifying the foreign key (Vineyard)<br/>Award <strong>[1]</strong> for splitting the three description fields</p>\n<p><strong>Stock table</strong> e.g. Stock (<span style=\"text-decoration:underline;\">StoreID</span>, <span style=\"text-decoration:underline;\">WineID</span><sup>(fk)</sup>, StockQty)<br/>Award <strong>[1]</strong> for composite key StoreID/WineID or Store/Wine/Vineyard<br/>Award <strong>[1]</strong> for WineID or equivalent key shown as foreign key</p>\n<p><em><strong>Note</strong>: Should candidates provide other reasonable solutions, please contact your team leader</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Relationship 1-1 might not exist;<br/>Which means a single-field PK might not uniquely identify a record;<br/>So a composite key is needed made up of 2 or more fields;<br/>Allow any suitable example;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a very straight-forward question.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were well-prepared with many providing actual queries. However, many did not achieve full marks for incorrectly identifying the adequate step to filter <em>fruity wines</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question was generally well-answered as many candidates were able to identify the steps for creating the derived field. </p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>In the second part of this question, many students failed to relate derived fields to normalization.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students were able to split the tables but only a few identified the foreign keys and correctly relate the tables to each other. Many students also identified that data needed to be atomic and were able to include this in the response. Candidates were not required to re-write the table.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some responses were reasonable, but many candidates were not aware of the use of composite keys/limitations of primary keys in normalized databases.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.3",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A charitable organisation, <em>Harvest</em>, which operates in a less economically developed country (LEDC), uses old computers that have been donated to them. The organization relies on WiFi and satellite-based transmission for access to the Internet.</p>\n</div><div class=\"specification\">\n<p><em>Harvest</em> is considering using a cloud-based service provided by a large IT company based in one of the more economically developed countries (MEDC).</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> technical challenge that <em>Harvest</em> may encounter in setting up its own website with the technologies that it has available.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the use of cloud-based services may help <em>Harvest</em> to overcome the limitations of the available technologies.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> problems this may cause for an organizsation such as <em>Harvest</em>.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p><em>Harvest</em> wishes to improve its ranking in the major search engines.<br/><br/>Discuss whether <em>Harvest</em> should use black hat search engine optimization techniques in order to improve its ranking.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for describing the challenge resulting from some limitation and <strong>[1]</strong> expansion, possibly with example up to <strong>[2 max]</strong></em>.<br/>Old computers impose <span style=\"text-decoration:underline;\">memory and processing constraints</span>;<br/>It is likely that they cannot make sophisticated web pages;<br/>For example, they may need to reduce the number of interactions/transmissions;<br/>By deciding not to have dynamic web pages;<br/>To the purpose of not generating loss of processing power on their side;</p>\n<p><span style=\"text-decoration:underline;\">The software might not be up-to-date/the OS is old</span>;<br/>This poses a threat for viruses or deliberate attacks (attack the weakest nodes);<br/>To the point that not even the charities will link to their website, rather just listing the name of the association;<br/>To limit the risk of propagating malware;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each reason how the use of cloud-based services may help Harvest to overcome the limitations of the available technologies up to <strong>[4 max]</strong></em>.<br/>They can host the website on the cloud;<br/>Enabling a sophisticated site to be created / bypassing their own limitations;<br/>The cloud could store all of their data;<br/>As they will have limited storage on their own equipment;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying how the use of cloud-based services may cause problems and <strong>[1]</strong> for an expansion / development up to <strong>[2 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>. <br/>The costs are likely to be high;<br/>And <em>Harvest</em> is clearly a company with limited funds;</p>\n<p>The cloud company will be bound by rules and regulations in the country in which it is registered;<br/>These may cause conflicts with regard to the type of information that <em>Harvest</em> deals with;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[5 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying an advantage of using black hat techniques and an additional <strong>[1]</strong> for each development of that advantage up to<strong> [2 max]</strong>.</em><br/><em>Award [1] for identifying a disadvantage of using black hat techniques and an additional <strong>[1]</strong> for each development of that disadvantage up to<strong> [2 max]</strong>.</em></p>\n<p><em>Award <strong>[1]</strong> for a valid conclusion.</em></p>\n<p><strong>Advantages</strong>:<br/>The use of black hat techniques + an example (e.g. hidden links, or reciprocal links, keyword stuffing, hidden content, content theft, etc.);<br/>May temporarily improve its ranking;</p>\n<p><strong>Disadvantages</strong>:<br/>However, this is unethical;<br/>This may not sit well with its image as a charity;</p>\n<p><strong>Conclusion</strong>:<br/>Search engines will eventually discover that these techniques are being used;<br/>This may lead to the site being banned;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.9",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-4-the-evolving-web",
|
||
"c-2-searching-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>BuildYourWebSite</em> is an online company that provides a number of common templates for building your own website. Each template includes one HTML file, one CSS file, a folder of web images, and a folder of special sound effects.</p>\n</div><div class=\"specification\">\n<p>Each template can be downloaded as a single compressed file, using a web browser.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p style=\"text-align:left;\">Identify <strong>two</strong> characteristics of HTML.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p style=\"text-align:left;\">Discuss the benefits and disadvantages of the template including a CSS file in addition to the HTML page.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why TCP/IP is a reliable protocol in relation to downloading operations.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate lossy compression and lossless compression when used to download files.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Mark-up language;<br/>Can contain scripting commands/code;<br/>Can imbed objects;<br/>Uses tags to structure page;<br/>Provides constructs to build hyperlinks;<br/>Can be integrated with CSS and JavaScript;<br/><em><strong>Note</strong>: Accept other reasonable characteristics</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[6 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying an advantage, <strong>[1]</strong> for identifying a disadvantage, and a further <strong>[4 max]</strong> for expanding on these advantages/disadvantages</em>.</p>\n<p><em><strong>Advantages</strong></em><br/>It saves time (in web development);<br/>Because modification of style needs to only be made to the CSS;<br/>It saves space;<br/>Because the code (of the style) is not repeated in each HTML file;<br/>Quicker load of many pages / Quicker download of many pages from the same site;<br/>HTML files are smaller;<br/>It gives a uniform appearance to the entire website;<br/>Which makes it more attractive/appealing/easy to navigate;<br/>It can be integrated with outside sources (e.g. RSS feeds);<br/>Which makes the website more interactive/dynamic for the user;<br/>Quicker to make changes to layout/formatting/page positioning;<br/>Therefore, it helps separating the jobs/tasks of illustrators (designer) from those that produce content;<br/>Increases accessibility of authoring to non-experts;<br/>Supported by most browsers;<br/>Increasing the number of users;</p>\n<p><em><strong>Disadvantages</strong></em>:<br/>Downloading pages from different sites can be slow (general browsing);<br/>Because each page may have its own CSS;<br/>(However, downloading many pages from the same site is instead faster;)<br/>CSS syntax is different from HTML and can be slightly ambiguous;<br/>Not a user-friendly language (but available as IDE) that the developer needs to learn;<br/>(e.g. the same cascade style name may have slightly different effects when used by different browsers;)<br/>An HTML page saved without CSS, and seen offline, will not display nicely;<br/>Because it would require access to external files, including CSS (including images, video, sound);<br/>Anybody with read/write permission to the CSS can easily override just the CSS;<br/>Showing unwanted information to an entire web-site (risk of hacking in just one point/internal threat with high risk);<br/>Some browsers do not support exactly the same CSS (some styles/fonts for example);<br/>The view can be slightly different using different browsers/risk of slight incompatibility;<br/>(For large, corporate sites) Integration of HTML + CSS with other content management systems (CMS) may be tricky;<br/>Because CMS also use their own CSS, and there can be collisions, and it requires technical competence;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/><em>(When a request of download is received at the Application level (e.g. HTTP with a browser), appropriate data packets are generated and sent to the transport layer/TCP;)</em></p>\n<p>TCP uses the header of the data packets to order them and to <strong>check</strong> their contents;<br/>And <strong>sends an acknowledgement</strong> signal to the transmitter upon correct reception, before preparing a new data packet with a further header for the IP/Internet level;<br/>If the transmitter does not receive the acknowledgement from the TCP, the <strong>transmitter re-sends</strong> the packet;<br/>Therefore, all correct packets will be available to the TCP at some point to be made available to the IP and specifically to the IP destination/receiver (in the header);<br/>IP ensures that the package reaches the correct address;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1 max]</strong> each for outlining the <strong>two</strong> techniques (lossy and lossless)</em>.<br/><em>Award <strong>[up to 2 max]</strong> for relating both to actual applications (<strong>[1]</strong> if related to file </em><em>types instead)</em>.</p>\n<p>Images and audio can be compressed using lossy techniques;<br/>This will create a smaller file/faster transmission time;<br/>But the data loss will not seriously affect quality;</p>\n<p>However, CSS and HTML files might lose possible scripting;<br/>As you need to recover the original data;<br/>Lossless compression is more suitable;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.7",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-3-distributed-approaches-to-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The programming team have decided to replace the array of <code>Item</code> objects <code>(pl)</code> and the array of <code>Payment</code> objects <code>(tables)</code> with either a linked list or an ArrayList.</p>\n</div><div class=\"specification\">\n<p>The array of <code>Item</code> objects <code>(pl)</code> is replaced by <code>priceLL</code>, an object of the LinkedList library class. The <code>Item</code> objects can be created, deleted or amended.</p>\n<p>The method <code>changePrice()</code> allows an item, identified by its item code, to have its price changed. All data required by this method are passed as parameters. If the item is not found then an appropriate message is displayed.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> benefit that the use of either of these choices will have over the original array structures.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method <code>changePrice()</code>.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how a binary tree structure would allow a more efficient search for the <code>Item</code> object.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Memory space for the exact number of objects can be assigned;<br/>Whereas the array will (inevitably) waste space/allot more memory than is needed/may run out of allotted memory/there is no need to determine array size;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows, up to <strong>[6 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for correct signature.</em><br/><em>Award <strong>[1]</strong> for correct initialization of the length of the loop/size of the linked list/ </em><em>Boolean/Iterator object as appropriate to the solution and appropriate message </em><em>displayed at end;</em><br/><em>Award <strong>[1]</strong> for correct loop.</em><br/><em>Award <strong>[1]</strong> for correct comparison, with or without <code>get</code> methods.</em><br/><em>Award <strong>[1]</strong> for correct updating, with or without <code>get</code> methods.</em><br/><em>Award <strong>[1]</strong> for early exit if found.</em><br/><em>Award <strong>[1]</strong> for answer completely correct.</em></p>\n<p><strong><em>Example 1</em></strong></p>\n<pre>public void changePrice(LinkedList<Item> pll, String c,<br/> double newPrice)<br/>{<br/> int i = 0;<br/> boolean found = false;<br/> int size = pll.size();<br/> while (i < size && !found)<br/> {<br/> if (pll.get(i).getCode().equals(c)) // allow “=”<br/> {<br/> pll.get(i).setPrice(newPrice);<br/> found = true;<br/> }<br/> i = i + 1;<br/> }<br/>}</pre>\n<p><strong><em>Example 2</em></strong></p>\n<pre>public void changePrice(LinkedList<Item> pll, String c,<br/> double newPrice)<br/>{<br/> Iterator<Item> iter = pll.iterator();<br/> boolean found = false;<br/> while (iter.hasNext() && !found)<br/> {<br/> Item current = iter.next();<br/> if (current.getCode().equals(c)) // allow “=”<br/> {<br/> current.setPrice(newPrice);<br/> found = true;<br/> }<br/> }<br/>}</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The <code>pl</code> array/<code>Item</code> objects could be read into a binary tree;<br/>And placed in order of the <code>Item</code> code;<br/>(Successive) comparisons between the search item and tree item will reduce the search space by a half (each time);<br/>Which results in a faster search than a linear search/<code>Olog(n)</code> is better than <code>O(n)</code>;<br/>As a linear search might have to loop through the whole list;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "17N.2.HL.TZ0.18",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>one</strong> advantage of using a dedicated operating system on a mobile phone.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1 max]</strong></em><br/>Makes maximum use of the available (limited) memory to provide the features needed for the phone;<br/>Does not waste memory space with unwanted/inappropriate features;<br/>Ensures a higher level of security;<br/>Makes efficient use of hardware equipment;<br/>Suited to available hardware equipment;</p>\n<p><em><strong>Note</strong>: Accept examples, GUI will fit right with the screen resolution /can make running the device easier to use / better suited to their audience/ it is faster than universal OS's, etc</em>.</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Many candidates correctly answered this question.</p>\n</div>",
|
||
"question_id": "21M.1.HL.TZ0.9",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the use of data-hiding as a security feature in OOP.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The <code>Arrival</code> object has two methods named <code>compareWith</code>.</p>\n<p>Outline why calling the <code>compareWith</code> method does not cause a conflict.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the name of this OOP property.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for stating encapsulation as an OOP property.</em><br/><em>Award <strong>[1]</strong> for an elaboration</em>.</p>\n<p><em><strong>Example answer:</strong></em><br/>Encapsulation allows to make instance variables (and methods) of a class private to that class;<br/>So that the main program / other classes can't accidentally access / change the data in an object;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>.</em><br/>The two methods have different parameters;<br/>allowing the compiler to choose the correct one.</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Polymorphism</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.11",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-2-features-of-oop"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A company that provides training for teachers plans to set up a training room in its offices with a network of 15 computers. Each computer has 1 TB of storage and 16 GB of random access memory (RAM).</p>\n</div><div class=\"specification\">\n<p>In order to minimize costs, the company decided only to install general application software on the training computers.</p>\n</div><div class=\"specification\">\n<p>The company has decided to allow the teachers to use their own devices in its training room by adding wireless networking.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> characteristics of RAM.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the purpose of persistent storage on the computers.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> types of general application software that would be installed on the training computers.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage to the company of implementing this change.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> disadvantage to the company of implementing this change.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>one</strong> method of security that may be used on this wireless network.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the speed of data transmission on the wireless network in the training room may vary.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>RAM is volatile / contents erased when power is switched off;<br/>Access speed is fast / faster than hard drive;<br/>Data / instructions can be read from and written to it / /RAM can be overwritten;<br/>Size is limited;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>To store programs / files / data in a non-volatile device so it isn’t lost;<br/>Stores more data as it has a larger capacity;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Word processor;<br/>Spreadsheet;<br/>Database management system;<br/>Email;<br/>Web browser;</p>\n<p><em>Allow any general purpose application that is appropriate for a ‘training room computer’</em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>May save money;<br/>Due to not having to supply all the training computers;</p>\n<p>May be able to increase the size of the training group;<br/>Which may generate more income;</p>\n<p>Trainees / teachers likely to be more familiar with software on own machine (and how new training software interacts with OS / user interface);<br/>Making training sessions more efficient / allowing trainer to concentrate on the training rather than using generic applications;</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em><br/>May cause security issues;<br/>Due to multiple users having network access from their “unsecured” devices;</p>\n<p>May interfere with running of training sessions;<br/>As some machines may not be compatible;</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award </em><strong><em>[2 max]</em> </strong><br/>Encryption;<strong><br/></strong>Scrambles the contents of the network transmissions so that if they are intercepted they can’t be understood (without the decryption key);</p>\n<p>User ID (and password);<br/>Only allows authorized users to access the network;</p>\n<p>Media Access Control (MAC) addresses;<br/>Unique identification codes embedded in networkable equipment so that only authorized equipment may access the network;</p>\n<p>Firewall;<br/>Checks traffic coming into the network and leaving the network, and can block suspicious data;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>The speed of data transmission (on a wireless network) slows down;<br/>The further the receiver is from the transmitter;</p>\n<p>Passing through obstructions such as solid walls;<br/>Can slow down transmissions (on a wireless network);</p>\n<p>The bandwidth available for transmission on a wireless network is finite;<br/>So, transmission speeds can be affected if the number of users on the network increases;</p>\n<p><em>Note to examiners: Answers must relate to wireless networks and not be a comparison between cabled and wireless networks</em>.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates often named uses of RAM, but the question asked for characteristics of RAM, so therefore lost out as a consequence. However, many recognised it is volatile and can be overwritten.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to state the purpose of persistent storage, but a significant number mistook this for ROM, so gave the purpose of that instead.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This part was not answered as well as it could have been. Candidates were asked to name two types of general-purpose applications software suitable for a training room, with the most likely answers being word processor and spreadsheet. However, candidates provided a wide range of incorrect answers that were, for example, utilities, system software or translation software.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates recognised that if the teachers could bring their own devices to the training room it would save the training company money, as they wouldn’t need to provide so many training computers. Or, that their training sessions may be more efficient, as the teachers were already familiar with their own machines, so they could get straight into the training session rather than learning how to use the machine. Unfortunately, many candidates gave responses that were benefits to the teacher and generally within their teaching environment rather than in the training room, such as being able to connect anywhere in their classroom.</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates often gave responses that were generic disadvantages of wireless networks, and sometimes, when compared to cabled networks, rather than relating their answers to the given scenario. Some candidates did, however, state that one of the teacher’s devices may be infected with malware which could be uploaded, or they may be incompatible with the training software.</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Well answered, with the full range of possible answers seen.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Generally well answered, with the full range of possible answers seen.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.15",
|
||
"topics": [
|
||
"topic-2-computer-organization",
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization",
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> characteristics of a dynamic data structure.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max] </strong></em><br/>Dynamic data structure does not have predetermined size/ allows memory use to change as needed (no fixed size) / if more space is required to store more data, it can therefore increase;<em><strong><br/></strong></em>Can be expanded until all the available RAM is used;<br/>There is no unused/wasted memory;<br/>Memory is allocated to the data structure as the program executes (run-time);<br/>Elements of a dynamic data structure are stored in memory locations that are chained together but not necessarily physically contiguous;<br/>Elements of a dynamic data structure are sequentially accessed;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates were able to identify two characteristics of a dynamic data structure.</p>\n<p>Most candidates were able to identify two characteristics of a dynamic data structure. </p>\n</div>",
|
||
"question_id": "21M.1.HL.TZ0.10",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Sketch a balanced binary tree that would allow the following output when traversed using in order traversal:</p>\n<p>Zebra, Tango, Hotel, Foxtrot, Delta, Bravo, Alpha. </p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></em></p>\n<p><em>Award <strong>[3 max] </strong></em><br/>Correct root;<br/>Correct left sub-tree;<br/>Correct right sub-tree;<br/><em><strong>Note</strong></em>: Award 1 mark for any binary tree with the same number of nodes in the left and right subtree;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>A balanced binary tree was not always familiar to candidates.</p>\n</div>",
|
||
"question_id": "21M.1.HL.TZ0.11",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>EnviroBuild</em> is a construction company that recently purchased land. It has permission to build either small houses <strong>or</strong> large houses but not both types of house. The maximum number of small houses that can be built is 10. The maximum number of large houses that can be built is five.</p>\n<p>The cost of building the houses is calculated using a model with the following three variables:</p>\n<p><code>House_Type</code>: The type of house (small or large).</p>\n<p><code>House_Num</code>: The number of houses to be built.</p>\n<p><code>Profit</code>: The total sales revenue minus the land costs, labour costs and material costs.</p>\n</div><div class=\"specification\">\n<p>The decision whether to build small houses or large houses is a purely financial one and is based on the following information:</p>\n<ul>\n<li>A single payment of $500 000 for the land, regardless of whether 10 small houses or five large houses are to be built.</li>\n<li>The revenue from each house sale will be $220 000 for a small house and $400 000 for a large house.</li>\n<li>The labour costs will be $2500 per day, regardless of the type of house built.</li>\n<li>It will take 17 days to build each small house and 23 days to build each large house.<br/>Houses are built sequentially so that they can be sold as soon as they are completed.</li>\n<li>The material costs will be $100 000 for each small house and $190 000 for each large house.</li>\n</ul>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the data types for the <code>House_Type</code>, <code>House_Num</code> and <code>Profit</code> variables.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a spreadsheet model that shows the total profit for the chosen type of house. The user must input the <code>House_Type</code> and <code>House_Num</code> to calculate the total profit.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> validation tests that should be included in the test plan for this spreadsheet model.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>To finance this project, <em>EnviroBuild</em> took out a bank loan of $400 000 and will be required to pay interest on this loan. The project starts on 1 January 2021.</p>\n<p>The following steps are used to calculate the total profit:</p>\n<ul>\n<li>Read the <code>Profit</code> variable and the <code>No_of_Days</code> variable from the spreadsheet model in (b).</li>\n<li>Calculate the number of months that the project will take.\n<ul>\n<li>There are no partial months.</li>\n<li>For example, if a project finished on 1 July 2021, the loan interest rates will include July: the project will last for 7 months.</li>\n</ul>\n</li>\n<li>The rate of interest on the bank loan of $400 000 is 1 % per month.</li>\n<li>The land tax is $500 per month.</li>\n</ul>\n<p>Construct the pseudocode that will calculate the profit after these additional costs have been considered. You can introduce any new variables, if necessary.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/><code>House_Type</code>: char/string/Boolean;<br/><code>House_Num</code>: integer;<br/><code>Profit</code>: fixed-point decimal/currency/float/double;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for including</em> <code>HOUSE_TYPE</code> <em>and</em> <code>HOUSE_NUM</code> <em>as input</em><br/><em>Award <strong>[1]</strong> for calculating total revenue;</em><br/><em>Award <strong>[1]</strong> for calculating the number of days for each project</em><br/><em>Award <strong>[1]</strong> for calculating the labour costs</em><br/><em>Award <strong>[1]</strong> for calculating material costs</em><br/><em>Award <strong>[1]</strong> for calculating the profit</em></p>\n<p><code>REVENUE</code>:<em> Award <strong>[1]</strong> for Sales_price * House_Num based on the If statement<br/></em><code>NUM_DAYS</code>:<em> Award <strong>[1]</strong> for the correct number of days * house_num.<br/></em><code>LABOUR_COSTS</code>:<em> Award <strong>[1]</strong> for NUM_DAYS * 2500<br/></em><code>MATERIAL_COSTS:</code><em> Award <strong>[1]</strong> for checking the HOUSE_TYPE and then multiplying HOUSE_NUM by the correct material cost.<br/></em><code>PROFIT:</code><em> Award <strong>[1]</strong> for deducting all of the costs from the revenue.<br/></em></p>\n<p><strong>Example answer</strong>:</p>\n<p><img src=\"\"/></p>\n<p><strong>Alternative solution</strong>:</p>\n<p><img src=\"\"/></p>\n<p><em>Note: accept cell references such as B3 instead of variables</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p><em>Award <strong>[2 max]</strong> for each variable tested.</em><br/><em>Award <strong>[1]</strong> for the type of test and <strong>[1]</strong> for example test data</em>.</p>\n<p>Type test for <code>HOUSE_TYPE</code><br/>Normal: s or l / small or large; Abnormal: m / medium.<br/>If Boolean has been used Normal: True or False; Abnormal: “small”</p>\n<p>Range test for <code>NUM_HOUSES</code><br/>Normal <code>HOUSE_NUM</code> = 5 / Abnormal <code>HOUSE_NUM</code> = 12 / Extreme <code>HOUSE_NUM</code> = 6 or <code>HOUSE_NUM</code> = 10</p>\n<p><em>Accept any testing that relates to</em>:</p>\n<ul>\n<li><em>normal data // <strong>Note</strong>: an example will get this mark</em></li>\n<li><em>extreme data</em></li>\n<li>\n<em>abnormal data</em>.</li>\n</ul>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for reading the profit, number of days from csv file / cell range.</em><br/><em>Award <strong>[1]</strong> for adding the number of days to the date.</em><br/><em>Award <strong>[1]</strong> for extracting the month from the date.</em><br/><em>Award <strong>[1]</strong> for calculating interest and rates.</em><br/><em>Award <strong>[1]</strong> for deducting the costs from the profit and displaying result.</em></p>\n<p><strong>Example pseudocode</strong>:</p>\n<pre>import FILE.CSV As SS<br/>read PROFIT, NUM_DAYS from SS<br/>END_DATE = #01/01/2021 + NUM_DAYS<br/>NUM_MONTHS = MONTH(END_DATE)<br/>COSTS = (NUM_MONTHS * 500) + (NUM_MONTHS * (400000 * .01))<br/>output (PROFIT – COSTS)</pre>\n<p><strong>Alternative pseudocode</strong>:</p>\n<pre>input Profit, NumDays from spreadsheet<br/>endDate = date(dateval(\"1/1/21\") + NumDays)<br/>monthsTaken = month(endDate)<br/>interest = 400000 * 0.01 * monthsTaken<br/>output \"Net profit = $\", (Profit – interest)</pre>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.4",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-1-the-basic-model",
|
||
"b-2-simulations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A company provides car parking services in large cities and needs a computer system to keep track of the number of vehicles using its parking areas.</p>\n<p>When a vehicle arrives, its registration plate is recorded on the system and it is allocated a number that identifies where it should park. When the vehicle leaves, that space is made available for other vehicles to use.</p>\n<p>Vehicles are identified by their unique registration plate, which is an alphanumeric code of eight characters (e.g. <code>X1234567</code>). This is clearly displayed on the vehicle.</p>\n<p>A programmer created the classes <code>ParkingArea</code> and <code>Vehicle</code> to model the above situation.</p>\n<pre>public class ParkingArea {<br/> private Vehicle vehicles[];<br/> private String name;<br/><br/> ParkingArea(String name, int capacity) {<br/> this.name = name;<br/> if (capacity > 300) capacity = 300;<br/> this.vehicles = new Vehicle[capacity];<br/> }<br/><br/> String getName() {<br/> return name;<br/> }<br/> <br/> public int getCapacity() {<br/> return vehicles.length;<br/> }<br/><br/> public int findVehicle(String reg) {<br/> //find where the vehicle is located in the array and<br/> //return the index not yet written<br/> }<br/>}</pre>\n<pre>public class Vehicle {<br/> private String registration;<br/> private byte colour;<br/> private boolean broken;<br/><br/> public final static byte BLACK=1;<br/> public final static byte WHITE=2;<br/> public final static byte BLUE=3;<br/> public final static byte RED=4;<br/> public final static byte GREEN=5;<br/> private final static double ADMIN_FEE = 3;<br/><br/> public Vehicle() {}<br/><br/> public Vehicle(String registration) {<br/> this.registration = registration;<br/> }<br/> public Vehicle(String registration, byte colour) {<br/> this.registration = registration;<br/> this.colour=colour;<br/> }<br/> public void setBroken(boolean broken) {<br/> this.broken=broken;<br/> }<br/> public void setColour(byte colour) {<br/> this.colour=colour;<br/> }<br/> public boolean getBroken() {<br/> return broken;<br/> }<br/> public String getRegistration() {<br/> return registration;<br/> }<br/> public double pay(int hours) {<br/> // code to return admin fee - only if applicable<br/> }<br/>}</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> effect of using the modifier <code>static</code> when declaring a variable.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the relationship between the classes <code>Vehicle</code> and <code>ParkingArea</code>.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why it is necessary to use the keyword <code>this</code> in the <code>setBroken</code> method of the <code>Vehicle</code> class.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct code to create an instance of the <code>Vehicle</code> class that has a registration of <code>X1234567</code>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct code that sets the colour of the object created in part (i) as black.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.ii.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Static means it is the same for all instances of the class;<br/>because it is contained in the class rather than in an instance of the class/object / it is defined at the class level;<br/>Static means that less memory is taken up;<br/>as only 1 memory allocation it created for all instances rather than 1 per instance;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Award <em><strong>[1]</strong></em> for aggregation (accept Composition also);<br/>Award <em><strong>[1]</strong></em> for An instance of ParkingArea can contain Vehicles;<br/>Award<em> <strong>[1]</strong></em> for A single ParkingArea can contain between 0 and 300 instances of Vehicle;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>To distinguish between 2 variables with the same name;<br/>Allows the local/instance variable to be set to the parameter/class variable;</p>\n<p><em><strong>Note</strong>: Award <strong>[1]</strong> if the incorrect technical terms for variables are given but the idea of distinguishing between 2 types of variables with the same name is expressed</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.</p>\n<p>Award <em><strong>[1]</strong></em> for correctly declaring the variable as type Vehicle;<br/>Award <em><strong>[1]</strong></em> for using the correct constructor;</p>\n<p>e.g.</p>\n<p><code>Vehicle v=new Vehicle(\"X1234567\")</code>;</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Award <em><strong>[1]</strong></em> for calling the correct method on the correct instance variable name;<br/>Award <em><strong>[1]</strong></em> for using the constant correctly, i.e. Vehicle.BLACK;</p>\n<p><code>v.setColour(Vehicle.BLACK)</code>;</p>\n<p><em><strong>Note</strong>: accept the constant prefixed by the name of the instance instead of the class</em></p>\n<div class=\"question_part_label\">d.ii.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students associated the modifier <em>static</em> with the idea of permanence in some form, but not all clearly understood the difference between class variables and instance variables.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was well-answered.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The <em>this</em> modifier clearly causes confusion. Students realized that it in some way clarified the difference between the two occurrences of the variable <em>broken</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many full marks for part (i), although some failed to put the <em>String</em> data in speech marks.</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Part (ii) showed a lack of experience with the <em>byte</em> type.</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.10",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-3-program-development",
|
||
"d-1-objects-as-a-programming-concept"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A palindrome is a word that spells the same backwards. For example, the words “kayak” and “rotor” are palindromes.</p>\n<p>A word can be checked to see if it is a palindrome by comparing the first letter with the last letter and then the second letter with the next-to-last letter and so on.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why recursion is a suitable tool to use when performing this check.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The method <code>palindrome()</code> is called by <code><strong>boolean</strong> t = palindrome(word)</code>;<br/>where <code>word</code> is a String variable.</p>\n<p>Without writing code, describe the recursive method <code>palindrome()</code> that returns whether or not a word is a palindrome.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The solution repeats the same algorithm/series of steps/code;<br/>With a changing/different parameter set;<br/>Until a base/terminating case is reached; </p>\n<p><em><strong>Note</strong>: Do not award marks for “the method calls itself”</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The base case will return true if the length of word = 0 or 1 (<em>must have both values</em>) / The index of last character <= index of the first character;<br/>Otherwise the first and last letters will be compared;<br/>Returns false if they are not equal;<br/>If they are equal, calls the method again;<br/>With, as its parameter, the word stripped of its first and last letters (can use indices);</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "17N.2.HL.TZ0.19",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Open source code is made available by a community of developers and is frequently updated. The code can be downloaded for free, but users must register with the website and have their access authenticated.</p>\n</div><div class=\"specification\">\n<p>Authentication is based on signing in to an established third-party company, for example a user’s existing email or a social network account. The third-party company then verifies the user, granting them access to the open source code website.</p>\n</div><div class=\"specification\">\n<p>The URL of this website is www.OpenSourceDev.org. Any new pieces of code that the developers make available become new resources on the website. A script generates weekly automatic notifications of new code available on the site, and sends this notification to users as an email.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the use of server-side scripting to provide the mechanism for registration.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the user’s privacy can be maintained whilst using this method of authentication.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline, with an example, how the URL for these new pieces of code will be generated.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the steps that the script could perform for sending out these notifications.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A fragment of a script and a web form are provided below.<br/>In the script some functions are not implemented, and only their specification is provided.</p>\n<pre><?php<br/> //include a database of urls<br/> include('url_db.php');<br/> $url = $short = \"\";<br/><br/> if ($_SERVER[\"REQUEST_METHOD\"] == \"POST\")<br/> { $url = $_POST['url'];<br/> $short = make_short($url);<br/> function make_short($u)<br/> { $x = make_alpha_string($u);<br/> $y = first4_last4($x);<br/> $z = limits($x);<br/> $v = $y. \".\".$z; //string concatenation<br/> return $v;<br/> }<br/><br/> function make_alpha_string($u)<br/> { // It removes, in this order: substrings corresponding to<br/> // protocol names, the substring www, and all characters<br/> // except for letters<br/> }<br/><br/> function first4_last4($u)<br/> { // It returns the string made of the first 4 characters<br/> // followed by the last 4 characters of $u<br/> }<br/><br/> function limits($u)<br/> { // It returns the string made of the first character and<br/> // last character of $u<br/> }<br/><br/> mysql_query(\"<br/> INSERT INTO url_db(orig_url, short_url, url_ip) VALUES<br/> ( '\".$_POST['url'].\"',<br/> '\".$short.\"',<br/> '\".$_SERVER['REMOTE_ADDR'].\"'<br/> )<br/> \");<br/> }<br/>?><br/><br/><form method=\"post\" action=\"\"><br/>URL:<br/><input type=\"text\" name=\"url\" /><br/><br><br><br/><input type=\"submit\" name=\"Submit\" value=\"Submit\" /><br/></form></pre>\n<p>Describe the processing that occurs when the form is filled with the URL https://www.the2nd.org/bin.php?id=70 that the server discovers is associated with the IP address 172.16.254.1.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4]</strong></em>.<br/>Server-side scripting does not require the installation of extra resources on a computer, for example the latest plug-in to run the script;<br/>The log-in process will generally be slower as a round trip has to be made;<br/>However, for regular visitors of the site, it speeds up the login, as the server script might be linked to data storage and recognize their access for further reference;<br/>The server script is independent from the version of the browsers that is used, the user just sees the HTML interface (this is the typical problem with client-side scripting);<br/>A security breach on the server could lead to <span style=\"text-decoration:underline;\">all</span> log-ins being compromised;<br/>However, server-side is more secure as client-side is more easily hacked into;<br/>There can be occasional downgrade in performance if too many users are running simultaneously their scripts on the server;<br/>However, for the nature of the files, this should not generate bottlenecks in the network (small files, not intensive streaming);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>Your email address and associated password are private;<br/>Both are needed to register with the initial website, but at most only the email address is stored there;<br/>They are forwarded to the third-party website for identification;<br/>The third-party identifies/confirms whether or not the person is who they say they are, based on their email/social network services that the third party provides;<br/>This yes–no answer/confirmation provides the authentication for the open-source developers;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for stating how the URL is generated, and <strong>[1]</strong> for giving an example, up to <strong>[2 max]</strong></em>.<br/>It is generated by taking the path of the website extended with the path for the code;<br/>e.g. www.OpenSourceDev.org/newcode/json/fakecode007;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The script accesses the file of new URLs (in a file);<br/>And adds the URLs to an email template;<br/>Then accesses the file of email addresses of subscribers (and sends email);</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows, up to <strong>[3 max]</strong>. (<strong>Note</strong>: there are <strong>[5]</strong> marking points)</em><br/><em>Award <strong>[1]</strong> for the <span style=\"text-decoration:underline;\">value passing</span> from the form to php via <code>POST</code>.</em><br/><em>Award <strong>[1]</strong> for the <span style=\"text-decoration:underline;\">operation</span> of the code to generate the short URL with final <code>$v</code>.</em><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">access to update</span> database.</em><br/><em>Award <strong>[1]</strong> for a <span style=\"text-decoration:underline;\">new correct triple</span> in database.</em><br/><em>Award <strong>[1]</strong> for <span style=\"text-decoration:underline;\">remote access</span> operated by server through the database to retrieve the URL.</em></p>\n<p><em><strong>Note</strong>: Competent use of terminology is needed to award full marks. Generic answers that show general good understanding of the process, but lack use of competent language should not be awarded full marks</em>.</p>\n<p><em><strong>Example</strong></em><br/>The <span style=\"text-decoration:underline;\">value of the URL</span> that is inputted (and submitted) via the form is stored in the <span style=\"text-decoration:underline;\">variable URL</span> which Interacts with the php code, because the <span style=\"text-decoration:underline;\">method <code>POST</code></span> is specified in the form, therefore starting a communication process;</p>\n<p>The process generates a <span style=\"text-decoration:underline;\">different value</span> for the name for the URL that is <span style=\"text-decoration:underline;\">used to update</span> a database of URLs <span style=\"text-decoration:underline;\">together with the IP address</span>;</p>\n<p>The IP address is retrieved by the server through a <span style=\"text-decoration:underline;\">remote call</span> requested from the insertion in database;</p>\n<pre>The new value for the URL that is generated, given the one in input, is <code><span style=\"text-decoration:underline;\">thenhpid.td</span></code> and is stored in <code>$v</code>;<br/>(detail of intermediate operations:<br/>$x = thendorgbinphpid<br/>$y = thenhpid<br/>$z = td<br/>$v = thenhpid.td)<br/><br/>The new record inserted in the database url_db will be the following triple www.the2nd.org/bin.php?id=70, thenhpid.td, 172.16.254.1;</pre>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.8",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-4-the-evolving-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The array <code>inbound</code> in the <code>FlightManagement</code> class is sorted by Estimated Time of Arrival (ETA).</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>method signature</em>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a method <code>showDelayed()</code> that outputs the IDs of all delayed flights in the array <code>inbound</code> that have not yet landed and that have an ETA before a given time <code>t</code>. The time <code>t</code> is passed as a <code>String</code> parameter.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Without using a sorting algorithm, construct the method <code>add(Arrival newArrival)</code> that inserts a <code>newArrival</code> in the sorted array <code>inbound</code>. You may assume that <code>newArrival</code> has been instantiated and that the array <code>inbound</code> is not full.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>When a flight is delayed, a method in <code>FlightManagement</code> is used to find and update the flight with the delay and to reorganize the array so that it remains sorted for the ETA.<br/><br/>Describe how this method would be implemented using the methods provided.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>. <br/><strong>[1 max]</strong> for any two out of three underlined key components.<br/><strong>[2 max]</strong> for all three key components.<br/><strong>Note</strong>: the return type is <span style=\"text-decoration:underline;\">not</span> part of the method signature.<br/></em></p>\n<p><em><strong>Example answers</strong>:<br/></em>The <span style=\"text-decoration:underline;\">method name</span> and <span style=\"text-decoration:underline;\">all of its parameters</span> and the <span style=\"text-decoration:underline;\">type of these parameters</span>.<br/>The <span style=\"text-decoration:underline;\">method name</span> and the <span style=\"text-decoration:underline;\">type</span> of <span style=\"text-decoration:underline;\">all of its parameters</span>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for a correct loop until last Arrival.</em><br/><em>Award <strong>[1]</strong> for including correct test for ETA.</em><br/><em>Award <strong>[1]</strong> for including correct test landed.</em><br/><em>Award <strong>[1]</strong> for correctly using double dot notation in output statement.</em><br/><em>Do not penalize incorrect use of accessor methods</em>.</p>\n<p><em><strong>Example answers</strong></em>:</p>\n<pre><strong>public void</strong> showDelayed(String t)<br/>{ <strong>int</strong> i = 0;<br/><strong> while</strong> (i <= last)<br/> { <strong>if</strong> (inbound[i].getETA().compareTo(t) < 0)<br/> { <strong>if</strong> (!inbound[i].getLanded())<br/> { <strong>output</strong>(inbound[i].getMyFlight().getID());<br/> }<br/> i = i + 1<br/> }<br/> }<br/>}<br/><strong><br/>public void</strong> showDelayed(String t)<br/>{ int i = 0;<br/> while ((i <= last) && (inbound[i].getETA().compareTo(t) < 0))<br/> { if (!inbound[i].landed)<br/> { output(inbound[i].myFlight.id);<br/> }<br/> i = i + 1<br/> }<br/>}<br/><br/><strong>public void</strong> showDelayed(String t)<br/>{ <strong>for</strong> (<strong>int</strong> i = 0; i <= last; i++)<br/> { <strong>if</strong> ((inbound[i].getETA().compareTo(t) < 0) &&<br/> (!inbound[i].landed))<br/> { <strong> output</strong>(inbound[i].myFlight.id);<br/> }<br/> }<br/>}</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for a loop comparing <code>newArrival</code> to entries in inbound.</em><br/><em>Award <strong>[1]</strong> for testing for the last entry.</em><br/><em>Award <strong>[1]</strong> for good attempt a for loop in reverse order.</em><br/><em>Award <strong>[1]</strong> for a fully correct for loop in reverse order.</em><br/><em>Award <strong>[1]</strong> for correctly shifting elements in the array.<br/>Award <strong>[1]</strong> for assigning <code>newArrival</code>.<br/>Award <strong>[1]</strong> for incrementing last.</em></p>\n<p><em><strong>Example answer</strong></em>:</p>\n<pre><strong>public void</strong> add(Arrival newArrival)<br/>{ <strong>int</strong> i = 0;<br/><strong> while</strong> ((i <= last)&&(inbound[i].compareWith(newArrival) < 0))<br/> { i++;<br/> }<br/><strong> for</strong> (<strong>int</strong> j = last + 1; j>i; j--)<br/> { inbound[j] = inbound[j - 1];<br/> }<br/> inbound[i] = newArrival;<br/> last++;<br/>}</pre>\n<p><em><strong>Alternative answer</strong></em>:</p>\n<pre><strong>public void</strong> add(Arrival newArrival)<br/>{<br/><strong> int</strong> i = 0;<br/><strong> while</strong> (i <= last)&&<br/> (inbound[i].getETA().compareTo(newArrival.getETA()) < 0)<br/> { i++;<br/> }<br/><strong> for</strong> (<strong>int</strong> j = last; j >= i; j--)<br/> { inbound[j + 1] = inbound[j];<br/> }<br/> inbound[i] = newArrival;<br/> last++;<br/>}</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for declaring a variable of type <code>Arrival</code>.</em><br/><em>Award <strong>[1]</strong> for calling remove (<code>flightID</code>).</em><br/><em>Award <strong>[1]</strong> for calling <code>addDelay(minutes)</code>.</em><br/><em>Award <strong>[1]</strong> for adding the updated <code>Arrival</code> object to array inbound.</em><br/><em>Award <strong>[1]</strong> for adding the update to the array inbound by calling <code>add(update)</code>.</em></p>\n<pre><strong>public void</strong> delay(String flightID, <strong>int</strong> minutes)<br/>{<br/> Arrival update = remove(flightID);<br/> update.addDelay(minutes);<br/> add(update);<br/>}</pre>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.12",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-3-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Two further classes, <code>Car</code> and <code>Motorbike</code>, are created.</p>\n<pre>public class Car extends Vehicle{<br/> public static double hourlyFee=3.5;<br/> public double pay(int hours) {<br/> //code to calculate and return the complete price<br/> }<br/>}<br/><br/>public class Motorbike extends Vehicle{<br/> public static double hourlyFee=2.5;<br/> public double pay(int hours) {<br/> //code to calculate and return the complete price<br/> }<br/>}</pre>\n</div><div class=\"specification\">\n<p>The method <code>pay</code> in the <code>Vehicle</code> class returns the administration fee (which is only part of the total price), while the method <code>pay</code> of the <code>Car</code> class calculates the total price for a car staying in the parking area.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> differences between inheritance and aggregation.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a UML diagram that shows the relationships between the <code>ParkingArea</code>, <code>Vehicle</code>, <code>Motorbike</code> and <code>Car</code> classes. There is no need to include the attributes or methods of each class.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method <code>pay</code> in the <code>Vehicle</code> class that returns the admin fee stored in the variable <code>AdminFee</code> if the vehicle has stayed for five hours or less; otherwise, it returns 0.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method <code>pay</code> in the <code>Car</code> class, where it uses the <code>vehicle</code> method <code>pay</code> but adds the charge for the amount of time spent in the parking area.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The array <code>vehicles[]</code> in the <code>ParkingArea</code> class is used to store instances of the <code>Car</code> or <code>Motorbike</code> class.</p>\n<p>Outline why <code>Vehicle</code> is a valid type for this array.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Inheritance is when the behaviour of a class is transferred to another class;<br/>whereas aggregation is when a class is contained inside another and used;</p>\n<p>Aggregation is useful for modelling a real life situation of containment aka. “has a” (e.g. contents of a box);<br/>whereas Inheritance is useful for modelling real life situation that one entity is a particular (more specific) type of another entity, aka. “is a”;</p>\n<p>While both can achieve the same result, Aggregation (composition) can lead to more robust and safer code;<br/>whereas inheritance is a more flexible solution but prone to errors due to the behaviour of subclasses being changed;</p>\n<p>Inheritance allows for code reuse / lowers maintenance cost;<br/>whereas aggregation does neither of the above;</p>\n<p>Can have more than 1 aggregation;<br/>but only 1 superclass (in Java);</p>\n<p>Inheritance allows for code reuse as in the creation of sub-classes;<br/>whereas with aggregation each class must be written out in full;</p>\n<p><em>Mark as [2] + [2]</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Award <strong>[1]</strong> for all four classes shown;<br/>Award <strong>[1]</strong> for showing the links in the correct place (any arrow or line is acceptable);<br/>Award <strong>[1]</strong> for distinguishing the relationship ParkingArea - Vehicle;<br/>Award <strong>[1]</strong> for distinguishing the relationships Car/Motorbike -Vehicle;</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for returning admin fee if <=5 hours;</em><br/><em>Award <strong>[1]</strong> for returning 0 if >5 hours;</em></p>\n<pre>public double pay(int hours) {<br/> if (hours <= 5) {<br/> return ADMIN_FEE;<br/> } else return 0;<br/>}</pre>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for for super.pay(hours);</em><br/><em>Award <strong>[1]</strong> for returning result of correct formula (i.e. adding on hourlyFee*hours);</em></p>\n<p><strong>Example</strong>:</p>\n<pre>public double pay(int hours) {<br/> return super.pay(hours)+hourlyFee*hours;<br/>}</pre>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong>.</em><br/>Cars and Motorbikes are also Vehicles as they extend the Vehicle class / Vehicle is the superclass and Car/Motorbike are subclasses;<br/>The subclasses can be cast as/considered to be/referred to as Vehicle which is its superclass;<br/>As Cars and Motorbikes inherit from Vehicles they are also Vehicles and can therefore be stored in an array of type Vehicle;<br/>Arrays must be declared as 1 type, and the state and behaviour of Vehicle is what both Car and Motorbike have in common. Therefore they can be referenced as Vehicles and stored in an array of Vehicles, even though they are subclasses;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This tested the level of understanding of OOP principles. Not many could clearly put into words the specific differences and tended to provide more in the line of definitions. The better students clarified the dependency levels between the different classes.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was well-answered. Most students either used the correct type of arrows or indicated the relationships with the correct expressions (has a etc.).</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Part (i) was well-answered, but few students understood the use of the super modifier in part (ii). All aspects of the OOP course (including inheritance) should be subject to comprehensive practical work in order to promote full understanding.</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Part (i) was well-answered, but few students understood the use of the super modifier in part (ii). All aspects of the OOP course (including inheritance) should be subject to comprehensive practical work in order to promote full understanding.</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The comments for part (d) are also appropriate here.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.11",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-2-features-of-oop",
|
||
"d-1-objects-as-a-programming-concept",
|
||
"d-3-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the difference between an information system and a database.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A bank maintains a database that stores details of clients and their accounts.</p>\n<p>A client wants to transfer money between two accounts held at the same bank.</p>\n<p>Explain how the ACID (Atomicity, Consistency, Isolation, Durability) properties would apply in the context of this database transaction.</p>\n<div class=\"marks\">[8]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A bank holds large volumes of financial and personal information about its clients in its database.<br/><br/>Discuss whether this database should be open to interrogation by the police or the Government.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for a definition of an information system, <strong>[1]</strong> for a definition of a database and <strong>[1]</strong> for the relationship between the two</em>.<br/>An information system is the collection of software, hardware, networking infrastructure, human resources and databases that provide the storage, processing and communication/distribution of information;<br/><em><strong>A database</strong></em> is an organized collection of data (organized so that its contents can easily be accessed, processed, and updated);<br/>A database is a subset of the information system;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[8 max]</strong></em>.<br/><em>Award up to <strong>[2 max]</strong> for each of the four properties,</em><br/><em>Award <strong>[1]</strong> for an explanation of the property and <strong>[1]</strong> in relation to the money transfer transaction</em>.</p>\n<p><em>Example answers</em>:</p>\n<p><strong>Atomicity</strong>:<br/>Ensures that either all changes to data are performed as if they are a single operation or none of them are performed;<br/>In moving money from one account to another, it ensures that if a debit is made successfully from one account then the corresponding credit is made to the other account;</p>\n<p><strong>Consistency</strong>:<br/>Ensures that data is in a consistent state when a transaction begins and when it ends / ensures that only valid data is written in the database;<br/>In transferring money from one account to another, it ensures that the total value of money in both the accounts is the same at the beginning and at the end of each transaction;</p>\n<p><strong>Isolation</strong>:<br/>Ensures that intermediate state of a transaction is invisible to other transactions;<br/>In moving money from one account to another the isolation property ensures that another transaction might see one account or the other but cannot see both accounts;</p>\n<p><strong>Durability</strong>:<br/>Ensures that after a transaction successfully completes, changes to data persist and are not undone even in the event of a system failure;<br/>In moving money from one account to another durability property ensures that the changes made to each account are permanent;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying an advantage of these databases being open to interrogation and an additional <strong>[1]</strong> for each development of that advantage up to <strong>[3 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for identifying a disadvantage of these databases being open to interrogation and an additional <strong>[1]</strong> for each development of that disadvantage up to <strong>[3 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for a valid conclusion.</em><br/><em>If there is no conclusion, award <strong>[5 max]</strong></em>.</p>\n<p><strong>Advantages</strong>:<br/>Sharing the information may enable it to be made accessible to organizations such as the Police or the Government that may not have access to it;<br/>This means that it could be used to detect fraudulent financial activities;<br/>Leading to reduced insurance or health insurance premiums as monies are not lost from the system that create artificially high premiums;</p>\n<p><strong>Disadvantages</strong>:<br/>Misuse of information / security issues;<br/>Information from this database may enable the account details of the clients to be shared with third parties;<br/>Who may use this information to take money from their accounts;</p>\n<p><strong>Conclusion</strong>:<br/>Although the information may be shared, the overall benefits from a reduction in fraudulent crime or inflated insurance premiums is greater than the potential for this information to get into the wrong hands;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.1",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-1-basic-concepts",
|
||
"a-3-further-aspects-of-database-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Global warming is a term used to describe the increase in mean global temperatures.</p>\n<p>There have been numerous computer simulations developed to predict the effects of global warming. One simulation is NASA’s Virtual Earth System Laboratory (VESL), which allows users to see how climate change affects glacier size, global sea level and changes to the coastline.</p>\n<p>The VESL runs simulations in real time and is an abstraction of reality.</p>\n</div><div class=\"specification\">\n<p>A recent study reported that previous simulations of predicted global sea levels for 2100 were highly inaccurate.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline what is meant by a real-time simulation in the context of a glacier size simulation.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline what is meant by the statement “the VESL simulation is an abstraction of reality”.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> reasons why predictions of global sea levels from simulations may not be accurate.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>NASA has decided to make its simulation software available for other scientists as well as members of the public.</p>\n<p>Evaluate the social and ethical implications of this decision.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>A real-time simulation runs at the same rate as the actual physical system;<br/>The change in the glacier size occurs at the same rate as the real change / a virtual glacier will be the same size as the real glacier after the same period of time;</p>\n<p>A real time simulation operations it can mean that it happens without a delay/action carried out before the next input;<br/>Changes to the simulation inputs will be displayed immediately;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Abstraction removes specific detail that will not the accuracy of the simulation / climate change variables that have little influence;<br/>Abstractions helps create the model / reduces the complexity of the model so that it works effectively;<br/>Symbols may be used to represent patterns (e.g. temperature change);</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Sea levels are based on so many factors (e.g. CO<sub>2</sub> emissions, cattle); that it is difficult to accurate predict all of these variables;</p>\n<p>Global events (eg nuclear war, volcanic eruptions);<br/>may cause for an under-prediction;</p>\n<p>Unknown variables (confounding factors) may be affecting rising sea levels;<br/>Population growth may increase or decrease and this may impact upon emissions;</p>\n<p><em>Accept any reasonable argument</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/><em>Award <strong>[3 max]</strong> for positive reasons.</em><br/><em>Award <strong>[3 max]</strong> for negative reasons.</em><br/><em>Award <strong>[1 max]</strong> for a reasonable conclusion.</em></p>\n<p><em><strong>Positive</strong></em><br/>Making it free means more people may use it;<br/>Educating the public may encourage more people to be environmental friendly (e.g. boycott plastics);<br/>This may lead to pressure on governments to reduce emissions;<br/>May provide valuable data for scientists who don’t have access to NASA resources;</p>\n<p><em><strong>Negative</strong></em><br/>Users may not fully understand the simulation results and may misinterpret findings;<br/>May change the perception of the accuracy of the simulation software / Users may not value predictions when the simulator seems so simple;<br/>Predictions that don’t reflect the real change may do damage to public perception of climate change;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.5",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The management of the company will launch a new scheme to give every 50th car driver and every 60th motorcyclist a free coffee voucher. The code for printing this voucher has already been created and is activated by calling the static method <code>Vouchers.printCoffeeVoucher()</code>.</p>\n<p>A <code>getKind()</code> method has already been added to the <code>Vehicle</code> class, which returns a <code>char</code> value indicating whether it is a car (<code>c</code>) or a motorbike (<code>m</code>).</p>\n</div><div class=\"specification\">\n<p>One test performed on the finished code was defined as follows:</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe, <strong>without writing code</strong>, any changes required to the <code>addVehicle</code> method and the <code>ParkingArea</code> class to make the new voucher scheme work.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> other tests you might perform on the completed code to prove that it functions correctly.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The <code>removeVehicle </code>method of the <code>ParkingArea</code> class searches in the array for a <code>Vehicle</code> object with a specified registration plate, then removes it by setting that array index to <code>null</code>.</p>\n<p>The method returns a reference to the <code>Vehicle</code> object that has been removed from the array, or <code>null</code> if no matching registration plate was found.<br/><br/>Construct the <code>removeVehicle</code> method.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong>.</em><br/>Award <strong>[1]</strong> for declaring both the variable for total cars and the variable for total motorbikes at class level (private);<br/>Award <strong>[1]</strong> for initializing the variables, either by calling a mutator method, while declaring, or in the constructor;<br/>Award <strong>[1]</strong> for deciding whether the car or motorbike is 50th or 60th in the daily additions;<br/>Award <strong>[1]</strong> for printing the message if so;<br/>Award <strong>[1]</strong> for incrementing the appropriate counter for the total cars / motorbikes added based on the value returned by <code>getKind()</code>;</p>\n<p><em><strong>Note</strong>: Do not award marks for simply adding mutator or accessor methods for the motorbike / car totals</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong>.</em></p>\n<p><strong>Car</strong>:<br/><em>Award <strong>[1]</strong> for Car count mod 50 is 0, <code>coffee voucher</code>;</em><br/><em>Award <strong>[1]</strong> for Car count mod 50 is n, n <code>coffee vouchers</code>;</em></p>\n<p><strong>Motorbike</strong>:<br/><em>Award <strong>[1]</strong> for Motorbike count mod 60 is not 0, <code>No coffee vouchers</code>;</em><br/><em>Award <strong>[1]</strong> for Motorbike count mod 60 is n, n <code>coffee voucher</code>;</em></p>\n<p><strong>Non Car/Motorbike</strong><br/>Award <strong>[1]</strong> for Any amount of instances of the Vehicle class which are neither Car nor Motorbike, <code>No coffee voucher</code></p>\n<p><em><strong>Note</strong>: do not award a mark for first test case above which is already give in question stem</em></p>\n<p> </p>\n<p><strong>Examples</strong>:</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong>. </em><br/><em>Award <strong>[1]</strong> for correct loop;</em><br/><em>Award <strong>[1]</strong> for checking if not null;</em><br/><em>Award <strong>[1]</strong> for checking registration using the getRegistration().equals() method;</em><br/><em>Award <strong>[1]</strong> for setting vehicles[i] to null;</em><br/><em>Award <strong>[1]</strong> for returning the reference (not the null element of the array), by making another variable;</em><br/><em>Award <strong>[1]</strong> for returning null if it is not found;</em></p>\n<p><strong>Example 1</strong>:</p>\n<pre>public Vehicle removeVehicle(String registration) {<br/>for (int i = 0; i < vehicles.length; i++) {<br/> if (vehicles[i] != null &&vehicles[i].getRegistration().equals(registration)) { //question - why<br/>do it in this order?<br/> Vehicle leaving = vehicles[i];<br/> vehicles[i] = null;<br/> return leaving;<br/> }<br/>}<br/>return null;<br/>}</pre>\n<p><strong>Example 2</strong>:</p>\n<pre>public Vehicle removeVehicle(String registration)<br/> { Vehicle v = null;<br/> boolean found = false;<br/> int i = 0;<br/> while (!found && i < Vehicles.length)<br/> { found = Vehicles[i] != null &&<br/> registration.equals(Vehicles[i].getRegistration());<br/> if (found)<br/> { v = Vehicles[i];<br/> Vehicles[i] = null;<br/> }<br/> else i = i + 1;<br/> }<br/> return v;<br/> }</pre>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a good test of logical thinking. Students need to be precise: \"Include two new integer variables in the <em>ParkingArea </em>class to hold the total number of cars and motorcycles\" is clearly better than \"keep count of the different vehicles\". </p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was poorly answered, with many answers being too vague. Similar to the requirements in the IA-section B, the tests need to give both specific test data and the expected results.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was similar to 11(a) and students who answered the first one successfully also tended to answer this one well. Care needs to be taken when methods return something that types match with the return type indicated in the method signature.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.12",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-3-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A museum has an online catalogue of its pieces. No new pieces have been acquired over the past 20 years, and the museum has already been at risk of closure for lack of funding. Its website consists only of static web pages.</p>\n<p>It is suggested that the museum’s static web pages may be contributing to the museum’s lack of success.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> differences between a static web page and dynamic web page.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Suggest <strong>two</strong> services, and the benefits that they would provide, if the museum were to redesign its website to be dynamic.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the provision of services on the museum’s website can increase its rankings in search engines.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>It is also suggested that the museum’s basic catalogue be revised and upgraded with all of the museum’s pieces being catalogued using meta-tags.</p>\n<p>Suggest how the use of meta-tags can be relevant for search engine optimization.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong> for <strong>three</strong> differences stated</em>.<br/>Dynamic allows user interaction;<br/>Allows parts of the content to be changed without uploading the complete page;<br/>Can connect with server-side databases;<br/>Gives different views for different users;<br/>Includes the use of scripts / server side scripting, examples of;<br/>Dynamic makes use of templates;</p>\n<p>Static webpages are changed only by administrator;<br/>It gives the same view to all users;<br/>It displays exactly the information that is stored in the html file (and it may still include multimedia);<br/>Simpler to develop/maintain, because it does not require major design/knowledge of web applications;<br/>Source code edited directly in HTML generally shorter/less cumbersome than the one developed with web applications;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying a service and <strong>[1]</strong> for stating a benefit, for <strong>two</strong> services up to <strong>[4 max]</strong></em>.</p>\n<p>Book/pre-pay online for tickets;<br/>More convenient for visitors (avoids closures/queues etc.);</p>\n<p>Add a virtual tour of the museum online;<br/>Increases the visibility of the museum / It becomes better known;</p>\n<p>Add an audio-guide for smartphone to be downloaded from the portal;<br/>So that users are already equipped before they visit;</p>\n<p>(Targeted) pop up adverts/links;<br/>Can increase revenue to the museum;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>More possibility for the users to interact will make the website more popular;<br/>More services online provides more ways for the museum to be linked from/to other external organizations/institutions (e.g. bank/tourist office);<br/>The two combined would generate more traffic and more authoritative in-links;<br/>This increases the possibility for the site to be found in a variety of ways when searched;<br/>And this increases the website’s ranking;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[3 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for an example/idea of a meta-tag and its purpose.</em><br/><em>Award <strong>[1]</strong> for understanding the link between meta-tags and indexing via the search operation by crawlers.</em><br/><em>Award <strong>[1]</strong> for understanding the link between indexing and ranking via optimization/better classification by SEO</em>.</p>\n<p>Use of correct keywords allows the search engine to search and find those terms;</p>\n<p><em><strong>For Example</strong></em><br/>Title tags / keywords associated to the title of the page;<br/>A description with tags may induce more visitors to visit the page;<br/>Other keywords that appropriately refer to the content of the web;<br/>(Even irrelevant keywords or hidden content however keyword stuffing might actually be punished by more recent algorithms for ranking);<br/>Meta attributes for robots (such as follow/nofollow, index/noindex) that give indication about whether or not to index the page;<br/>Meta language descriptors (for example to recognize in some language rather than English) to appropriately index content based on the dictionary of that language;<br/>This is related to indexing, because web crawlers visit pages and inspect their content based on the terms that they have to search;<br/>The ranking algorithms give value to the pages once that they are indexed, based on parameters that depend also on the ease of retrieving the pages/number of authoritative in-links/number of hits (or visitors);<br/>The Search Engine can be optimized so that the best use of meta-tags can be made with the objective of indexing and ultimately ranking;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.9",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-2-searching-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The machine instruction cycle is a sequence of actions that a central processing unit (CPU) performs to execute each machine code instruction in a program.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State where the program is held.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the part of the central processing unit (CPU) that performs the decoding.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the function of the memory address register (MAR).</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>RAM;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>CU/Control Unit;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>MAR (is a register in the CPU that) stores the address of the (next) instruction/data;<br/>to be read from/written to RAM;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>A small number of candidates recognised that a program is held in random access memory (RAM) when it is being run. However, a large number of candidates gave less precise or incorrect answers, such as 'in the computer' or 'on the drive'.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates correctly identified the control unit as the part of the central processing unit (CPU) that decodes instructions. Some candidates incorrectly stated the ALU or the CPU, the latter being taken from the question.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A good range of answers was seen for this question with candidates recognising that the memory address register stores the address of the data to be read from or written to the RAM. Candidates who gave a correct answer either achieved one or both marks, depending on whether they covered part or all of the answer.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.4",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>database management system</em> (<em>DBMS</em>).</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> characteristics of logical schema.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the purpose of a data definition language (DDL).</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> tasks that a database administrator carries out to ensure the security of the database.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[1 max]</strong></em>.<br/>A database management system (DBMS) is a set of programs that allows to read, store, change /extract data in a database;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each characteristic of logical schema identified up to <strong>[3 max]</strong></em>.<br/>All attributes for each entity in database are specified; <br/>The primary key for each entity is identified; <br/>Includes all entities and relationships among them; <br/>Keys identifying the relationship between different entities (foreign keys) are specified; <br/>Normalization occurs at logical level;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each identifying the role of Data Definition Language (DDL) and <strong>[1] </strong>for an expansion or explains how it may be used up to <strong>[2 max]</strong></em>.<br/>The Data Definition Language (DDL) are commands which define the different structures/objects in a database;<br/>Database administrators use these commands during the setup and/or removal of a database and database objects (such as tables, indexes, and users);</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each task that a database administrator carries out to ensure the security of the database up to <strong>[2 max]</strong></em>.<br/>DBA sets access levels and passwords;<br/>DBA manages back-up procedures (allow examples of this);<br/>DBA establishes a recovery plan for the database in disaster case;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.2.SL.TZ0.2",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model",
|
||
"a-3-further-aspects-of-database-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A school teacher decides to write a program to store class records and marks. Part of this program involves using a sort algorithm. The algorithm shown is a selection sort and to test it, the teacher has set up an array <code>VALUES[]</code> with 5 elements of test data.</p>\n<pre>LIMIT = 4<br/><br/>loop COUNTER1 from 0 to LIMIT – 1<br/>MINIMUM = COUNTER1<br/><br/> loop COUNTER2 from COUNTER1 + 1 to LIMIT<br/> if VALUES[COUNTER2] < VALUES[MINIMUM] then<br/> MINIMUM = COUNTER2<br/> end if<br/> end loop<br/><br/> if MINIMUM ≠ COUNTER1 then<br/> TEMPORARY = VALUES[MINIMUM]<br/> VALUES[MINIMUM] = VALUES[COUNTER1]<br/> VALUES[COUNTER1] = TEMPORARY<br/> end if<br/><br/>end loop</pre>\n</div><div class=\"specification\">\n<p> <img src=\"\"/><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> variables that have been used in the algorithm.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the table below to trace the algorithm using the data set:</p>\n<p>20, 6, 38, 50, 40</p>\n<p><img src=\"\"/></p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the algorithm in the flow chart, construct this algorithm in pseudocode so that it performs the same function.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the type of sort in the algorithm constructed in c(i).</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm fragment to output the data in the array <code>VALUES[].</code></p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The sorting algorithm could be part of a sub-program within a larger program.<br/><br/>Explain the benefits of using sub-programs when constructing a larger program.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for any <strong>two</strong> from</em>:</p>\n<pre>LIMIT;<br/>MINIMUM;<br/>COUNTER1;<br/>COUNTER2;<br/>TEMPORARY.</pre>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><img src=\"\"/></p>\n<p><em>Award <strong>[5 max]</strong></em>.<br/>Both <code>COUNTER1</code> and <code>COUNTER2</code> correct;<br/><code>MINIMUM</code> column correct;<br/>Final <code>VALUES[]</code> 0, 1, 2 correct;<br/>Final <code>VALUES[]</code> 3, 4 correct;<br/><code>TEMPORARY</code> column correct;</p>\n<p><em>Note to examiners</em>:<br/><em>Allow follow through (FT)</em>.<br/><em>In case of different representation of values in columns COUNTER1 and COUNTER2, then FT, award marks for the correct values of the variables MINIMUM and TEMPORARY</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Use of correct nested loops;<br/>Correct use of flag;<br/>Inner loop checking adjacent cells;<br/>Values being swapped if necessary;</p>\n<p><em>Example algorithm 1</em>:</p>\n<pre>LIMIT = 4<br/>FLAG = TRUE<br/>loop while FLAG = TRUE<br/> FLAG = FALSE<br/> loop COUNTER from 0 to LIMIT - 1<br/> if VALUES[COUNTER] > VALUES[COUNTER + 1] then<br/> TEMPORARY = VALUES[COUNTER]<br/> VALUES[COUNTER] = VALUES[COUNTER + 1]<br/> VALUES[COUNTER + 1] = TEMPORARY<br/> FLAG = TRUE<br/> end if<br/> end loop<br/>end loop</pre>\n<p><em><strong>A recursive solution is allowed at HL. SL candidates who submit an above level recursive solution should also receive credit</strong></em>.</p>\n<p><em>Version 1 – basic recursive solution</em></p>\n<p><em>Award <strong>[3 max]</strong></em>.<br/>BUBBLESORT defined as a procedure with correct pass through parameters and end/return statement;<br/>Correct loop with values swapped if necessary inside procedure;<br/>Recursive call of BUBBLESORT with parameters passed;<br/>Correct condition for recursive call;</p>\n<p><em>Example algorithm 2</em></p>\n<pre>LIMIT = 4<br/>BUBBLESORT(VALUES, LIMIT)<br/> loop COUNTER from 0 to LIMIT - 1<br/> if VALUES[COUNTER] > VALUES[COUNTER + 1] then<br/> TEMPORARY = VALUES[COUNTER]<br/> VALUES[COUNTER] = VALUES[COUNTER + 1]<br/> VALUES[COUNTER + 1] = TEMPORARY<br/> end if<br/> end loop<br/> if LIMIT – 1 > 1 then<br/> call BUBBLESORT(VALUES, LIMIT - 1)<br/> end if<br/>end BUBBLESORT</pre>\n<p><em>Version 2 – more efficient recursive solution</em></p>\n<p><em>Award <strong>[3 max]</strong>.<br/></em>BUBBLESORT defined as a procedure with correct pass through<br/>parameters and end/return statement;<br/>Correct loop with values swapped if necessary inside procedure;<br/>Recursive call of BUBBLESORT with parameters passed;<br/>Correct condition for recursive call;<br/>Correct use of flag;</p>\n<p><em>Example algorithm 2</em></p>\n<pre>LIMIT = 4<br/>BUBBLESORT(VALUES, LIMIT)<br/> FLAG = FALSE<br/> loop COUNTER from 0 to LIMIT - 1<br/> if VALUES[COUNTER] > VALUES[COUNTER + 1] then<br/> TEMPORARY = VALUES[COUNTER]<br/> VALUES[COUNTER] = VALUES[COUNTER + 1]<br/> VALUES[COUNTER + 1] = TEMPORARY<br/> FLAG = TRUE<br/> end if<br/> end loop<br/> if LIMIT – 1 > 1 and FLAG = TRUE then<br/> call BUBBLESORT(VALUES, LIMIT - 1)<br/> end if<br/>end BUBBLESORT</pre>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Bubblesort;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Use of (any type of) loop;<br/>Correct output statement;</p>\n<p><em>Example algorithm</em>:</p>\n<pre>loop COUNTER from 0 to LIMIT<br/> output VALUES[COUNTER]<br/>end loop</pre>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Sub-programs contain reusable code (for use in other programs);<br/>A large programming project can be divided into sub-programs;<br/>Different sub-programs can be constructed by different programmers;<br/>Future maintenance is easier due to the organisation of the large program (into sub-programs);</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>No real problems noted with this question other than a few candidates did not accurately copying the variable names as provided in the algorithm.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many fully correct or partially correct responses to this question were seen, however, a significant number of candidates did not fully trace the algorithm to its conclusion, therefore limiting their mark for the question.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates attempted to construct this algorithm and the vast majority made use of pseudocode, rather than a programming language, unfortunately, very few achieved full marks. The usual reason was that candidates did not give a nested loop, which made the awarding of full marks difficult, as the outer loop also makes use of a flag as its terminal condition, therefore also affecting one of the other marking points. Many candidates incorrectly made use of the conditional IF statement as though it was a loop, thereby creating an ‘IF loop’.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates recognised that the algorithm was a sorting routine, but not all specified the correct type. Other candidates thought it was a search routine.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A number of versions of correctly operating responses were seen for this question, some of which were given in pseudocode, others were in programming code. However, a small number of responses were not given inside a loop, so therefore would only print one of the values.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many responses seen were quite brief making it difficult to award all the marks, as the responses did not cover sufficient distinct marking points. However, the responses seen demonstrated that candidates understood the benefits of using sub-programs when constructing a larger program, and with a bit more detail in their answer, could have achieved full marks.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19M.1.SL.TZ0.16",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming",
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>The Ministry of Tourism</em> intends to include data from a number of sources in a data warehouse in an attempt to improve the services the tourism companies offer to their customers.</p>\n</div><div class=\"specification\">\n<p><em>The Ministry of Tourism</em> will use data mining to provide the Government with information that it can use to promote and support tourism in the country.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>four</strong> sources of information that could be incorporated in the data warehouse.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> differences between a data warehouse and database.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the Extract, Transform, Load (ETL) processes can be used to address the problems related to data migration.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> ethical problem that may result from data mining.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how cluster analysis can be used to improve the advertising strategy of the tourism companies.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the importance of link analysis in exploring patterns in data mining.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for each source of information up to <strong>[4 max]</strong></em>.</p>\n<p>For example,<br/>Sources of travel information such as airports, ports, bus/train;<br/>Sources of personal data about tourists (such as age, gender, etc.);<br/>Sources of social data about tourists (such as family status, occupation, economic circumstances, etc.);<br/>Sources of information about the tourism products and services these tourists booked such as:</p>\n<ul>\n<li>accommodation (hotels, camps, apartments);</li>\n<li>attractions (natural parks, palaces, museums);</li>\n<li>activities (yachting, biking, diving, fishing, surfing);</li>\n</ul>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for each identifying a difference between a data warehouse and a database and <strong>[1]</strong> for an expansion up to <strong>[2 max]</strong>.</em><br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>Database is based on operational processing;<br/>Whilst data warehouse is based on informational processing;</p>\n<p>The operations on databases consist of transactions;<br/>Whilst operations on data warehouse consist of queries;</p>\n<p>Database is used for everyday transactions;<br/>Whilst data warehouse is used for decision support;</p>\n<p>Database mainly stores current data;<br/>Whilst data warehouse stores historical data;</p>\n<p>Data in the database is always up to date/accurate;<br/>Whilst the data in data warehouse is maintained over time;</p>\n<p>Data in the database is simple/primitive/detailed;<br/>Whilst data warehouse holds summarized/consolidated data;</p>\n<p>The type of access to data in database is read/write;<br/>Whilst mostly read only access for the data stored in data warehouse;</p>\n<p>Database size is smaller (for example in up to 10GB);<br/>Than the size of data warehouse (for example 100GB to TB);</p>\n<p>View of data in database is flat/relational;<br/>Whilst the view of data in data warehouse is multidimensional;</p>\n<p>Users (end-users) of the database are common users (for example customers, tourists, clerks, etc.);<br/>Whilst end-users of data warehouse are knowledge users (for example, analysts, managers, executives);</p>\n<p>The number of database users is greater;<br/>Whilst the data in data warehouse is used by smaller number of people;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong>.</em><br/><strong>Extract data</strong><br/><em>Award <strong>[1 max]</strong> for an explanation of how the extraction process can be used to address the problems related to data migration</em>.</p>\n<p>Pulling data from different source databases/ from various source systems (e.g. MS Access, SQL Server, Oracle, etc.);</p>\n<p><strong>(Cleanse and) transform data (so that data is clean and useful for a purpose)</strong><br/><em>Award <strong>[1 max]</strong> for an explanation of how the transformation process can be used to address the problems related to data migration</em>.</p>\n<p>Trimming for white space/ proper data type/do some validation, etc.;</p>\n<p><strong>Load data</strong><br/><em>Award <strong>[1 max]</strong> for an explanation of how the load process can be used to address the problems related to data migration</em>.</p>\n<p>Transfer data into data warehouse/ data mart/operational data store so it can be used for the mining processes within the data warehouse;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for each identifying an ethical problem that may result from data mining and <strong>[1]</strong> for an expansion up to <strong>[2 max]</strong></em>.</p>\n<p>Data mining raises privacy concerns when people are traced;<br/>Their actions are analyzed without their knowledge;</p>\n<p>Data mining creates people/tourist/customer files with a tendency of judging and treating people on the basis of group characteristics;<br/>Instead of on their own individual characteristics;</p>\n<p>Data mining can provide information that could be used unethically;<br/>For example, increasing profits by selling this information to others / or by targeting return tourists with information obtained on their previous visits;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[2 max]</strong> for evidence that candidates understand how cluster analysis is used and <strong>[2 max]</strong> for an explanation related to tourism products/services</em>.</p>\n<p><strong>Cluster analysis</strong>:<br/>Subdivide tourists into distinct subsets;<br/>Where any subset may be selected as a market target;</p>\n<p><strong>Explanation related to tourism products/services</strong>:<br/>Subsets could be “young tourists with limited budget”;<br/>For this subset music festivals, sport could be advertised to ensure the hotel can maximize its revenue;</p>\n<p>Subset of tourists traveling with young children;<br/>Children activities / sports / games available / “kids hotels” could be advertised to ensure the hotel can maximize its revenue;</p>\n<p>Subset of older tourists influenced by cost–value considerations and/or secure/or quiet environment;<br/>So these hotels can be configured to specifically meet their needs and promoted only to these tourists such as advertise “stay 7 days and pay only 6 days” / advertise hotel located in the quiet place/secure place / at some distance from the center;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for each identifying the importance of link analysis in exploring patterns in data mining and <strong>[1]</strong> for each subsequent expansion up to <strong>[3 max]</strong></em>.</p>\n<p>Link analysis technique is used to analyse connections/links between small instances of relational databases / only on required datasets of database/;<br/>(But) it can also be applied on large number of databases to show the relationships between these databases;<br/>Link analysis is important because it discovers new relations in relational databases / new patterns of interest / checks the similarity between the datasets / finds anomalies where old/known patterns are violated;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "18N.2.HL.TZ0.4",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-4-further-database-models-and-database-analysis"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p style=\"text-align: left;\">Simulation software can be used to produce a 3D visualization of rising sea levels that change as the user alters the percentage of ice that has melted.</p>\n<p style=\"text-align: center;\"><strong>Figure 3: 3D visualization of rising sea levels</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align: center;\">[Source: Courtesy NASA/JPL-Caltech.]</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>visualization</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify how a 2D visualization could be used in this scenario.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the benefits of using visualization when simulating rising sea levels.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Once the 3D visualization has been rendered, when the user drags a slider bar to simulate the amount of ice that has melted, the visualization is re-rendered without any delay.</p>\n<p style=\"text-align:center;\"><strong>Figure 4: Slider bar to simulate different percentages of sea ice</strong></p>\n<p style=\"text-align:center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align:center;\">[Source: Courtesy NASA/JPL-Caltech.]</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>A visualisation is graphical software technique that creates an image / diagram / graph to communicate data;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>2D map of a coastline;<br/>standard flat map;<br/>cross-section of the land;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/>Visualizations provides a quick way of seeing where the sea levels are now and where they will be if the glaciers melt;<br/>People can understand a visual image more easily than raw data;<br/>No need to interpret figures so time is saved;<br/>A visual of land being claimed by the water has greater emotional impact that raw data;<br/>Public / politicians are more likely to be influenced by a visualization than raw data;</p>\n<p><em>Accept other reasonable reasons</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/>Wireframe model is created with polygons;<br/>The 3D rendering process automatically converts a 3D wireframe model into 2D images on a computer;<br/>2D images are combined to create a 3D image;<br/>3D renders may, or may not, use photorealistic effects;<br/>It is likely that scanline rendering would be used because it uses less processing / system resources than ray tracing;<br/>it is unlikely that ray tracing would be used because of the time taken for rendering;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.6",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-3-visualization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Genetic algorithms are used to influence the behaviour of non-playing characters (NPCs) in role-playing games (RPGs). NPCs are computer-controlled characters that the player interacts with but does not control.</p>\n</div><div class=\"specification\">\n<p>A series of generic NPCs are being developed for use in any multi-player RPG. The environmental and social interactions of these NPCs are being developed using supervised learning and will continue to develop as the game is played.</p>\n</div><div class=\"specification\">\n<p>Once NPCs have completed their supervised training, they are placed in a dynamic game environment. Each NPC learns to adapt its behaviour to its environment.</p>\n<p>At this stage of the training, NPCs will not be verbally communicating with other characters in their environment.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> advantages of developing NPCs using genetic algorithms.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how supervised learning of a genetic algorithm could be used to support the way NPCs learn.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the way an NPC in a game could adapt its behaviour when moving and interacting with its environment.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The last stage of NPC development is verbal communication with player characters and other NPCs. To assist with this process, it was decided to explore research related to chatbots.</p>\n<p>Explain the benefits of giving NPCs the functionality of chatbots.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>No need to anticipate and code in advance the reactions that NPCs need to display;<br/>since the supervised training will ensure the characters can adapt their responses;</p>\n<p>Save programmers development time;<br/>because NPCs can be used in similar RPG games;</p>\n<p>Provides greater game realism;<br/>NPC characters would evolve to behave more like real people;</p>\n<p>NPCs would remember previous encounters with players;<br/>thus, altering their gameplay rather than running through a loop;</p>\n<p><em>Mark as 2 + 2</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/>Start with a set of “units” (here, NPCs) with some predetermined code/behaviour with added randomness / genetic algorithms work successively towards a solution from a starting point;<br/>Apply a process of selection to the units, so that the probability of survival depends on their success against some predetermined criteria;<br/>Supervised learning has training data with a known set of responses to a known set of problems;<br/>The fitness function (defined by the programmers) limits the adaptability of a given population of NPCs to the skills or tasks defined by the fitness function;<br/>A <em>(fitness) function</em> is used to measure the effectiveness of a solution / offspring (respawned NPCs) are evaluated using a fitness function;<br/>The best solutions are retained / worse solutions are discarded / the most adaptive NPCs will remain in the population and others removed (die);<br/>The retained solutions are mutated (randomness) to generate another set of solutions / retained NPCs are mutated and respawned / recloned;<br/>This process is repeated until the best solution is identified / repeated until the most adaptable NPC model is identified;</p>\n<p><em>Accept other reasonable reasons or examples</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/>The NPC makes a random set of moves;<br/>Records the location/identity of objects relative to its current position;<br/>Building up a map of identifyable surrounding objects;<br/>This is repeated until all objects in the space have been placed in distance and direction from a starting point;<br/>The NPC would learn how to react to the object (e.g. swim in a river / walk on a path);<br/>NPC would learn where it could walk and where it could not (e.g. river would need to be avoided);<br/>NPCs that die could be regenerated from ones that had avoided dying up to that point in the game;<br/>NPC would adapt to a changing environment e.g. a house built in a game;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Chatbots are designed to output language in response to human language;<br/>Most NPC conversations are scriptive speeches / repetitive…<br/>so using chabots will add more realism to the game;<br/>NPCs could verbally communicate in script or sound form;<br/>There would still need to be some hardcoded responses that relate to the game storyline;<br/>Natural language processing (NLP) could be applied to chatbot conversations;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.2.HL.TZ0.8",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Describe the steps involved in using the bubble sort algorithm to sort an array.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for looping through array;</em><br/><em>Award <strong>[1]</strong> for comparing each pair of adjacent items (in the array);</em><br/><em>Award <strong>[1]</strong> for swapping them if they are in the wrong order;</em><br/><em>Award <strong>[1]</strong> for repeating this until no swaps is required (which indicates that the array is sorted);</em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were required to write the main steps involved in a bubble sort algorithm. Candidates who wrote their answer in algorithmic form achieved better results than those who simply described the process. The full range of marks, from zero to four were achieved for this question. Some candidates lost out because they described a different sort routine than the bubble sort required in the question. Other candidates were able to demonstrate well how the bubble sort operated for one pass of the algorithm but forgot to mention that it would repeat until no swaps had been required.</p>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.5",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A restaurant uses an object-oriented program to manage the cost of the food and drink consumed by customers. Everytime a table is occupied a <code>Payment</code> object is instantiated which will contain details of the items ordered. As each item is ordered, a <code>FoodItem</code> or a <code>DrinkItem</code> object is added to the <code>Payment</code> object as appropriate.</p>\n<pre><strong>public class</strong> Payment<br/>{<br/><strong> private</strong> FoodItem[] fi = <strong>new</strong> FoodItem[100];<br/><strong> private int</strong> fiCount;<br/><strong> private static double</strong> foodTax = 0.2; // 20 % sales tax added to<br/> // all food prices<br/><strong> private</strong> DrinkItem[] di = new DrinkItem[100];<br/><strong> private int</strong> diCount;<br/><strong> private static double</strong> drinkTax = 0.1; // 10 % sales tax added to<br/> // all drink prices<br/><strong> public</strong> Payment()<br/> {<br/> fiCount = 0;<br/> diCount = 0;<br/> }<br/><strong> <br/> public</strong> DrinkItem getDi(int x)<br/> {<br/><strong> return</strong> di[x];<br/> }<br/><br/> // all other accessor and mutator methods are included<br/> <br/> // addFoodItem() – this method adds a new FoodItem object<br/> // addDrinkItem() – this method adds a new DrinkItem object<br/><br/><strong> public static double</strong> findPrice(Item[] pl, String c)<br/> { //code missing }<br/><br/> // calculateBill() – This method returns the bill (the total value of<br/> // the items consumed for a particular table)<br/>}<br/><br/><strong>public class</strong> FoodItem<br/>{<br/> <strong>private</strong> String itemCode;<br/> <strong>private int</strong> quantity;<br/><br/> <strong>public</strong> FoodItem(String x, int y)<br/> {<br/> itemCode = x;<br/> quantity = y;<br/> }<br/> // all accessor and mutator methods are included<br/>}</pre>\n<pre>The DrinkItem class is defined in a similar way.</pre>\n</div><div class=\"specification\">\n<p>Whenever a <math style=\"font-family:'Courier New'\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>Payment</mi></math> object is instantiated, the variables <math style=\"font-family:'Courier New'\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>fiCount</mi></math> and <math style=\"font-family:'Courier New'\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>diCount</mi></math> are initialized to 0 through the code in the constructor.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline an alternative method of initializing these variables that would not require the use of the code in the constructor.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the implication of the use of the term <code>static</code> in the <code>Payment</code> class.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to <strong>two</strong> examples from the classes in the resource, explain the benefits gained by the use of different data types.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p style=\"text-align:center;\">Describe the purpose of the following statement:<br/><br/><code><strong>private</strong> FoodItem[] fi = <strong>new</strong> FoodItem[100]</code></p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The <code>Payment</code> class method <code>addFoodItem()</code> is passed a <code>FoodItem</code> object as a parameter.</p>\n<p>Construct the method <code>addFoodItem()</code>.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying the code and <strong>[1]</strong> for identifying the new position</em>.<br/><code>private int fiCount = 0</code> and <code>private int diCount = 0</code>;<br/>In the variable/attribute section of the class and not in the constructor);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em><strong>EITHER</strong></em><br/>The <span style=\"text-decoration:underline;\">values</span> of these (static) variables;<br/>Are the same for all objects;<br/>They belong to the class (not to the objects);<br/>And are only created/declared once;<br/><em><strong>Note</strong>: Do not accept “cannot be changed”</em>.</p>\n<p><em><strong>OR</strong></em><br/>The static methods;<br/>Are class methods (not object methods);<br/>Are independent of the objects in the class;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 × 2]</strong> for each clear example. Only award <strong>[2]</strong> for an example if the benefit is clearly shown</em>;</p>\n<p>Having different data types allow different operations to be carried out depending upon the type;<br/>e.g.<br/>Calculations in the integer “quantity” variable;<br/>which are not possible for a String;</p>\n<p>Double instead of integer allows the use of decimals;<br/>which mirrors real-life scenarios/allows more precise calculations;</p>\n<p>Using an array (of objects);<br/>Allows individual items to be accessed/processed more easily;</p>\n<p>Memory usage can be reduced;<br/>e.g. “<code>fiCount</code>” takes up less space as an integer than it would as a double (assuming it’s just a number);</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The variable <code>fi</code> is declared as an array of <code>FoodItem</code> objects / of type <code>FoodItem</code>;<br/>With (a maximum of) 100 values;<br/>It cannot be directly accessed/it is encapsulated within the Payment class;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each correct line of code</em>.</p>\n<pre>public void addFoodItem(FoodItem f)<br/>{<br/> fi[fiCount] = f;<br/> fiCount++;<br/>}</pre>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.10",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-3-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Pugh University has a website that allows computer science students to enter their name and customize the web pages.</p>\n<p>Consider the section of HTML and CSS code shown below.</p>\n<p>File name: index.html</p>\n<pre><!DOCTYPE html><br/><html><br/><body><br/><script><br/> function setVar(){<br/> var subject=document.getElementById(\"kippers\").value;<br/> document.getElementById(\"subj\").innerHTML = subject;<br/> }<br/></script><br/><h2>My First Page</h2><br/><p>Welcome to the <span id=\"subj\"></span> Faculty</p><br/><br/><input type=\"text\" id=\"kippers\"/><br/><button onclick=\"setVar();\"/>clickme</button><br/></body><br/></html></pre>\n</div><div class=\"specification\">\n<p>When a student enrolls, they must enter their name on a web page. Before being added to the database, the system should check that the name typed is not blank and that it has not already been added to the database.</p>\n</div><div class=\"specification\">\n<p>Consider the following URL:</p>\n<p style=\"text-align: center;\">https://www.follettibstore.com</p>\n</div><div class=\"specification\">\n<p>The common gateway interface (CGI) offers a standard protocol for web servers.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the output of the <code>index.html</code> file in the web browser.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the processing that takes place when the user inputs “Pugh” into the text box and then uses the <code>clickme</code> button.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why these <strong>two</strong> validation checks occur on different computer systems.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how website certificates are used to authenticate a user’s browser through secure protocol communications like HTTPS.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the working of the common gateway interface (CGI).</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Pugh University uses cloud computing services, such as Google Docs or Office 365.</p>\n<p>Describe how cloud computing is different to a client–server architecture.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for the text within the <p> tags (My First Page large font/Welcome to the Faculty in a smaller font;</em><br/><em>Award <strong>[1]</strong> for the text box and correctly labelled button;</em></p>\n<p><em><img src=\"\"/></em></p>\n<p><em><strong>OR</strong><br/></em></p>\n<p><em>Award <strong>[2 max ]</strong>.<br/></em>Initially it displays:<br/>My First Page – in large font;<br/>Welcome to the Faculty – in normal font;<br/>A text box + a button labelled “clickme”;<br/>A Then if you type in the text box and then press the button, it displays what is typed between “Welcome to the” and “Faculty” – e.g. type “Science” and it will display; “Welcome to the Science Faculty”;<em><br/></em></p>\n<p><em><strong>Note</strong>: Students either show the output on the web-browser or describe what would be displayed on the web-browser.</em></p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>The button’s onclick method is called, i.e. setVar();<br/>This first sets the variable subject to the value of the HTML element with id kippers, i.e. the text box;<br/>and then sets the inner text of the element with id subj, i.e. the span, to “Pugh”, so that the display is “Welcome to the Pugh Faculty”;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for identifying correct validation check.</em><br/><em>Award <strong>[1]</strong> for describing the validation check.</em></p>\n<p><strong>Presence check</strong>:<br/>It happens in JavaScript in the web page on the <strong>client</strong>;<br/>because this will save the server handling many transactions/to avoid sending a null value that will need to be handled by the server;</p>\n<p><strong>Lookup check</strong><br/>It happens on the <strong>server</strong>;<br/>because the database is stored on the server rather than on the client’s computer;</p>\n<p><em>Mark as <strong>[2]</strong> + <strong>[2]</strong></em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>The website certificate is used to initiate sessions between the user’s browser and the server;<br/>The web server sends the browser a copy of its SSL certificate;<br/>If the browser trusts the certificate, it sends a message to the web server;<br/>The web server sends back a digitally signed acknowledgement to start an SSL encrypted session;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>The Common Gateway Interface (CGI) is used to provide interactivity to web applications/enable forms to be submitted;<br/>It uses a standard protocol that acts as an intermediary between the CGI program and the web server;<br/>The CGI allows the web server to pass a user’s request to an application program;<br/>And then the forwarded data is received to the user’s browser;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Cloud computing is based on sharing computing resources over the internet;<br/>Cloud computing can be offered as a service to individuals and companies (SaaS) which means they do not have to maintain the infrastructure;<br/>Cloud computing and applications are more scalable than client-server architectures;<br/>Client-server architecture does not need to be operating over the internet, but instead can be limited to a local network;<br/>Client-server architectures may require more maintenance of the infrastructure by the organization who are using it;<br/>cloud computing is typically more resilient than client server, because the services offered are more widely distributed, rather than being concentrated on one server or on a small number of alternative servers;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not all students were familiar with the processing of web scripts. The processing of such scripts is fundamental to the functioning of the web commercially and is an important part of the Web Science course.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not all students were familiar with the processing of web scripts. The processing of such scripts is fundamental to the functioning of the web commercially and is an important part of the Web Science course.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was testing the students' knowledge of client-side and server-side processing. Not many brought this aspect into their answers. As with part (a) more practical experience is recommended.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Poorly answered. Not many understood what these certificates were and even fewer could correctly explain the process involved.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Students were more comfortable with this concept and were aware of its role as an intermediary between application and server.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a comparison question which required relating different aspects to both paradigms. It was not answered particularly well.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.7",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-4-the-evolving-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The World Wide Web can be represented as a web graph.</p>\n</div><div class=\"specification\">\n<p>The World Wide Web has expanded significantly over the last 10 years. In June 2018, there were an estimated 1600 million websites and 4100 million users. This is approximately twice the figures of January 2014.</p>\n</div><div class=\"specification\">\n<p>The World Wide Web can be divided into the text web and the semantic web.</p>\n</div><div class=\"specification\">\n<p>The development of technologies that underpin the World Wide Web has led to the growth of ambient intelligence and collective intelligence.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how a web graph can be used to represent the connectivity of the World Wide Web.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why a user can still navigate from one web page to another web page in the same amount of time as previously, even though the number of web pages is significantly larger.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> reasons why there needs to be a balance between expressivity and usability on the semantic web.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> features of ambient intelligence.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the role of collective intelligence in the advancement of human knowledge.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>In graph theory, a graph is a set of nodes (also called vertices) that can be connected through edges;<br/>In a web graph each web page is represented by a vertex;<br/>In a web graph each hyperlink is represented by a directed edge;<br/>Therefore, the web graph provides a representation / model of the connectivity of the World Wide Web;<br/>The direction of the edge is from the page with the hyperlink to the page that is the target of the hyperlink;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Although the growth in the number of web-pages on the World Wide Web has increased exponentially, the diameter of the World Wide Web increases linearly;<br/>The increase in routing hubs may lead to a more efficient routing algorithm being used;<br/>And in combination with the increasing speed of web-pages loading;<br/>Means that despite the significant increase in the number of web-pages, despite there being an increase in the number of hops required to navigate from one web-page, there may be no discernable increase in time for this process to occur;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>The semantic web is based on data and enables computer systems to understand the meaning of information and its relation to other pieces of information;<br/>this increased usability is dependent on the ability of the different computers to process the intended meaning of content better;<br/>however, giving information more expressive power may come at an expense of usability;<br/>for example, a language such as RDF can be highly expressive power, but requires the user to specify relations of information to other information;<br/>in some cases, it may be beneficial to create shared databases (i.e. increase the usability);<br/>but, there may be other cases where the increased expressivity leads to a decrease in usability;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>embedded, devices are integrated into their environment;<br/>context aware, these technologies can adapt to the needs of the user;<br/>machine learning, these technologies can learn from previous behaviors;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/>Collective intelligence is the intellectual by product of a group of people working together;<br/>This ability to harness the benefits of collective intelligence have been made possible by the development of the internet;<br/>Collective intelligence can be used for a variety of purposes, for example linked to social media (Facebook and Twitter), gaming sites (Online Multi-player games), Scientific research (Large hadron Collider and Wikipedia;<br/>Collective intelligence benefits from the open sharing of resources and may allow for a more rapid evolution of ideas than ‘traditional’ methods;<br/>Collective intelligence may not have a central authority, so the user created information may be considered to be factual when it is not;<br/>Collective intelligence may lead to a disruption in the way that knowledge is stored or classified, i.e. the development of folksonomies in place of ontologies;<br/>The lack of a formal organizational structure may lead to the acquisition of the collective intelligence being potentially piecemeal or haphazard;<br/>There may be no owner of this additional knowledge, so it may not be stored or maintained in the most efficient manner;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many answers identified the fundamental elements nodes, vertices, edges, and some also made references to the identification of the SCC.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Two reasons, the advance in technology leading to increase in the speed of operations and the linear increase of the web's diameter showed that some schools had investigated this aspect of the developing web.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>There were few full marks with most students failing to make reference to the ability of devices to adapt.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was reasonable well-answered, with references both to positive and negative aspects.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "20N.2.HL.TZ0.12",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-5-analysing-the-web",
|
||
"c-6-the-intelligent-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline why single processor computers may not be able to render 3D graphics effectively.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Single processor is mainly occupied with the OS jobs / might not be able to handle multiple jobs/;<br/>Rendering 3D graphics requires a great deal of processing (which a single processor may not be able to give);</p>\n<p>If attempting rendering on a single processor, a (very) high clock speed is required;<br/>which may not be available;</p>\n<p>3D graphics processing is (inherently) parallel;<br/>A single processor is not able to handle parallel processing;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Not an easy question for many candidates.</p>\n</div>",
|
||
"question_id": "19M.1.HL.TZ0.4",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The global variable <code>tables</code> is declared as follows:</p>\n<p style=\"text-align: center;\"><code>Payment[] tables = <strong>new</strong> Payment[50]</code>;</p>\n<p style=\"text-align: left;\">The indices in this array represent the table number, so <code>tables[1]</code> is a <code>Payment</code> object for the customers occupying table number 1.</p>\n<p style=\"text-align: left;\">The driver (main) class contains the following code. <strong>Note</strong>: You can assume that all appropriate accessor and mutator methods have been included in their respective classes.</p>\n<pre style=\"text-align: left;\">tables[1] = <strong>new</strong> Payment();<br/>tables[2] = <strong>new</strong> Payment();<br/>FoodItem a = <strong>new</strong> FoodItem(\"f102\", 2);<br/>FoodItem b = <strong>new</strong> FoodItem(\"f100\", 1);<br/>DrinkItem c = <strong>new</strong> DrinkItem(\"d102\", 3);<br/>tables[1].addFoodItem(a);<br/>tables[1].addFoodItem(b);<br/>tables[2].addDrinkItem(c);<br/>tables[2].addDrinkItem(new DrinkItem(\"d103\",1));<br/>System.out.println(tables[1].getFiCount());<br/>System.out.println(Payment.getFoodTax());<br/>System.out.println(tables[2].getDi(1).getItemCode());</pre>\n</div><div class=\"specification\">\n<p>The price of each item is stored in an object of the <code>Item</code> class.<br/>The class is outlined below:</p>\n<pre><strong>public class</strong> Item<br/>{<br/><strong> private</strong> String code; // item code<br/><strong> private</strong> String name; // item name<br/><strong> private double</strong> price; // unit price before tax<br/> // all accessor, mutator and constructor methods are included<br/>}</pre>\n<p>All of the objects in this class are held in the global array <code>pl</code> according to the following declaration: </p>\n<p><code>Item[] pl = new Item[200]</code>; </p>\n<p><strong>Note</strong>: The number of objects held in this array will change from week to week.</p>\n<p>The method <code>findPrice(Item[] pl, String c)</code> in the <code>Payment</code> class looks up and returns the price of the item with code <code>c</code>.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the output after this code is executed.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct statements, in code, that will print out the following: The number of drink items ordered by table 40.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct statements, in code, that will print out the following: The item code of the third food item ordered by table 2.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method <code>findPrice()</code>. You may assume that the item exists in the array.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>When a customer wishes to pay the bill, the <math style=\"font-family:'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>calculateBill</mi><mo> </mo><mo>(</mo><mo> </mo><mo>)</mo></math> method is called. If the bill was for table 10 then the following call would be made:</p>\n<p style=\"text-align:center;\"><code><strong>double</strong> finalBill = tables[10].calculateBill(Item[] pl)</code>;</p>\n<p>Construct the <code>calculateBill()</code> method. You should make use of any previously defined methods.</p>\n<div class=\"marks\">[7]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each correct value</em>.<br/>2;<br/>0.2;<br/>d103;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><code>System.out.println(tables[40].getDiCount())</code>;</p>\n<p><em>Allow variations of the <code>get</code> method name</em></p>\n<p><em><strong>Note</strong>: Ignore minor syntax errors.</em></p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><code>System.out.println(tables[2].getFi(2).getItemCode());</code></p>\n<p><em>Allow variations of the <code>get</code> method name</em></p>\n<p><em><strong>Note</strong>: Ignore minor syntax errors.</em></p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[6 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for correct initialization.</em><br/><em>Award <strong>[2]</strong> for loop that checks entries, but has early exit.</em><br/><em>Award <strong>[1]</strong> for a loop that checks all 200 entries with no early exit.</em><br/><em>Award <strong>[1]</strong> for correct assignment.</em><br/><em>Award <strong>[1]</strong> for correct comparison.</em><br/><em>Award <strong>[1]</strong> for correct return value.</em><br/><em>Award <strong>[1]</strong> for both the assignment and comparison <strong>IF</strong> <code>get</code> methods are not used.</em></p>\n<pre>public static double findPrice(Item[] pl, String c)<br/>{<br/> int x = 0;<br/> double price = 0.0;<br/> boolean found = false;<br/> while(!found)<br/> {<br/> if ((pl[x].getCode()) == c)<br/> {<br/> price = pl[x].getPrice();<br/> found = true;<br/> }<br/> x++;<br/> }<br/> return price;<br/>}</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[7 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for correct method header.</em><br/><em>Award <strong>[1]</strong> for correct initialization.</em><br/><em>Award <strong>[1]</strong> for correct loop.</em><br/><em>Award <strong>[1]</strong> for finding item code.</em><br/><em>Award <strong>[1]</strong> for use of <code>findPrice</code> method.</em><br/><em>Award <strong>[2]</strong> for the calculation if completely correct, award only <strong>[1]</strong> if taxes are wrong and/or no use of accessor.</em><br/><em>Award <strong>[1]</strong> for consideration of both food and drink objects (whether correct or not);</em></p>\n<pre>public double calculateBill(Item[] pl)<br/>{<br/> double total = 0.0;<br/><br/> for(int x = 0; x < fiCount; x++)<br/> {<br/> String c = fi[x].getItemCode();<br/> double price = findPrice(pl,c);<br/> total = total + fi[x].getQuantity()*price*(1 + foodTax);<br/> }<br/><br/> for(int y = 0; y < diCount; y++)<br/> {<br/> String c = di[y].getItemCode();<br/> double price = findPrice(pl,c);<br/> total = total + di[y].getQuantity()*price*(1 + drinkTax);<br/> }<br/> return total;<br/>}</pre>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.11",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-3-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct a truth table for the following logical expression.</p>\n<p style=\"text-align:center;\">(A XOR B) AND NOT C</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for a truth table with all 8 inputs and up to 3 correct outputs.</em><br/><em>Award <strong>[2]</strong> for 4 or 5 correct rows in the truth table.</em><br/><em>Award <strong>[3]</strong> for 6 or 7 correct rows in the truth table.</em><br/><em>Award <strong>[4]</strong> for all 8 correct rows in the truth table.</em></p>\n<p style=\"text-align:center;\"><em><img src=\"\"/></em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates demonstrated that they could create a truth table for a given logical expression, and as a result, achieved full, or near full, marks. A small number of candidates lost marks for errors such as an incorrect number of rows in the truth table or applying AND C to the final result, rather than AND NOT C, as required in the question. Inputs were mostly laid out in an organised manner, making it easy to check that all combinations of 0 or 1 had been included. A small number of tables were less organised, and this may have contributed to some errors.</p>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.6",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage of using virtual memory.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> disadvantage of using virtual memory.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award [1] for an advantage and [1] mark for an outline</em>.</p>\n<p>Allows more applications to run than there is available physical memory;<br/>By the use of page/swap files/part of hard disk as primary memory;</p>\n<p>Larger application can run with less real RAM;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Award [1] for a disadvantage and [1] mark for an outline</em>.</p>\n<p>Applications run more slowly;<br/>Uses hard drive memory as primary memory / takes more time to switch between applications;</p>\n<p>When a computer's virtual memory resources are overused /Reduced amount of hard drive space available for your use;<br/>programs lock-up/do not run/disk thrashing;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Poorly answered by majority of the candidates: virtual memory was confused with cloud storage.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Poorly answered by majority of the candidates: virtual memory was confused with cloud storage.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "19M.1.HL.TZ0.5",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A school has a local area network (LAN) connecting its computers and peripheral devices. The LAN also provides access to the internet.</p>\n</div><div class=\"specification\">\n<p>Users have been troubled by slow speeds when accessing the internet.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the role of a router in this network.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> reasons why there might be a reduction in data transmission speed at certain times.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> measures that the school could take to safeguard its data from unlawful access via the internet.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The inventory of office supplies used in the school is stored on the computer as a single file.</p>\n<p>Each of the office supplies in the inventory (such as paper, ink, toner, printers, pens, staplers, pencils and scissors) has a unique ID number, name, maximum quantity, minimum quantity and remaining quantity.</p>\n<p>Outline the steps in an algorithm that would output a list of supplies with the quantity to be ordered.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>controls the flow of data in the network;<br/>inspects address of data packets;<br/>directs to the appropriate network path/ selects a path between networks (by inspecting address of data packets);<br/>securely transmits data packets (across that path toward the intended destination);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>malicious software/spyware/malware / viruses;<br/>attacking the system;</p>\n<p>the type of connection;<br/>valid outline for the slow down (depending on the type of connection);</p>\n<p><em><strong>Note</strong>: There are many types of internet connection: wireless connections, wireless hotspots, mobile internet, broadband connections, fixed wireless and satellite connection, cable, DSL</em>;</p>\n<p>hardware malfunction;<br/>internet speed can considerably slow down if modem-router configuration is not correct / updated;</p>\n<p>external factors;<br/>during the peak hours of daytime the most visited websites encounter more network traffic than what has been anticipated;</p>\n<p><em><strong>NOTE</strong>: Accept examples. For example, too many students try to connect to an e-learning site at the same time</em>.</p>\n<p><em>Mark as 2 and 2</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Preventing unauthorized access/No access without user names/passwords;<br/>which should be regularly changed/made difficult to guess;</p>\n<p>Data should be encrypted;<br/>Allowing only those with decrypting code access;</p>\n<p>Teachers/students should be trained for safe practices;<br/>to create a risk-conscious /security-aware culture within the school;</p>\n<p>Installation of virus checkers/spyware software;<br/>to prevent damage to data files or the system / to prevent data being extracted from the files/system;</p>\n<p><em>Mark as 2 and 2</em></p>\n<p><em><strong>Note</strong>: Accept appropriate measures such as physical security measures / access control / data security / network and communication security / user awareness and education, etc</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for looping through the inventory file;</em><br/><em>Award <strong>[1]</strong> for reading the supply data record (ID number, name, maximum quantity, minimum quantity and remaining quantity);</em><br/><em>Award <strong>[1]</strong> for checking if the quantity remaining is less than minimum quantity;</em><br/><em>Award <strong>[1]</strong> If so, calculate the quantity to be ordered (number to buy) / as the maximum quantity minus the quantity remaining;</em><br/><em>Award <strong>[1]</strong> for outputting the name/ID number of the office supply and the number to buy;</em></p>\n<p>Example 1:</p>\n<pre>while not end of inventory file<br/> read supply data record from file<br/> if remaining quantity < minimum quantity<br/> then<br/> numbertobuy = maximum quantity – remaining quantity<br/> output (\"Reorder \", ID, name, numbertobuy)<br/> end if<br/>end loop</pre>\n<p>Example 2:</p>\n<pre>for each item in the inventory loop<br/> with item do<br/> if remaining quantity < minimum quantity then<br/> output \"Reorder \", ID, name, (maximum quantity – remaining quantity)<br/> end if<br/> end do<br/>end loop</pre>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally recognised that a router directs data between networks and gained a mark for this. However, most answers didn't really go beyond that point and concentrated more on access to the internet. Some candidates did recognise the role of addresses in data packets to ensure they arrived at the correct destination.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates who achieved marks in this question, which asked for two reasons why there may be a reduction in data transmission speed at certain times, gave answers that may fit into category 'external factors'. An example of this was high demands on bandwidth due to many students accessing the network at the same time. Sometimes, candidates gave more than one answer related to this same category. Other categories, such as malicious software, type of connection and hardware malfunction, were largely overlooked by candidates.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates recognised at least one measure that a school could take to safeguard its data from unlawful access via the internet, with correct answers based on authentication of users or encryption. A small number of candidates recognised the benefits of anti-virus software. However, candidates could also have discussed the benefits or training staff or users in safe practices.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were required to write the main steps in an algorithm to output a list of office supplies with the quantity to be ordered. Candidates who gave a list of logical steps written in the style of an algorithm, rather than as a purely descriptive answer, achieved higher marks. Marks were generally lost when candidates failed to recognise the need for a loop to check the whole file, or if they were not specific enough about either what was being ordered, or the quantity of the order. Sometimes, candidates would output the office supply item and its order quantity but failed to show how the order quantity was determined.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.7",
|
||
"topics": [
|
||
"topic-1-system-fundamentals",
|
||
"topic-4-computational-thinking-problem-solving-and-programming",
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics",
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A single parking space that holds one car can be used to hold two motorbikes. The programmer has decided to use a two-dimensional array to create a map of the parking area.</p>\n<p><code>Vehicle parkingSpaces[][] = new Vehicle[2][200]</code>;</p>\n<p><img src=\"\" style=\"display: block; margin-left: auto; margin-right: auto;\"/></p>\n<p><strong>Note</strong>: <code>m</code> and<code> c</code> have been used to show where motorbikes and cars are parked.</p>\n</div><div class=\"specification\">\n<p>Police have requested a way of searching the parking area for vehicles with a specified registration plate, and a binary tree has been suggested.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> advantage of using a two-dimensional array for this purpose.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> disadvantage of using a two-dimensional array for this purpose.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why searching for the registration plate in a binary tree would be faster than looking for it in the two-dimensional array.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the steps that would be involved in taking the data from this two-dimensional array and creating a binary search tree.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Faster to access (i.e. O1 instead of On);<br/>Arrays take less memory than lists (as they do not store pointers);<br/>Mirrors real life situation;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Static, therefore memory wasted when not being fully utilised;<br/>Inability to grow, should further spaces be added, i.e. If Parking area grows;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>The array would need to be searched using a linear search which is inefficient O(n) whereas a binary search is much more efficient O(log n);<br/>A linear search for a car in this parking area could require a maximum of 200 comparisons (i.e. it would look at the first row of every column) whereas a binary search would only require 8 (i.e. log 200 base 2);<br/>A linear search for a motorbike in this parking area would require a maximum of 400 comparisons (i.e. it would need to look at both rows of every column) whereas a binary search would only require 7 (log 100 base 2);<br/>In a binary search, each comparison would eliminate half of the remaining possible matches, whereas in a linear search it only eliminates 1;<br/>A binary search has the registration plate as its key and therefore it doesn’t require accessing the field of the vehicle object for each comparison, whereas in a linear search, each comparison would be slower because it would require getting the vehicle object’s registration field using an accessor method;<br/>A binary search is always faster than a linear search on a large data set. As the police may be searching for many cars and in many parking areas, their searches will be on large set of data;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/>Create a binary tree to store vehicle objects;<br/>Loop around all of the elements in the 2 dimensional array (e.g. using inner and outer loop);<br/>Skip empty locations;<br/>Take the first vehicle found and add as the head of the binary tree;<br/>Take all subsequent vehicles found and do the following;<br/>Get the node’s vehicle registration;<br/>Find the appropriate insertion point in the binary tree by navigating from the root and comparing the registration to the key of the current node;<br/>When a leaf node is reached compare the registration with the vehicle to be inserted and insert it as the left or right child node, using its registration as the key;<br/>Continue until the end of the vehicle array has been reached;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Both parts were well-answered.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Both parts were well-answered.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students identified the tree property that effectively eliminates half of the tree when searching but answers were not always detailed enough to gain full marks.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A large number of students were unclear as to how a binary search tree is created. Full marks were only reached by those students who clearly identified the different stages of the process.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "20N.2.HL.TZ0.16",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures",
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures",
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Website developers need to consider a range of usability factors when designing a website.</p>\n</div><div class=\"specification\">\n<p>A company promotes its products online. To make a purchase, customers are required to register with the company and provide data like their name, date of birth, age, gender and email address. Once registered, more than one customer is able to access the server to retrieve and modify their data at the same time.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> usability factors that need to be considered in the design of a website.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> reason why visual displays on a computer screen can create difficulties for some people.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State where the customer data is held during the process of modifying their data.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the operating system ensures that each customer’s data is secure when multiple users are accessing the data at the same time.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The company is considering sharing its customers’ data with marketing organizations.</p>\n<p>Explain why there could be ethical issues for the company when sharing its customers’ data.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>complexity / simplicity / amount of effort to get a result / number of errors with the time taken to move past them;<br/>readability / comprehensibility / reading or writing speed;<br/>learnability / time to accomplish tasks on the first use;<br/>effectiveness ( user performance);<br/>efficiency (time needed to complete a task);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Award marks for the reason/accessibility issue arising from visual / hearing impairments / cognitive disabilities, and not only for users with disabilities but also for those using mobile devices (alternative browsing devices such as TVs, watches, etc.), or those with slow network connections</em>.</p>\n<p>Visual display design is not logical;<br/>workflows are not simple, and do not require as few interactions as possible to complete;</p>\n<p>Visual display design is not consistent;<br/>navigation, header, footer, and main content are not always in the same places;</p>\n<p>Visual display design is not usable as possible;<br/>tools are not easy to use, processes are not broken down into logical steps;</p>\n<p>People with poor eye-sight/color blind can have difficulties to distinguish;<br/>because of the way graphics, words and directions are used / combinations of some colours (e.g., red and green);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>RAM/primary memory;<br/>It's held by the process/thread handling the customer access, which may be in RAM or in other storage if the process is swapped out while handling the access;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>OS (memory management function) allocates / deallocates memory to each process/customer task, and guarantee each customer task the resources it needs to run correctly;<br/>moves processes back and forth between main memory and secondary memory during execution to prevent overwriting / accidental interchange;<br/>OS (hardware memory protection- part of an OS) isolates/protects customer’s data/applications;<br/>and control access rights to the specified memory area (for example, prevents write access to the memory which is not allocated to the process/ customer task);<br/>and protects data / applications when in memory / RAM from malicious code (prevents attempts to execute the contents of the partition/ allocated memory);</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/>privacy of customer/ person data;<br/>company needs to gain permission from customer;<br/>customer would need to be able to view all data details;<br/>customer must be informed about all uses that will be made of data;<br/>customer must be informed to whom data will be disclosed.<br/>legal issues to do with unauthorized disclosure of customer data;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Answers that simply identified usability factors related to website design, such as: complexity, readability, learnability, effectiveness and efficiency, were rare. The vast majority of candidates opted for a more descriptive approach, which generally did not reflect the required answers.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates in general offered responses to this question related to visually impaired users, and some gained marks here, particularly if their response related to poor choice of colours making it hard to read, for example. However, candidates could have also given answers related to screen layout not being logical, consistent screen layout design, or the fact that consideration needs to be given to the size of the screen being used, such as on mobile devices.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates recognised that customer data is held in RAM while it is being modified. However, other candidates incorrectly stated that it would be held in the computer or the server, which is not specific enough to achieve the mark.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The majority of candidates did not recognise that this question related to how an operating system functions and keeps data secure in multiuser environments. Candidates offered answers related to security, but often in relation to authentication when logging in. Some marks were achieved for statements related to the operating system's role in preventing one user's data overwriting that of another, or for the operating system controlling access rights to different parts of the memory. However, high marks on this question were rare.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates had the opportunity to discuss ethical issues related to a company considering sharing customers' data without permission. Many candidates described one or more of the points: privacy of its customer data, the need to obtain permission from customers in order to share their data, and the legal issues that may arise due to the unauthorised disclosure of customer data. However, candidates could also have discussed the need for customers to be aware of how their data may be used, the actual data that may be being shared and to whom it would be disclosed. Most candidates achieved some marks here, but mostly in the centre of the mark range.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.8",
|
||
"topics": [
|
||
"topic-1-system-fundamentals",
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics",
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>State the output from the binary tree using postorder traversal.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2]</strong> for completely correct answer and <strong>[1]</strong> for any 3 numbers in correct order</em>.</p>\n<p>Postorder traversal: 76 75 79 70 68 72 83</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates answered this question reasonably well.</p>\n</div>",
|
||
"question_id": "19M.1.HL.TZ0.11",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline why a binary tree would be a good choice of data structure for maintaining an address book.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Time efficient searching / traversing for a contact in an address book;<br/>Each iteration / comparison allows the size of the search to be reduced (by skipping about half of the remaining contacts);</p>\n<p>Fast/easy addition / removal of contacts in an address book;<br/>Quick search for the leaf node / empty node where a new contact can be placed / for the node containing the contact to be deleted;</p>\n<p>Contacts can be listed / output in alphabetical order/ fast sorting;<br/>using inorder traversal;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>A few candidates provided too vague, out-of-context answers.</p>\n</div>",
|
||
"question_id": "19M.1.HL.TZ0.12",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The internet and World Wide Web are often considered to be the same, or the terms are used in the wrong context.</p>\n</div><div class=\"specification\">\n<p>Many organizations produce computer-based solutions that implement open standards.</p>\n</div><div class=\"specification\">\n<p>A search engine is software that allows a user to search for information. The most commonly used search algorithms are the PageRank and HITS algorithms.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between the internet and the World Wide Web.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> advantages of using open standards.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why a search engine using the HITS algorithm might produce different page ranking from one using the PageRank algorithm.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Web crawlers browse the World Wide Web.</p>\n<p>Explain how data stored in a meta-tag is used by a web crawler.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>The internet is a global network of interconnected computers / a network of networks;</p>\n<p>The World Wide Web is software / a service that runs on the hardware of the internet and provides access to content / a collection of pages that can be accessed through hyperlinks / a way of accessing and sharing the information that is held on the internet in webpages;</p>\n<p>The World Wide Web uses the http protocol. This is only one of the many protocols used by the internet;</p>\n<p>E-mail, File Transfer Protocol (FTP), and instant messaging services are part of the internet but not of the web;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Open standards provide a publicly available specification for a specified task;<br/>This is an agreed set of parameters that enable interoperability and/or compatibility to occur;</p>\n<p>Using Open standards means that you are not subject to a governing body with its own agenda/self-interest;<br/>Thus, you can be confident that you won’t be subject to fees/bias;</p>\n<p>Open standards promote interoperability;<br/>This enables the various devices to communicate with each other;</p>\n<p>Open standards advocates also argue that openness encourages better and more secure systems;<br/>this is because more people are able to analyse the standards and resulting software and no-one has a proprietary interest in suppressing knowledge of problems to keep sales up.</p>\n<p><em>Mark as [2] + [2]</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>The HITS Algorithm ranks the page based on a combination of its importance as a hub and an authority;<br/>The PageRank Algorithm ranks the page by counting the number and quality of links to a page to determine the relative importance of the website;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Meta tags are included in the header of a web-page which are available to a web-crawler and give information about the page that it could make use of;<br/>When the web-page is crawled, a copy of the HTML is replicated in the search engine database;<br/>When a user enters text into a search the search engine retrieves the data indexed from the web-page;<br/>And the search engine ranks and displays the content (in order of relevance);</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Standard question and well answered.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students referred to the idea of interoperability.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many answers talked generally about popularity and some did mention the idea of hubs and authorities and others referred to the quality of connections, but few put the two ideas together correctly.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many answers identified the content of the tags and some were able to relate this content to subsequent decisions taken by the web crawler.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.8",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-3-distributed-approaches-to-the-web",
|
||
"c-2-searching-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a diagram showing the relationships between the <code>Payment</code>, <code>FoodItem</code>, <code>DrinkItem</code>, and <code>Item</code> classes. You do not need to include the names of attributes or methods.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>By making reference to any of the classes from 12(a), describe <strong>two</strong> benefits that a programming team would gain from the use of encapsulation.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The company that owns this restaurant also owns hotels, shops, and a car hire business. The programs that manage the finances of these different businesses include classes similar to the ones shown in this paper.</p>\n<p>Explain how inheritance could be used as a tool to both improve the clarity of the design and to reduce the amount of code that needs to be written.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows, up to <strong>[3 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for 4 classes connected with arrows/lines.</em><br/><em>Award <strong>[1]</strong> for “has a” label or correct arrow from <code>Payment</code> to <code>FoodItem</code><span style=\"font-family:monospace;\"> </span><strong>and</strong> “has a” label or correct arrow from <code>Payment</code> to <code>DrinkItem</code> (with no additional arrows).</em><br/><em>Award <strong>[1]</strong> for “uses” label or correct arrow going from Payment to Item (with no additional arrows).</em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying a feature, <strong>[1]</strong> for an example in the given context, and <strong>[1] </strong></em><em>for an elaboration, for two features up to <strong>[6 max]</strong></em>.<br/>Encapsulation places all attributes and methods that relate to a particular object/entity together;<br/>For example, <code>Payment</code> class includes attributes such as the food and drink arrays and methods such as <code>calculateBill()</code>;<br/>This provides a clearer view/understanding of each section of the problem;<br/>Which can lead to more efficient programming (faster, less errors etc.);</p>\n<p>Encapsulation protects the values of the data stored within the object;<br/>From (accidental) changes made by other classes;<br/>For example, quantity in the <code>FoodItem</code> class cannot be altered through another variable called quantity in another class;<br/>This allows programmers to select any variable names they wish/no restriction on choice of variable names;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>A generic <code>Payment</code> class can be created;<br/>This would contain data/variables/methods required by all units of the company;<br/>Each of the different operations could then inherit this class;<br/>Adding new variables/methods that relate only to them;<br/>Overriding the superclass methods as necessary;</p>\n<p><em><strong>Note</strong>: Allow a similar answer that deals with the different items (<code>FoodItem</code>, <code>DrinkItem</code> etc.)</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "17N.2.SL.TZ0.12",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-1-objects-as-a-programming-concept",
|
||
"d-2-features-of-oop"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A new parking service has been introduced: staff will park the car for the driver and then return it later when the driver wants to leave. This service will use a narrow parking area surrounded on three sides by walls, where any cars behind the required car must be reversed out. For example, car <code>X00000011</code> was the first vehicle to be parked, so to remove it from the parking area, the other five cars, starting with <code>X00000123</code>, will need to be removed. The cars are then returned starting with car <code>X00000010</code>.</p>\n<p style=\"text-align: center;\"><strong>Figure 5: Cars parked in the parking area</strong></p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">The class <code>Stack</code>, which contains the <code>Vehicle</code> objects, has the following methods:</p>\n<p style=\"text-align: left;\"><img src=\"\" style=\"display: block; margin-left: auto; margin-right: auto;\"/></p>\n<p style=\"text-align: left;\">The method <code>staffRemoveCar</code> will remove a vehicle with a specified registration plate from the parking area (you can assume the vehicle is in the parking area):</p>\n<pre style=\"text-align: left;\">public static void staffRemoveCar(Stack stack, String reg){<br/> Stack temp = new Stack();<br/> //add code here<br/>}</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the <code>staffRemoveCar</code> method.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A stack can be implemented using an array or a singly linked list.<br/><br/>Compare the use of these two data structures for creating a stack.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for looping around the main stack using isEmpty() method;</em><br/><em>Award <strong>[1]</strong> for using \"while\" loop in both loops (note: not a \"do while\"!);</em><br/><em>Award <strong>[1]</strong> for breaking out of outer loop when car is removed and other cars are replaced;</em><br/><em>Award <strong>[1]</strong> for correctly removing cars before target car is found;</em><br/><em>Award <strong>[2]</strong> for replacing cars in same order by popping off temporary stack;</em></p>\n<p><strong>Example 1</strong>:</p>\n<pre>public void staffRemoveCar(Stack stack, String reg) {<br/>Stack temp = new Stack();<br/>while (!stack.isEmpty()) {<br/> Vehicle v = (Vehicle) stack.pop();<br/> if (v.getRegistration().equals(reg)) {<br/> // correct car is now removed<br/> // return others<br/> while (!temp.isEmpty()) {<br/> stack.push(temp.pop());<br/> }<br/> break; // don't keep repeating<br/> }<br/> temp.push(v);<br/>}<br/>}</pre>\n<p><strong>Example 2</strong>:</p>\n<pre>public static void staffRemoveCar(Stack<Vehicle> stack, String reg)<br/>{ Stack<Vehicle> temp = new Stack<Vehicle>();<br/> boolean found = false;<br/> while (!found && !stack.isEmpty())<br/> { Vehicle curr = stack.pop();<br/> found = curr.getRegistration().equals(reg);<br/> if (!found) temp.push(curr);<br/> }<br/> while (!temp.isEmpty()) stack.push(temp.pop());<br/>}</pre>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award [1] for an initial valid comparison and [1] for a valid expansion</em>.</p>\n<p><strong>Memory</strong><br/>Linked lists can deal with memory issues more efficiently than arrays;<br/>Arrays are static so will have a maximum size and cannot grow beyond that;<br/>Memory will be allocated for maximum size at instantiation so while it is not full memory is wasted Links are dynamic and can add/remove memory as required- no memory is wasted;</p>\n<p><strong>Implementation</strong><br/>No particular advantage is gained by the use of either structure;<br/>As additions and removals (push and pop) work on one end of the stack, navigation speed (i.e. O1) is not very helpful; Linked lists can adjust the pointer at the end of the list (can use a tail pointer) so slow navigation is not an issue;</p>\n<p><strong>Errors</strong><br/>The use of arrays is more likely to lead to run-time errors;<br/>As arrays can reach their maximum limit whilst linked lists are only limited in size by the specifications of the CPU;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>There were many full marks gained for this algorithm with students making correct use of the various stack methods.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most alluded to the memory issues regarding the two data structures, but too many dealt incorrectly with issues dealing with traversing the structures, which were largely irrelevant as access was only needed for the top of the stack.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "20N.2.HL.TZ0.17",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> feature of a word processor that could reduce the amount of typing required when writing letters.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the purpose of technical documentation provided with software.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Auto-correct/short sequences/codes;<br/>can be used to represent longer phrases;</p>\n<p>Mail merge;<br/>allows production of many letters by only typing the (body of a) letter once;</p>\n<p>Voice recognition;<br/>allows easy entry of text;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>Technical documentation explains how to install software;<br/>Technical documentation describes the hardware configuration/operating system needed(to install this software);</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were generally able to name or describe a feature of a word processor that could reduce the amount of typing required when writing letters. Candidates who named a feature and described it achieved both marks.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A small number of candidates recognised the role of technical documentation in the installation of software or in identifying the hardware requirements of a program. However, many answers were seen in which candidates described user documentation.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.1",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A school has 100 students. All student names (strings) and student ID numbers (five-digit integers) are held in two separate one-dimensional arrays named <code>SID</code> and <code>SNAMES</code>.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">For example, student Pia Baranger has ID number 11876.</p>\n<p style=\"text-align: left;\">A binary search algorithm is not used to find a particular name in array <code>SNAMES</code>.</p>\n</div><div class=\"specification\">\n<p>The school offers its sporting program to students and has a basketball team, a tennis team and a football team. Each student must choose at least one of these three sports.</p>\n<p>Three collections, <code>BASKETBALL, TENNIS</code> and <code>FOOTBALL</code>, are created. When a student chooses a sporting activity, their ID number is added to the appropriate collection.</p>\n<p>For example:</p>\n<pre>BASKETBALL={10011, 11876, 10122}<br/>TENNIS={10011, 11876, 10002}<br/>FOOTBALL={10011, 10002, 22103, 32000}</pre>\n<p>The method <code>isIn(X, COL)</code> is available, where:</p>\n<ul>\n<li><code>X </code>is a five-digit integer representing an ID number</li>\n<li><code>COL</code> is a collection that holds student ID numbers.</li>\n</ul>\n<p>The method <code>isIn(X, COL)</code> returns <code>True</code> if the ID number <code>X</code> is in the collection <code>COL; False</code> otherwise.</p>\n<p>For example:</p>\n<p><code>isIn(11876, BASKETBALL)</code> returns <code>True</code> <br/><code>isIn(11876, FOOTBALL)</code> returns <code>False </code></p>\n</div><div class=\"specification\">\n<p>The football and tennis training sessions are held at the same time. The football coach would like to know how many students will not be able to attend the football training session because they will be attending the tennis training session.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the reason for not using a binary search.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm in pseudocode for the method <code>isIn(X, COL)</code>.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm in pseudocode that will output the number of students who have chosen both tennis and football. The method <code>isIn()</code> should be used in your answer.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The school coordinator would like to check whether there are students who have not yet chosen any one of the three sports.<br/><br/>Construct an algorithm in pseudocode that will output the names of students who have not yet chosen any one of the three sports. An appropriate message should be displayed if every student has chosen a sport.</p>\n<div class=\"marks\">[7]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.</p>\n<p>Because the array SNAMES is not sorted/ordered;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for initializing and returning/outputting flag;</em><br/><em>Award <strong>[1]</strong> for a while loop;</em><br/><em>Award <strong>[1]</strong> for correct comparison and updating flag;</em><br/><em>Award <strong>[1]</strong> for the correct use of collection methods (resetNext(), hasNext() and getNext());</em></p>\n<p>Example 1:</p>\n<p><code>isIn(X,COL)</code><br/><code> PRESENT=False</code><br/><code> COL.resetNext()</code><br/><code> loop while COL.hasNext()and not PRESENT</code><br/><code> Y= COL.getNext()</code><br/><code> if X== Y</code><br/><code> then PRESENT=True</code><br/><code> end if</code><br/><code> end loop</code><br/><code> return PRESENT</code><br/><code>end isIn</code></p>\n<p>Example 2:</p>\n<p><code>isIn(X,COL)</code><br/><code> P=0</code><br/><code> COL.resetNext()</code><br/><code> loop while COL.hasNext()</code><br/><code> if X== COL.getNext()</code><br/><code> then P=1</code><br/><code> end if</code><br/><code> end loop</code><br/><code> if P==1 // NOTE: instead of if statement only</code><br/><code> then return True // the statement : return P==1</code><br/><code> else return False // may be written</code><br/><code> end if</code><br/><code>end isIn</code></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for initializing, updating and returning/outputting COUNT;</em><br/><em>Award <strong>[1]</strong> for a while loop;</em><br/><em>Award <strong>[1]</strong> for calling method <code>isIn()</code>;</em><br/><em>Award <strong>[1]</strong> for correct use of collection methods (<code>resetNext(), hasNext()</code> and <code>getNext()</code>;</em></p>\n<p>Example 1 (loop through collection FOOTBALL):</p>\n<pre>COUNT=0<br/>FOOTBALL.resetNext()<br/>loop while FOOTBALL.hasNext()<br/> X== FOOTBALL.getNext()<br/> if isIn(X,TENNIS)<br/> then COUNT=COUNT+1<br/> end if<br/>end loop<br/>output COUNT</pre>\n<p>Example 2 (loop through collection TENNIS):</p>\n<pre>COUNT=0<br/>TENNIS.resetNext()<br/>loop while TENNIS.hasNext()<br/> if isIn(TENNIS.getNext(),FOOTBALL)<br/> then COUNT=COUNT+1<br/> end if<br/>end loop<br/>output COUNT</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[7 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for the use of flag;</em><br/><em>Award <strong>[1]</strong> for looping through the array SID;</em><br/><em>Award <strong>[2]</strong> for correct use of logical operators not/and/or in if statement, 1 mark for minor error;</em><br/><em>Award <strong>[1]</strong> for the correct call of method <code>isIn()</code>;</em><br/><em>Award <strong>[1]</strong> for outputting the name from the array SNAMES within the loop;</em><br/><em>Award <strong>[1]</strong> for outputting message(if needed) after the loop;</em></p>\n<p>Example 1:</p>\n<pre>FLAG=True<br/>loop for K=0 to 99<br/> if <strong>not</strong>( isIn(SID[K],FOOTBALL)or isIn(SID[K],BASKETBALL) <strong>or</strong> isIn(SID[K],TENNIS))<br/> then<br/> output SNAME[K]<br/> FLAG=False<br/> end if<br/>end loop<br/>if FLAG<br/> output 'Each of the students is on at least one of the three teams'<br/>end if</pre>\n<p><em><strong>Note</strong>: the condition in if statement could be written as</em><br/><em><strong>not</strong>(isIn(SID[K],FOOTBALL))<strong>and not</strong>(isIn(SID[K],BASKETBALL))<strong>and not</strong>(isIn(SID[K],TENNIS))</em></p>\n<p>Example 2:</p>\n<p><em>Award <strong>[1]</strong> for the use of flag</em><br/><em>Award <strong>[1]</strong> for looping through the array SID</em><br/><em>Award <strong>[1]</strong> for nested if statements</em><br/><em>Award <strong>[1]</strong> for correct logical expressions in each of these ifs</em><br/><em>Award <strong>[1]</strong> for the correct call of method isIn()</em><br/><em>Award <strong>[1]</strong> for outputting the name from the array SNAMES within the loop</em><br/><em>Award <strong>[1]</strong> for outputting message(if needed) after the loop</em></p>\n<pre>X=1<br/>loop for K=0 to 99<br/> if <strong>not</strong>(isIn(SID[K],FOOTBALL))<br/> then if <strong>not</strong> (isIn(SID[K],BASKETBALL))<br/> then if <strong>not</strong>(isIn(SID[K],TENNIS))<br/> then<br/> output SNAME[K]<br/> X=0<br/> end if<br/> end if<br/> end if<br/>end loop<br/>if X==1<br/> output 'Every student has chosen a sport'<br/>end if</pre>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates recognised that a binary search would only work with sorted data.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were required to produce an algorithm for the method described in the question. Most candidates achieved some marks for this algorithm, but full marks were rare. The scenario involved the use of a collection, so collection methods were expected within the algorithm. Many candidates failed to demonstrate the use of collection methods.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were required to construct a second algorithm involving the use of the method defined in part b. As with part b, the use of collection methods was also expected, but was often missing. Candidates who attempted the question, however, generally achieved some marks.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A final algorithm was required based on the question scenario. Some candidates did not attempt this question. A small number of candidates achieved high marks by demonstrating good programming skills. However, a large number of candidates scored low marks for the construction of a partial solution or a solution that was partially correct.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.9",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The World Wide Web can be divided into three categories: the surface web, the dark web and the deep web.</p>\n</div><div class=\"specification\">\n<p>The dark web is only accessible by using specialist software, such as TOR and I2P. Many users of the dark web use it to protect their anonymity.</p>\n</div><div class=\"specification\">\n<p>Many users of the dark web use peer-2-peer (P2P) networks for activities like torrent streaming. This opens up ports on the computer to upload and download data.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between the surface web and the deep web.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how a user’s anonymity can be maintained while accessing the dark web.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why users have concerns about opening up ports to upload and download data.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The founders of the World Wide Web intended it to be a decentralized and democratic environment.</p>\n<p>To what extent have the aspirations of the founders of the World Wide Web been met?</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>The surface web is the part of the web that can be reached by a search engine whereas the deep web cannot;<br/>The deep web may consist of dynamic content such as the result of database queries or may be protected proprietary content;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>The dark web uses a layered encryption system;<br/>Data is routed through a large number of intermediate servers;<br/>Which means it is almost impossible to decrypt the information layer by layer;<br/>With the result that the user’s details are practically untraceable, and their anonymity can be maintained;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>A port is used to facilitate the communication between a computer and an application;<br/>Certain ports such as Port 21 (FTP), 23 (Telnet) and 80 (HTTP) are reserved;<br/>Every time a port is opened on a computer it provides access to that computer;<br/>This means that the security of that computer may be potentially compromised every time a new port is opened;<br/>Or port conflicts may occur when more than one application tries to use a specified port;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/>World Wide Web has enabled citizens to communicate easily and for ‘ordinary’ citizens to express their opinions;<br/>Therefore, the ability to publish is not confined to certain ‘privileged’ groups such as broadcasters and journalists;<br/>The World Wide Web has to a large degree given access to common resources to all citizens globally who have access to the Internet;<br/>However, it can be argued that the evolution of the World Wide Web has led to a greater centralization of power, for example the digital oligarchs (Microsoft, Google, Amazon, Apple, Facebook);<br/>This centralization has led to a reduction in democracy as the digital oligarchs have an increasing stranglehold over the lives of their ‘digital subjects’ through the aggregation, analysis and monetarization of their data;<br/>There are still issues with a lack of digital democracy, for example, many citizens may not have access to the World Wide Web, either through income, geography or necessary skills;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Dark web and deep web are clearly concepts that engage the interest of our students. Search engines were correctly brought into the answers to part (a) whilst various ruses, some of which were correct, were present in the answers to part (b).</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Being an \"explain\" question the answers required knowledge of \"how\" or \"why\". Not that many explained the importance of the translation feature of a browser.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students identified the dangers of opening these ports to potential hackers with the consequent dangers.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>In a 6-mark discussion question, the examiner will look for six different ideas that are both relevant to the question and reasonably well-explained. Students need to bear this in mind when planning the way in which they are going to answer. Short phrases or bullet points are not appropriate.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.9",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-4-the-evolving-web",
|
||
"c-3-distributed-approaches-to-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A telecommunication company stores a large amount of data in three databases.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>The database segmentation is carried out on the CUSTOMERS database.</p>\n</div><div class=\"specification\">\n<p>Data mining is used to extract knowledge hidden in this large amount of data. Before using data mining processes the existing data should be cleaned up.</p>\n</div><div class=\"specification\">\n<p>Customers committing fraud is a risk to the company.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the use of an object-oriented database as opposed to a relational database.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define a <em>spatial database</em>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State what is meant by database segmentation.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> benefit of database segmentation to the telecommunication company.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how ETL processes could be used in data preparation.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between the use of association and sequential patterns as data mining techniques.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how deviation detection could be used to detect fraud at the telecommunications company.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Customers who decide to leave the telecommunication company for a competitor may result in huge losses for the telecommunications company.</p>\n<p>Explain with the use of an example, how predictive modelling could be used to optimize information sent to existing customers.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>Object-oriented databases store objects rather than data such as integers, strings or real numbers;<br/>Objects are used in object-oriented languages such as C++, Java, and others;<br/>Objects consist of attributes (data which defines the characteristics of an object) and methods (procedures or functions which define the behaviour of an object) / the data is closely related to the programs that process them;<br/>Which may be a more accurate representation of the real-world objects they represent;</p>\n<p>Relational databases store data such as integers, strings or real numbers in tables / uses tables with rows and columns);<br/>Relational database is normalized so data is not repeated more often than necessary;<br/>All columns depend on a primary key (a unique value in the column) to identify the column;<br/>Once the specific column is identified, data from one or more rows associated with that column may be obtained or changed;<br/>There is a distinct separation between the storage of data and any application using them;</p>\n<p><em>Disadvantages of object-oriented database over relational database</em><br/>Lower efficiency when data is simple and relationships are simple;<br/>Relational tables are simpler;<br/>More user tools exist for relational databases;<br/>Standards and support for relational databases are more stable so changes in database are less likely to be required;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>A spatial database stores</em>:<br/>Spatial data / locational data / geometric data types;<br/>Such as point, polygons, lines, 3D shapes, coordinates etc.; <em>//</em> <em>allow any one of these</em>;<br/>That model the structure of geometric/3D objects;<br/>And make use of spatial indexes to access data;<br/>And supports geometric functions;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Database segmentation means dividing entities into groups with similar characteristics/common attributes;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying a benefit and <strong>[1]</strong> for a further explanation, up to <strong>[2 max]</strong></em>.</p>\n<p><em><strong>Benefit</strong></em><br/>Increased profit;<br/>Better reputation;<br/>Increased number of customers;<br/>Better opportunities for growth;<br/>To gain a larger share of the market;</p>\n<p><em><strong>Explanation</strong></em><br/>By studying the groups and behaviour of the customers in the group (for example, average call time of customers younger than 30 or which services are purchased by customers older than 60, etc.);<br/>The company will better understand customers and serve them better;<br/>Can better decide which marketing actions should be taken;<br/>Can better predict which group of customers new products/services should be offered to;<br/>Can better decide which new products/services are needed;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>Useful data should be discovered then <strong>extracted</strong> from various sources;<br/><strong>Transformations</strong> performed;<br/>Repair inaccuracy between data formats;<br/>Remove mistakes/spelling mistakes;<br/>Delete unnecessary data/data fields / clean up the data;<br/>(<em>accept other examples</em>)<br/><strong>Load</strong> data into data warehouse;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>Association is a (rule based) data mining technique which searches for relationships between data items;<br/>In the same transaction;<br/>Sequential patterns is a technique that seeks to discover/identify similar patterns in transaction data;<br/>Over a period of time;</p>\n<p><em><strong>Note</strong>: Accept examples in given situation</em>.<br/>Association could find out that customers who buy a new mobile phone also change the subscription type;<br/>Sequential patterns could discover that twice a year number and duration of calls increase (e.g., customers’ birthday and New Year’s Eve);</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for creating a model and <strong>[1]</strong> for detecting changes/differences in the data/model from previously measured values, up to <strong>[2 max]</strong></em>.</p>\n<p><em><strong>Example answer</strong></em><br/>The customer call records and calling behaviour (other activities) could be summarized to obtain their calling pattern;<br/>The (previous) calling pattern could be compared with the customers’ recent call/activity;<br/>In case of significant changes/differences the activity is suspicious/fraud detected;</p>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for creating a statistical model, <strong>[1]</strong> for analysing the model and forecasting probabilities/trends and <strong>[1]</strong> for an appropriate example in the given situation</em>.</p>\n<p><em><strong>Example answer 1</strong></em><br/>Customer’s online behaviour pattern could be created and considered;<br/>Customers who spend less time logged on may be less likely to renew their annual subscription;<br/>In this case, the ability to keep the customer can be increased by offering new/better/cheaper services and products;</p>\n<p><em><strong>Example answer 2</strong></em><br/>Customer’s calling pattern could be created and analysed;<br/>If, for example, the customer has high monthly usage of services then the customer will probably renew his annual subscription;<br/>(No actions made by the company needed);</p>\n<p>If a customer is younger than 20, may spend more time exploring new service features, and the customer is at a greater risk to cancel the contract/the customer will probably not renew annual subscription;<br/>(Actions made by the company might be needed, for example: offering new/better services and products;)</p>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"question_id": "17N.2.HL.TZ0.4",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-4-further-database-models-and-database-analysis"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An airline has a server that holds the flight database. Passengers can check in using a number of self-service client kiosks located in the airport.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>client</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>server</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the functions performed by the server in this situation.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>A client is a simple application or a whole system that accesses services being provided by a (remote) computer/server;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>A server is a computer / software which manages access to a centralized resource or service in a network.<br/>A server is a computer/software that provides data to other computers/clients in a network;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p>the central computer receives requests from the kiosks/terminals at the check-in desks/mobile phones;<br/>can manage several clients simultaneously (in order, each providing a different set of services);<br/>makes sure that the request is valid by accessing its database;<br/>processes the request;<br/>sends information to the kiosk;<br/>all requests/information are sent over the network connection;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>A large number of candidates recognised a <em>client</em> as a system that accesses the services of a <em>server</em>.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A large number of candidates recognised a <em>server</em> as a computer that provides data to a <em>client</em>.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates failed to understand that answers were required to explain the functions of the server in an airline's system that holds its flight database. Some candidates recognised that the server receives requests from clients, processes requests, accesses the database, or works over the network. However, most candidates only described one or two of these points and rarely stated where the requests came from i.e. the kiosks, check-in desks, or mobile phones.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.2",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following binary tree.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the result of inorder traversal of this binary tree.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the result of preorder traversal of this binary tree.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>B, A, D, C;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>A, B, C, D;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Straightforward question which caused few problems. Some candidates confused in-order with pre-order traversal.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Straightforward question which caused few problems. Some candidates confused in-order with pre-order traversal.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "20N.1.HL.TZ0.2",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Compare direct changeover with parallel running as a method of implementation.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>there is no extra cost;<br/>for running two systems/for extra salaries (no need to increase the number of employees);</p>\n<p>benefits can be gained immediately;<br/>because new system is better than the old;</p>\n<p>if there is a bug in the new system;<br/>there is not a second system to fall back on/could be disastrous for the company;</p>\n<p>employees will need to be capable of using the new system immediately;<br/>without training/with training in advance but not on the system;</p>\n<p><em>Mark as 2 and 2</em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>A large number of candidates scored full or nearly full marks for this question because they were able to describe the different benefits and drawbacks of the direct changeover and parallel running methods of implementation. If marks were lost, it was most often because candidates gave a description to show why one method may be better than the other, but then gave the reverse argument, as to why the other system may not be as good as the first, rather than offering two distinct arguments. However, many good and comprehensive answers were seen.</p>\n</div>",
|
||
"question_id": "20N.1.SL.TZ0.3",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Describe how an operating system uses paging when running a program.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em></p>\n<p>memory management method that uses secondary memory to increase the amount of primary memory;<br/>transfers data blocks of the same size (“pages”);<br/>from secondary storage to main storage when they are required;<br/>and returns them to secondary storage when they are not;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Not all candidates answered this question correctly, but most of those who did, scored good marks.</p>\n</div>",
|
||
"question_id": "20N.1.HL.TZ0.3",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline <strong>one</strong> feature of autonomous agents.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max] </strong></em><br/>Reactive behavior;<br/>autonomous agent senses the environment and reacts;</p>\n<p>Autonomy;<br/>autonomous agent activates alone for a task / is not invoked for a task / selects the task itself / operates without human supervision;</p>\n<p>Persistence;<br/>autonomous agent is a programmed device and the software describing an agent runs continuously;</p>\n<p>Sociality;<br/>autonomous agent can interact with other agents through communication / it can work in coordination and cooperation with other agents;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates were able to outline one feature of autonomous agents. Only a few candidates did not attempt this question.</p>\n</div>",
|
||
"question_id": "20N.1.HL.TZ0.5",
|
||
"topics": [
|
||
"topic-7-control"
|
||
],
|
||
"subtopics": [
|
||
"topic-7-1-control"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A company produces and sells domestic floor-cleaning robots.</p>\n<p>The floor-cleaning robots can clean different surfaces like wood and carpet. The floor‑cleaning robots can also avoid obstacles or stairs.</p>\n<p>Sensors are used by the processor that controls the floor-cleaning robot so that it can move safely.</p>\n</div><div class=\"specification\">\n<p>A computerized security system for the company’s headquarters protects against unauthorized access using a swipe-card system. Each door has a swipe-card reader that is connected to the central computer. A database stores the IDs of all employees and the rooms they are allowed to access.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> types of sensors used in the floor-cleaning robots.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the function of an output transducer in this situation.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> alternative computerized method that could be used in place of the swipe-card readers.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how the method identified in (c)(i) functions.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare polling <strong>and</strong> interrupts as mechanisms for the swipe-card readers to interact with the central computer.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em><br/>Proximity sensors/ range sensors;<br/>Which are used to determine how close an object is to the sensor;</p>\n<p>Optical sensors /Photocells and other photometric devices (often used in conjunction to proximity sensors);<br/>which are used to detect the presence or absence of objects;</p>\n<p>Tactile sensors / Contact sensors / Bumpers;<br/>which are used to determine whether contact is made between sensor and another object;</p>\n<p>Touch sensors;<br/>which indicate when contact is made;</p>\n<p>Force sensors;<br/>which indicate the magnitude of the force with the object;</p>\n<p>Machine vision;<br/>which is used in robotics for inspection / parts identification / guidance (accept other uses);</p>\n<p><em>Mark as 2 and 2</em></p>\n<p><em>Award marks for other miscellaneous category of sensors which also are used in robots. For example, devices for detecting / measuring temperature / fluid pressure / fluid flow / electrical voltage / other physical properties/</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/>Output transducer is a device that accepts a (digital) signal from processor;<br/>and turns it into a physical movement;<br/>to make the floor cleaning robot move in different direction;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>Any biometric device (finger print, eye scanner);<br/>pin pads/Key pads on doors;<br/>smartphone access(cloud-based) / mobile access control;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/><em>The answer to partc (ii) should match the candidate’s answer to part (i). For example</em>:<br/>a camera is used to scan the iris / finger print is scanned;<br/>a database stores images (scanned iris/finger print of each employee) and the rooms they are allowed access to;<br/>computer compares the scanned image to images stored in the database;<br/>if found, the employee is allowed to enter;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em><br/>Polling requires the computer to actively interact with each swipe device;<br/>the computer periodically checks each swipe device whether it has requested service, if it does not require servicing, the computer examines the next one, etc. If one of them requires servicing, the computer switches to running the serving program;<br/>polling will waste processing time whilst the device is idle;</p>\n<p>whilst:<br/>interrupt requires the device to flag the computer;<br/>processor receives interruption signal and services the interrupt by calling the appropriate system subroutine for interrupt processing/interrupt handler;<br/>and hence the computer’s time is not wasted whilst the swipe device is idle;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Mostly a well answered question.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates mostly gave good responses for this question. Some candidates confused output transducers with sensors.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Almost all were able to identify one alternative method and to give a good description.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Almost all were able to identify one alternative method and to give a good description.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>It is evident that students generally have problems with compare questions, describing the issues individually without performing any comparison, as was the case here.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.1.HL.TZ0.11",
|
||
"topics": [
|
||
"topic-7-control",
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"topic-7-1-control",
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>one</strong> difference between stack and queue data structures.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the purpose of the following queue method:</p>\n<p><code>enqueue()</code></p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the purpose of the following queue method:</p>\n<p><code>dequeue()</code></p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the purpose of the following queue method:</p>\n<p><code>isEmpty()</code></p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Assume that the queue Q holds the following data:</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<p style=\"text-align:left;\">The reversed queue Q would be:</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<p>Construct an algorithm in pseudocode for reversing the queue using a stack data structure.</p>\n<p>You may assume that the data in the queue is input and a new empty stack is created.<br/>Only the standard queue and stack operations are allowed.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Consider the following recursive method:</p>\n<pre>mystery(N)<br/> if N>0 then<br/> return 3 + mystery(N-3)<br/> else<br/> return 3<br/> end if<br/>end mystery</pre>\n<p>where <code>N</code> is an integer.</p>\n<p>Determine the value of <code>mystery(7)</code>. Show all your working.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> disadvantage of solving problems recursively.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em><br/>In a stack, the same end is used to insert and delete the elements;<br/>whilst two different ends are used in the queue to insert and delete the elements;</p>\n<p>Stack has only one open end so only one pointer is used to refer to the top of the stack;<br/>but queue has two open ends and two pointers should be used (to refer front and the rear end of the queue);</p>\n<p>Queue is a first-in-first-out (FIFO) data structure;<br/>and stack is last-in-first-out (LIFO) data structure;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>(<code>enqueue</code>) adds an item to rear/tail of the queue;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>(<code>dequeue</code>) removes an item from front/head of the queue;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>(<code>isEmpty</code>)<br/>checks if the queue is empty or not;<br/>returns <code>TRUE</code> if the queue is empty, <code>FALSE</code> otherwise;</p>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max] </strong></em><br/><em>Award <strong>[1]</strong> for a while loop (through queue);</em><br/><em>Award <strong>[1]</strong> for placing each item removed from the beginning of the queue to the top of the stack;</em><br/><em>Award <strong>[1]</strong> for a while loop (through stack);</em><br/><em>Award <strong>[1]</strong> for adding each element popped from the stack to the end of the queue;</em><br/><em>Award <strong>[1]</strong> for the correct use of stack and queue methods;</em></p>\n<p>Example:</p>\n<pre>//S is a new/created empty stack<br/> // push all of the elements of Q to stack<br/>while not Q.isEmpty()<br/> X=Q.dequeue()<br/> S.push(X) // <strong>OR</strong> S.push(Q.dequeue())<br/>end while<br/><br/> //then, pop each element from the stack and add it to Q<br/><br/>while not S.isEmpty()<br/> X=S.pop() <br/> Q.enqueue(X); //<strong>OR</strong> Q.enqueue(S.pop())<br/>end while</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em></p>\n<pre>mystery(7)= 3 + mystery(4);<br/> = 3 +3 + mystery(1) ;<br/> = 3 +3 + 3 +mystery(-2)=3+3+3+3=12 <em>;</em></pre>\n<p><em><strong>NOTE</strong>: Award only [<strong>1</strong>] if the working is not shown and only the final result is given</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em><br/>More difficult/complicated to code;<br/>if the data structure being processed is not recursive;</p>\n<p>It is difficult to find bugs;<br/>particularly while using global variables;</p>\n<p>Can use more memory (than iterative solution) when executed;<br/>because every recursive call increases the call stack;</p>\n<p>Recursion to a deeper level will be difficult/impossible to implement;<br/>if the call stack space on the system is limited;</p>\n<p>Slower execution / using a recursive function takes more time to execute;<br/>as compared to its non- recursive/ iterative counterpart;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Well answered question.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates mostly gave good responses for this question.</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates mostly gave good responses for this question.</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates mostly gave good responses for this question.</p>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A few candidates did not attempt this question. However, those who did generally answered well. A few candidates incorrectly used 'enqueue' operations also for the stack. </p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A simple enough recursive algorithm, leading to a high number of correct answers.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "20N.1.HL.TZ0.12",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Images in computers are stored as two-dimensional arrays.</p>\n<p>A black-and-white image (<strong>Figure 1</strong>) is stored as a 10 × 10 two-dimensional array named MAT (<strong>Figure 2</strong>).</p>\n<p>Each element of MAT holds a number for a colour; 1 represents the colour black and 0 represents the colour white.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">In an application, the black-and-white image can be inverted (all white pixels are changed to black, and all black pixels are changed to white).</p>\n<p style=\"text-align: left;\">Method <code>invert(N,A)</code> accepts a positive integer <code>N</code> and an <code>N × N</code> two-dimensional array <code>A</code> that holds the data for a simple black-and-white image; it returns the inverted <code>N × N</code> two-dimensional array <code>A</code>.</p>\n</div><div class=\"specification\">\n<p>In the application, it is also possible to rotate an image clockwise by 90 degrees (90°).<br/>For example, when the simple black-and-white image is rotated, the corresponding 10 × 10 two-dimensional array MAT is updated.</p>\n<p>This would mean the first row of the original MAT is the last column in the rotated MAT, the second row is the second-to-last last column, … and the last row is the first column.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">Consider the following algorithm fragment:</p>\n<pre style=\"text-align: left;\">K=input()<br/>loop for M=0 to K mod 4 - 1<br/> A=rotate(N,A)<br/>end loop</pre>\n<p style=\"text-align: left;\">where:</p>\n<ul>\n<li style=\"text-align: left;\"><code>N</code> is an integer and <code>A</code> is the <code>N × N</code> two-dimensional array that holds data about an image</li>\n<li style=\"text-align: left;\"><code>K(K>=0)</code> is an integer showing how many times the image should be rotated</li>\n<li style=\"text-align: left;\">method <code>rotate(N,A)</code> accepts an integer <code>N</code> and an <code>N × N</code> two-dimensional array <code>A</code> representing an image. It returns an <code>N × N</code> two-dimensional array representing the image rotated clockwise by 90°.</li>\n</ul>\n</div><div class=\"specification\">\n<p>The algorithm for method <code>rotate(N,A)</code> uses an additional <code>N × N</code> two-dimensional array, named <img src=\"\"/> The <code>N × N</code> dimensional array <code>B</code> is initialized and updated using the values from <code>A</code> to represent the image rotated clockwise by 90°.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm in pseudocode for the method <code>invert(N,A)</code>.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the number of degrees by which the image will be rotated if the input value of <code>K</code> is 3.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why it is more efficient that the loop in the given algorithm fragment executes <code>(K mod 4)</code> times instead of <code>K</code> times. You may give an appropriate example in your answer.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the algorithm in pseudocode for the method <code>rotate(N,A)</code> described above.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>To avoid inefficient use of memory, a new algorithm for the method <code>rotate(N,A)</code> is constructed.</p>\n<p>The <code>N × N</code> two-dimensional array <code>A</code> should be rotated clockwise by 90°, <strong>without</strong> the use of any additional arrays.</p>\n<p>One way of rotating the two-dimensional array <code>A</code> clockwise by 90° is to transpose <code>A</code>, and then reverse each row of <code>A</code>.</p>\n<p>The transpose of <code>A</code> is formed by turning all the rows of <code>A</code> into columns. For example, the value in the first row and third column (<code>A[1][3]</code>) is swapped with the value in the third row and first column (<code>A[3][1]</code>).<br/><br/>Construct the new algorithm in pseudocode for the method <code>rotate(N,A)</code> described above.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/><em>Award <strong>[1]</strong> for nested loops/loop through all array elements;</em><br/><em>Award <strong>[1]</strong> for checking the array element for the number of colour;</em><br/><em>Award <strong>[1]</strong> for updating correctly each of the array elements;</em></p>\n<p>Example 1:</p>\n<pre>loop for I=0 to N-1<br/> loop for J=0 to N-1<br/> if A[I][J]==1<br/> then A[I][J]=0<br/> else A[I][J]=1<br/> end if<br/> end loop<br/>end loop</pre>\n<p>Example 2:</p>\n<pre>R=0<br/>C=0<br/>I=0<br/>loop while I< N*N<br/> if A[R][C]==0<br/> then A[R][C]=1<br/> else A[R][C]=0<br/> end if<br/> C=C+1<br/> if C>9 then<br/> C=0<br/> R=R+1<br/> end if<br/> I=I+1<br/>end loop</pre>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>270 (degrees);</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em><br/>A rotation by 360 degrees returns the image/matrix to its original value, so no action need be taken. A rotation by 360+N degrees is equivalent to a rotation by N degrees(this logic repeats, so for 90 degree rotations, there are only 3 transformations needed: by 90, by 2*90 and by 3*90);<br/>making more is unnecessary/inefficient;</p>\n<p>Unnecessary calls to the method <code>rotate()</code> which would make the algorithm less efficient are avoided;<br/>for example, repeating 10 times and repeating 2 (=10 mod 4) times, both return the array holding the image rotated by 180 degrees;</p>\n<p><em><strong>NOTE</strong>: Accept any appropriate example, with any value of K which is greater than or equal to 4</em>;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/><em>Award <strong>[1]</strong> for completely correct nested loops;</em><br/><em>Award <strong>[1]</strong> for correctly determining row indexes (in both matrixes, A and B);</em><br/><em>Award <strong>[1]</strong> for correctly determining column indexes (in both matrixes, A and B);</em></p>\n<p><em><strong>NOTE</strong>: The method heading and return statement may not appear in the answers. Only an algorithm for the method <code>rotate()</code> is requested</em>.</p>\n<p>Example:</p>\n<pre>rotate(N,A)<br/> // initialize two dimensional array B<br/> // for example, int[][] B = new int[N][N];<br/><br/> <strong>loop for I = 0 to N-1</strong><br/><strong> loop for J = 0 to N-1</strong><br/><strong> B[I][J] = A[N-J–1][I]</strong><br/> // instead of these array subscripts<br/> // the following can be written<br/> // <strong>B[J][N-1-I] = A[I][J]</strong><br/> <strong>end loop</strong><br/><strong> end loop</strong><br/><br/> return B<br/>end rotate</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max] </strong></em></p>\n<p>Example:<br/>(Transposes the two-dimensional array and then reverses each row.)</p>\n<p><em>Award <strong>[3]</strong> for transposing.</em><br/><em>Award <strong>[1]</strong> for the correct outer loop;</em><br/><em>Award <strong>[1]</strong> for the correct inner loop;</em><br/><em>Award <strong>[1]</strong> for the correct swap;</em></p>\n<p><em>Award <strong>[3]</strong> for reversing each row of the transposed matrix.</em><br/><em>Award <strong>[1]</strong> for the correct outer loop;</em><br/><em>Award <strong>[1]</strong> for the correct inner loop;</em><br/><em>Award <strong>[1]</strong> for the correct swap;</em><br/><em>Award <strong>[1]</strong> for using nothing but a temporary variable to achieve this / no additional / extra space used except one temporary variable;</em></p>\n<p><em><strong>NOTE</strong>: The method heading and return statement may not appear. Only the algorithm for the method <code>rotate()</code> is requested</em>.</p>\n<pre>rotate (N,A)<br/> //transposes A<br/> loop for I=0 to N-1<br/> loop for J=0 to I-1 <br/> TEMP = A[I][J]<br/> A[I][J] = A[J][I] <br/> A[J][I] = TEMP<br/> end loop<br/> end loop<br/> // reverses each row of transposed matrix A<br/> loop for I=0 to N-1<br/> loop for J=0 to N div 2-1<br/> TEMP = A[I][J]<br/> A[I][J] = A[J][I]<br/> A[J][I] = TEMP<br/> end loop<br/> end loop<br/> return A<br/>end rotate</pre>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was answered well.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was well answered with many gaining full marks.</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was well answered with many gaining full marks.</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Answers to this question vary from poor to excellent. Some candidates constructed excellent algorithms and they gained full marks on this question.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Answers to this question vary from poor to excellent. Some candidates constructed excellent algorithms and they gained full marks on this question.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.1.HL.TZ0.13",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a new computer aided dispatch system for Bangbai, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"specification\">\n<p>The emergency management information system (EMIS) has a multitier architecture.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> functions of the Data Tier of the EMIS.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> characteristics of a TCP/IP Socket.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for any valid function up to <strong>[2 max]</strong></em>.<br/>Stores/retrieves/searches/edits the data;<br/>Encapsulates/holds the code for the database (accept DML / SQL or any other language);<br/>Abstracts/Simplifies access to the databases;<br/>Personalises the SQL for different databases (e.g. contains optimised queries for Oracle, MySQL etc.);<br/>Manages the transactions (anything relating to ACID);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for any characteristic up to <strong>[2 max]</strong></em>.<br/>Binding anything relevant (e.g. nodes, port, IP);<br/>Associating a socket with a socket address;<br/>Associated with the IP address and a port number for the local node;<br/>IP address;<br/>Port number;<br/>Sending/receiving data (packets);<br/>Node-to-node communication;<br/>Works at OSI levels 3, 4, and 5 (Accept any from L3 - Network, L4 - Transport, L5 - Session);</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "19M.3.HL.TZ0.1",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a new computer aided dispatch system for Bangbai, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"specification\">\n<p>Tania is considering purchasing an off‑the‑shelf emergency response system rather than a bespoke system as an implementation option in the proposed EMIS.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Other than cost, explain <strong>one</strong> advantage of purchasing an off‑the‑shelf emergency response system rather than a bespoke system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Other than cost, explain <strong>one</strong> disadvantage of purchasing an off‑the‑shelf emergency response system rather than a bespoke system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>two</strong> advantages of using URL rewriting as a strategy for making the HTTP connection stateful.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for any advantage up to <strong>[2 max]</strong></em>.<br/>Tried and tested;<br/>So, less risk;</p>\n<p>Regularly updated;<br/>Therefore, contains fewer errors;</p>\n<p>More tech support;<br/>e.g. Online chat systems.</p>\n<p>Usually available for various platforms / operating systems;<br/>Therefore, fewer compatibility issues, or can be run on different HW and SW;</p>\n<p>Shorter timeframe for implementation;<br/>Which is important in the context of saving lives/obtain benefits more quickly;</p>\n<p>Books/Training material more accessible;<br/>Easier to train staff on using the system;</p>\n<p>Reviews and feedback exist already for the product;<br/>Therefore, the quality of the final product can be known in advance;</p>\n<p>Off-the shelf is likely to implement common standards;<br/>Whereas, you would need to program compatibility in a bespoke system/to work with a multitude of devices;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for any disadvantage up to <strong>[2 max]</strong></em>.<br/>Modifications are not possible without help of developers;<br/>Source code is not usually available to change;</p>\n<p>Compatibility/interfaces with existing systems;<br/>It may not be possible to connect / share data with systems already in use;</p>\n<p>Standard operating procedures may need to change;<br/>To fit the software capabilities/functions;</p>\n<p>Software may contain unused features;<br/>That is potentially confusing for users;</p>\n<p>Software is designed for general requirements;<br/>It may not include features needed by Bangbai;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong></em> for explaining what URL-rewriting is in the context of stateful connection and allow <strong>[1]</strong> for an example or a comparison with session cookies</p>\n<p>URL Rewriting changes the URL to include parameters<br/>e.g. www.bangbai.com?userId=Asdf34e3</p>\n<p><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>Works without cookies/cookies disabled/as an alternative to cookies;<br/>URL re-writing will still work as it embeds the session ID inside the request;</p>\n<p>URL Rewriting does not result in anything being saved (e.g. cookies) on the client side;<br/>Therefore, the privacy of the client cannot be compromised (e.g. By searching contents of the cookie folder later);</p>\n<p>May work with legacy devices/devices without access to cookies;<br/>That are not able to use cookies/do not have access to an alternative to URL re-writing;</p>\n<p>Makes the links more descriptive/readable;<br/>Which will help the developer resolve issues (accept example, such as server identified in URL);<br/>(<em>Note to examiners: descriptive cannot be awarded a second mark if not related to the scenario e.g. search engines is not correct</em>)</p>\n<p>Allows the details of the identification of the user to be recorded in log files;<br/>Which will help for future analysis/reviews/data mining;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "19M.3.HL.TZ0.2",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a new computer aided dispatch system for Bangbai, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Some citizens have used the citizen reporting function of the app through a VPN.</p>\n<p>Explain why the use of a VPN would reduce the effectiveness of the citizen reporting app.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each point that explains why the use of VPN reduces the effectiveness of the app up to <strong>[6 max]</strong></em>.</p>\n<p>A VPN hides the true IP address;<br/>Instead, it provides the IP address of the VPN’s server;<br/>A VPN adds an additional layer of complexity has been added;<br/>Which may increase the likelihood of the connection dropping;<br/>A VPN encrypts/tunnels the data which is transmitted;<br/>Which has a potential overhead (more computational power/increases the size of data packets) and this may reduce emergency responses times;<br/>A VPNs may log traffic that passes through;<br/>This may present a potential security concern if sensitive information is reported;<br/>A VPN may employ a filtering policy/blocks ports;<br/>So certain parts of the app may not work (e.g. VOIP protocols may not work);<br/>If GPS/location service is deactivated, then the system is reliant upon IP Address;<br/>Location information can be obtained from the GPS/GPS is sent in data packets;<br/>However, it may not be as easily verifiable by comparing with a known IP location;<br/>Not having the true IP address would mean that the EMIS server would not have any indication of the location of the source of the report;<br/>VPN usage may give users a feeling of anonymity which may encourage misuse;<br/>Which may divert resources to the hoaxes instead of authentic reports;</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "19M.3.HL.TZ0.3",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a new computer aided dispatch system for Bangbai, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Rahul has suggested that the use of the citizen reporting function of the app might be much higher than initially requested and this could affect the emergency assistance function if they share the same server.</p>\n<p>As a result of this, Rahul has decided to put citizen report on a separate cluster of servers and use a load balancing algorithm to manage the workload of the server.</p>\n<p>Evaluate the appropriateness of the following load balancing algorithms for use in the Bangbai EMIS:</p>\n<ul>\n<li>client side random</li>\n<li>source IP Hash.</li>\n</ul>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>The answer could include the following</em>:</p>\n<p><strong>Definitions</strong>:<br/>The source IP hash combines the source and destination IP address to generate a hash key, which is then assigned to a specific server. The benefit of this approach is that a client who experiences a dropped connection can be returned to their session with the same server.<br/>The client-side random load balancing algorithm delivers a list of server IPs to the client, which then selects a server IP at random.</p>\n<p><strong>Security</strong> <br/>As Client Side Random allows control of the choice of server to be made by the client it would leave the system much more vulnerable to DOS/DDOS attacks.</p>\n<p><strong>Persistence</strong> <br/>If disconnected, Client Side Random may allocate a new server to the client as it will choose randomly from the list. However, if the IP is the same, then Client-side Hash will pair the client with the previous server. This may mean that the work being done before is not lost (e.g. Client continues from where she left of seamlessly).</p>\n<p><strong>Distinguishing between users</strong> <br/>Client-Side Hash is affected when a single IP address is used by many users (e.g. proxy servers sharing a connection, VPNs etc.). A single user might also disconnect and re-connect with a different IP address due to DHCP so would be seen as a “different” person.</p>\n<p><strong>Cost</strong> Client Side Random is a cheaper solution as it doesn’t require any expensive hardware on the server side (i.e. the hardware load balancers etc.).</p>\n<p><strong>Single Point of Failure (SPOF)</strong><br/>Client Side Random eliminates the SPOF as all requests do not depend on one device (i.e. the hardware load balancer provided by the system). Similarly, it avoids <strong>bottlenecks</strong> if the load balancer is overloaded.</p>\n<p><strong>Control</strong><br/>When using client side random, Bangbai Government is essentially losing control over the load balancing process. If for some reason they suddenly want to re-direct all queries away from certain servers (e.g. It’s been compromised, or the data centre has a fire etc.) they can’t, as they cannot easily/quickly change the algorithm on each of the client devices.</p>\n<p><strong>Intelligence/Adaptiveness/Flexibility</strong><br/>Client Side Random may not take into consideration privileged information about the servers, which it does not have access to. Therefore, it cannot decide which of the servers is *currently* best suited to handle a specific type Such information may include:</p>\n<ul>\n<li>Server Resources are different (Primary Memory, Secondary Memory, Processor)</li>\n<li>Deployment of the services to different servers (Server A and B deal with video reports, Server C with simple text/photo reports etc.).</li>\n<li>Current load of each server (Server B has more connections than server A)</li>\n<li>Current Health of each server (Server C just died)</li>\n</ul>\n<p><strong>Additional Research</strong><br/>Caching can affect a lot of load balancing algorithms as they use DNS to allocate the next server. This can skew the allocation of servers, but because Client-side Random uses a randomly generated server from a simple list, it avoids this problem.<br/>The HTTP/2 specification, which is now supported by every major browser, has built in support for Client-Side Load Balancing. The citizen reporting app can benefit from this as it uses HTTP for the REST API.</p>\n<p><strong>Overall comparison/evaluation</strong><br/>The main issue with the source IP hash load balancing algorithm is that each change can redirect EVERYBODY to a different server, which again lags the time of response for a citizen call in Bangbai.<br/>That is why some good load-balancers have implemented a consistent hashing method to ensure that if a server fails, for example, only the client connected to this server are redirected and not all.<br/>The counterpart of consistent hashing is that it doesn’t provide a perfect hash, and so, in a farm of 3 servers, some may receive more clients than others and this can take a toll on the time of response to citizen calls.<br/>When a failed server comes back, its users (determined by the hashing done on the Source IP) will be redirected to it again.<br/>There is no overhead in terms of CPU or memory when using such an algorithm.</p>\n<p><strong>Conclusion</strong><br/>A final measured conclusion that links together the various points and recommends one or both of the algorithms as appropriate for the needs of Bangbai.</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "19M.3.HL.TZ0.4",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a local economy driven by blockchain, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> characteristics of a digital signature.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> stages in the proof-of-work process.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Award <em><strong>[2 Max]</strong></em><br/>Anonymity (signature key identifies the user but not their real name).<br/>Asymmetric (cryptography);<br/>Certificate authority stamp;<br/>Collision resistant;<br/>Data / transaction / message;<br/>Deterministic;<br/>Hash / bitstring;<br/>Non-invertibility;<br/>Non-repudiation;<br/>Private key / Secret key<br/>Public key / key generation;<br/>Randomness (for Private key generation);<br/>Secure / encryption;<br/>Signature function / signing algorithm;<br/>Timestamp (sometimes);<br/>Unique.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Award <em><strong>[2 Max]</strong></em><br/>Candidate block is formed from transactions in the pool<br/>Nonce is generated (based on difficulty level);<br/>Miners try to find the nonce / Hash generated and compared to target / mathematical calculations / solving the problem;<br/>Puzzle solved / Hash smaller than target;<br/>Broadcast to distributed ledgers;<br/>Other miners verify/validate;<br/>Block added;<br/>Reward is issued to successful miner;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21M.3.HL.TZ0.1",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a local economy driven by blockchain, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how a Merkle tree stores the hash addresses for the blockchain technology.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the residents of Santa Monica may be concerned by the lack of a central authority to manage MONS transactions.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Award <em><strong>[4 Max]</strong></em><br/>A transaction is hashed and added (as a leaf node);<br/>A pair of leaf nodes are combined (hashed) to form the hash of a parent;<br/>When the number of nodes on the same level is odd the rightmost node is copied to the parent (For example, 10, 5, 3, 2, 1);<br/>This is repeated (recursively) until the Merkle root node is created;<br/>The root node hash is created to represent all of the hashes of the nodes;</p>\n<p><em>Award marks for a diagram that shows the steps</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Award <em><strong>[4 Max]</strong></em><br/>Award <strong>[2 max]</strong> for a Governance technology concern with example and a further [<strong>2 max] </strong>for expansion and consequence.</p>\n<p><strong>Technology example answer 1 [4 marks]</strong><br/>Concerns that there is no way to correct errors;<br/>A transaction sent to the wrong person;<br/>Relies on the receiver’s honesty to return the funds;<br/>But difficult to identify the receiver from their signature;</p>\n<p><strong>Technology example answer 2 [4 marks]</strong><br/>Residences may be concerned that errors or mistakes won’t be corrected;<br/>Their wallet password may be compromised and transactions made from their account;<br/>They would need to put in a request to Pablo (Santa Monica mayor) to trace the transactions;<br/>Pablo (Mayor) is unlikely to act since it isn’t a major breech on the blockchain;</p>\n<p><strong>Technology example answer 3 [4 marks]</strong><br/>The MONS currency may be subject to a 51% attack;<br/>With no central authority to roll back the blockchain;<br/>Double spend problem will occur;<br/>Currency would lose credibility/residences may stop using it.</p>\n<p><strong>Technology example answer 4 [4 marks]</strong><br/>Residences are trusting that the software is designed well and secure;<br/>Since it is open-source they may be concerned that hackers will find a flaw;<br/>With no central authority to manage the blockchain, which is distributed;<br/>There could be concerns that necessary updates/patches won't get rolled out.</p>\n<p>Award <strong>[2 max]</strong> for a Governance non-technology example</p>\n<p><strong>Non-technology example answer 1 [2 marks]</strong><br/>Human nature to trust in authority;<br/>When there is no Governance there may be irrational concern;<br/>They may worry about the currency's value going down;<br/>Because there is no way to influence the exchange rate;</p>\n<p><strong>Non-technology example answer 2 [2 marks]</strong><br/>The MONS currency could be abused by the criminal element;<br/>It may be used for money laundering / fraud / illegal payments;<br/>The anonymity of digital signatures makes this possible;<br/>No central authority to prevent this;</p>\n<p><em>Do not award marks for saying how to overcome concerns</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21M.3.HL.TZ0.2",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a local economy driven by blockchain, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Two features of hashing are <em>determinism</em> and <em>non-invertibility</em>.</p>\n<p>Explain how <em>determinism</em> <strong>and</strong> <em>non-invertibility</em> are used to facilitate the use of the blockchain.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>Award <em><strong>[6 Max]</strong></em></p>\n<p><strong>Determinism</strong>:<br/>The hash algorithm must always generate the same output for the same input;<br/>when replicated on different nodes;<br/>Otherwise, the consensus cannot be reached;</p>\n<p>Without determinism different miners would get different results;<br/>And there would be no consensus;<br/>So, the distributed ledger would be different for every node;</p>\n<p>Without determinism one block could not link to the next / prevHash;<br/>Therefore, transactions could be edited / blockchain would not be immutable;<br/>The blockchain would be insecure;</p>\n<p>Merkle tree and the block are validated many times by miners;<br/>Without determinism the Merkle proof won’t work;<br/>So, transactions can’t be validated;</p>\n<p>Without determinism, when a sender signs a transaction, other nodes on the blockchain wouldn’t be able to be certain it was them;<br/>Which may result in an increase in illegal payments and corruption;</p>\n<p><strong>Non-invertibility</strong>:<br/>A public key is hashed to provide a unique encrypted public address that can be published;<br/>Whereas private keys are not publishable and can be hashed (needed to access the wallet);<br/>Non-invertibility guarantees that publishable information is protected, and separated from private key;</p>\n<p>Prevents the private key from being calculated if you have the public key;<br/>Non-invertibility/secure private key prevents false transactions being made;<br/>So that “digital signatures” can authenticate the person who made the transactions;</p>\n<p>If the nonce used an invertible hash it could be calculated;<br/>So, it would be solved quickly / difficulty level could not be set;<br/>And fake branches could be created / double spend could occur;</p>\n<p><em>Mark as 3 and 3</em>.<br/>Award <strong>[1 max]</strong> for definition + <strong>[2 max]</strong> for explanation, for both sections (determinism and non-invertibility)</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21M.3.HL.TZ0.3",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a local economy driven by blockchain, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Pablo has claimed that the use of blockchain technology for the MONS cryptocurrency will mean the cryptocurrency is both secure <strong>and</strong> scalable.</p>\n<p>To what extent do you agree with Pablo?</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>Answers may include:</p>\n<p><strong>Security features</strong></p>\n<ul>\n<li>All transactions are recorded into files called blocks.</li>\n<li>Each block contains a hash of the previous block as well as some transactions.</li>\n<li>Every transaction is visible to everyone, which makes it difficult to change existing data which may be replicated on thousands of computers (decentralization).</li>\n<li>Any change to any historic transaction would be noticeable because the hashes of all subsequent blocks would not agree.</li>\n<li>Transactions are confirmed many times (consensus control).</li>\n<li>The more users of MONS there are, the more likely that there will be additional miners, which will increase the security of the network.</li>\n<li>A proof of work is required when creating a new block, which makes the effort required to falsify many blocks unfeasible (intractable).</li>\n<li>Each user has his own private key which is unknown to anyone else, as well as a public key (cryptography).</li>\n<li>With no central authority there is no focus point for hackers to attack.</li>\n<li>As MONS uses a private blockchain then only verified and approved computers could mine;</li>\n<li>The larger and more distributed the network is, the safer it is considered to be.</li>\n</ul>\n<p><strong>Security concerns</strong></p>\n<ul>\n<li>Ledgers are technically not immutable (but to do so would require unfeasible computing power and taking over >51% of the network within the space of 10 minutes (ie a 51% attack).</li>\n<li>The 51% attack is more likely to be successful on a small private blockchain rather than a large public one.</li>\n<li>Attacks on cryptocurrencies have been documented (reference opportunities).</li>\n<li>These attacks related to access to wallets (obtaining private keys).</li>\n<li>Currency transfer websites are a target and have been hacked with cryptocurrencies stolen.</li>\n<li>With no central control it is difficult to rollback transactions.</li>\n<li>DDoS attacks on cryptocurrency services may slow transactions slightly/may affect MONS value.</li>\n<li>Future concerns have been expressed about the scalability of the blockchain, lack of standards, and how it can be used if laws on data privacy become tighter.</li>\n</ul>\n<p><strong>Scalability</strong></p>\n<ul>\n<li>Scalability is defined as the capacity for a system or network to grow in size to manage increased demand.</li>\n<li>Thus, scalability refers to the ability of the MONS currency to continue to function when the number of transactions increases.</li>\n<li>Number of miners are likely to increase in proportion to the number of transactions because there are more rewards.</li>\n<li>A peer-to-peer network makes scalability possible because it is easy to add new nodes.</li>\n<li>A peer-to-peer network is unlikely to bottleneck with increased transactions.</li>\n<li>An increase in processing speeds for miners causes the nonce difficulty level to adjust and allows the blockchain to function (regardless of the number of miners).</li>\n<li>Due to the limitations of proof of work, blocks should take a minimum time (e.g. 10 minutes) to create and should hold in the region of 1MB of data, which is about 1000 to 3000 transactions.</li>\n<li>Other consensus methods can be used to increase scalability at a slight cost of decentralization, e.g. using proof of stake, proof of ownership, instead of PoW;</li>\n<li>However, if the network becomes heavily congested, a MONS currency transaction might take longer to be processed.</li>\n<li>If a network is running slowly, the mining fees have to increase or there is a risk that miners will stop mining.</li>\n<li>These increased fees will need to be paid by the users making a cryptocurrency transfer. Small cryptocurrency transfers may incur high charges making the currency undesirable.</li>\n<li>Blockchain ledgers are more scalable than centralized ledgers because they are distributed and there is no bottleneck.</li>\n</ul>\n<p><strong>Strategies to improve scalability include</strong><br/>Increasing the block size to include more transactions.</p>\n<ul>\n<li>The initial reason behind block size limits is to prevent Denial-of-Service (DOS) attacks by hackers seeking to create huge (or infinite) blocks that would harm and paralyze the blockchain.</li>\n<li>Increasing the block size to cope with increased demand may place the MONS currency at a risk of attack.</li>\n</ul>\n<p>Modifying the underlying protocol (although the issue with this is that there needs to be some central governance to make these decisions).</p>\n<ul>\n<li>The code is open source and a consensus (proposal and voting on forums and discussions boards) would be need to change the protocol.</li>\n<li>Since its creation there have been very few changes to the bitcoin source code so is unlikely that MONS blockchain code would be open to frequent changes.</li>\n<li>In Santa Monica, the MONS project would need some form of governance so that decisions to change the protocol and improve scalability could be made.</li>\n</ul>\n<p>Sharding and other “Layer 2” solutions can be implemented to reduce congestion on blockchains, in which slower transaction types are put on a different chain which deals only with that type.<br/>For example, Lightning networks, which is a layer 2 payment protocol designed to be layered on top of a blockchain-based cryptocurrency.</p>\n<p>Security could be optimized according to the \"Blockchain Trilemma\".</p>\n<p><strong>Scalability concerns</strong></p>\n<ul>\n<li>The lack centralized servers means that there is no control over the amount of hardware that can be added to the system (i.e. if centralized, scalability could be improved by the central authority by adding more processing power).</li>\n<li>Making decisions / governance of a distributed ledger is more difficult and has to rely on voting and an agreement before proceeding.</li>\n<li>The increased network traffic of many nodes on the blockchain can have a greater overall requirement for network bandwidth than (for example) centralized miners.</li>\n<li>Scalability in distributed ledger systems such as blockchain depends on the participation of the whole network, whereas centralized ledger systems (for example VISA) which depend only on the service provider and can scale quickly, but with hard limits imposed by the infrastructure.</li>\n</ul>\n<p><strong>Conclusion</strong><br/>A reasonable conclusion that includes both security and scalability.</p>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21M.3.HL.TZ0.4",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: computer science in medicine, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define <em>bioinformatics</em> and give an example of the data used in medical research.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> feature of fuzzy logic which makes it suitable for medical diagnosis.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Bioinformatics is the analysis of biological data by computers;<br/>For example: DNA / patient statistics / results from blood samples, etc. </p>\n<p><em><strong>Note</strong>: Accept any example related to medical research</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for a feature of fuzzy logic and <strong>[1]</strong> for outlining its relevance to medical diagnosis, up to <strong>[2 max]</strong></em>.<br/>Fuzzy logic can put a measure on uncertainty (give an approximate/probabilistic value);<br/>Can express relationships in a probabilistic manner;<br/>Patterns can be found which are not easy to classify with traditional logic;<br/>Work with multi-variable connections;<br/>Can help to give probability of certain diagnoses; </p>\n<p><em><strong>Note</strong>: One symptom may be important only if there are some related ones;</em><br/><em>vagueness and uncertainty of measurements e.g. borderline blood results etc.;</em></p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "17N.3.HL.TZ0.1",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: computer science in medicine, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare ultrasound and a CT scan in the creation of a medical image.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> compatibility issues that might be faced with the introduction of Electronic health records (EHRs) in a large country.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each comparison up to <strong>[4 max]</strong>. Note that the italicised descriptions below are from then case study and will not gain credit unless they are expanded on</em>.</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each issue and <strong>[1]</strong> for each associated outline, for two issues up to <strong>[4 max]</strong></em>.</p>\n<p>Hardware incompatibility;<br/>Different machines making measurements with dedicated processors;</p>\n<p>Software incompatibility;<br/>e.g. different OS where not all function with the electronic records software;</p>\n<p>Different format of records;<br/>Not all centres taking the same measurements;</p>\n<p>Different format of results;<br/>For example temperature “> 40” or temperature “= 40.5”;<br/>Analogue values may be rounded differently;</p>\n<p><em><strong>Note</strong>: Accept other reasonable issues which could occur</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "17N.3.HL.TZ0.2",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: computer science in medicine, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>With reference to the technology involved, explain how augmented reality imaging could be used to assist a surgeon in one country to carry out a complicated operation under the supervision of an expert surgeon in another country.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2]</strong> for a clear description of augmented reality, <strong>[2]</strong> for a clear explanation of how an image could be sent to the expert surgeon, and <strong>[2]</strong> for the role in the operation (<strong>up to</strong> <strong>[6 max]</strong>)</em>.</p>\n<p><em><strong>AR</strong></em>:<br/>Augmented reality projects digital/additional information;<br/>onto a real-time situation/onto the real world;</p>\n<p>Augmented reality allows an actual situation to be complemented in such a way;<br/>that essential information is added to a video image;</p>\n<p>An expert surgeon in another place sees the operation as if they were there/as a video being filmed;</p>\n<p>Tags attached to the affected area to be operated can be overlaid on the image;<br/>Can overlay information on the view they have;</p>\n<p><em><strong>Transmission</strong></em>;<br/>Annotated video data is continually streamed between the two;<br/>Using a camera at the operation end;<br/>In real-time over a (very) secure and fast network;<br/>Viewed by expert surgeon on a screen;</p>\n<p><em><strong>Example of use</strong></em>;<br/>The expert can show on the image what actions should be made (and where);<br/>Allow example;<br/>Using the information being sent back on a headset tablet/smart phone/transparent screen;</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "17N.3.HL.TZ0.3",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: computer science in medicine, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>A new health centre is planned in a remote mountain area to serve a community which is scattered over a large area. The nearest large hospital with complete medical services is difficult to reach.</p>\n<p>The services to be offered in the new health centre should include:</p>\n<ul>\n<li>health carers at the health centre for visits made by appointment</li>\n<li>expert doctors from other locations, who are available 24 hours a day via a VPN connection</li>\n<li>a comprehensive care system for chronically sick patients at home</li>\n<li>some visiting health workers</li>\n<li>some provision for emergency operations in the health centre</li>\n<li>diagnostic equipment to identify cases where a person needs to be treated at the large hospital.</li>\n</ul>\n<p>The planners are also considering whether to create an internet site with authorized access for the community.</p>\n<p>With reference to the technologies involved, discuss ways in which the required services could be met and their effect on the people in the community.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><strong>Discussion should focus on</strong>:</p>\n<p>“<em>health carers at the health centre for visits made by appointment</em>”<br/>People will need a physical presence at the centre for reassurance which means carers need to be employed and in place – enough to cope with the estimated need especially as visits to the hospital are difficult.</p>\n<p>“<em>expert doctors from other locations, who are available 24 hours a day via a VPN </em><em>connection</em>”<br/>Essential for crises which occur outside of the hours the centre is open.<br/>Will need a secure and reliable connection with access from mobile device, and access to any data and phone calls coming into the centre.</p>\n<p>“<em>a comprehensive care system for chronically sick patients at home</em>”<br/>Continual measurements can be sent to the health centre; this could be done with wearables. Someone with a heart problem could have the heart rate continually measured on a bracelet with an imbedded RFID to communicate wirelessly via NFC to a receiving device which sends the data automatically to the health centre.<br/>The centre would need to have software to interpret the data (or this could be done at the patient side – therefore less to send) and any fluctuations identified.<br/>Danger signals would mean the doctor needs to know. Health carer would check on minor changes as well as regular check-ups – need for health carers depends on proportion of chronically sick and elderly.<br/>Effect on population – good system to stay at home may be met with some aversion to remote monitoring.</p>\n<p>“<em>some provision for emergency operations in the health centre</em>”<br/>Could be dealt with by telesurgery when essential but will need appropriate cameras/connections and software, as well as a doctor who is confident to be involved.</p>\n<p>“<em>diagnostic equipment to identify cases where a person needs to be treated at the large hospital</em>”<br/>An ultrasound scanner should probably be purchased. For example, regular scans are needed for pregnant women. However, these need expert technical operators and interpreters. One suggestion would be for the scans to take place via telemedicine and the results sent electronically to be analysed at the hospital.</p>\n<p>An internet site for communication and advice would have the advantages of knowledge so that a decision whether or not to make an appointment can be made. Accounts would need to be set up and security ensured via firewalls, encryption etc. as personal medical information is sensitive. It would be helpful to give information as to when an appointment should be made and simple remedies for simple problems. Some people may be suspicious of using this medium for medical uses and be concerned about privacy.</p>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "17N.3.HL.TZ0.4",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a new computer aided dispatch system for Bangbai, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> smartphone resources that might limit the user experience of the Bangbai app.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why an application programming interface (API) would be useful when developing a smartphone app which uses the CAD system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each smartphone resource identified up to <strong>[2 max]</strong></em>.</p>\n<p>Screen size;<br/>Memory;<br/>Processor speed;<br/>Available primary or secondary storage;<br/>Battery life;<br/>GPS Receiver;</p>\n<p><em>Do not accept any resources that are obviously on the server side</em><br/><em>Do not accept software as a resource</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying why an API may be useful and <strong>[1]</strong> for a brief elaboration up to <strong>[2 max]</strong></em>.</p>\n<p>An API ensures abstraction;<br/>as the user only how the service is requested, how the service is implemented;</p>\n<p>An API acts as a “contract” or definition of the services of the CAD system;<br/>which makes it clearer to client application developers and back-end developers;</p>\n<p>The API would ensure arguments (parameters) are passed to the system;<br/>in the correct order and type);</p>\n<p>An API would make sure that the app is expecting a specific data type;<br/>which will be returned from a CAD request/service;</p>\n<p>An API provides a consistent method/protocol/interface for building a resource;<br/>and thus, reduces the amount of programming required/provides structure.</p>\n<p>An API would allow the smartphone app and the CAD system to be “compatible”;<br/>can be easily updated if the situation changes;</p>\n<p>An API ensures authentication/authorisation/security checks are carried out;<br/>before allowing operations to be done;</p>\n<p>Using an API would allow server to be more secure;<br/>as unused ports and binary/executables/programs/scripts could be hidden from users. (i.e. Only the API handler would be accessible, not the program modules);</p>\n<p>Using an API would allow changes to be coordinated between all users;<br/>and backward compatibility when the app is upgraded;</p>\n<p>An API standardises the operations available across different clients/devices;<br/>and the level of service would not be as device dependent;</p>\n<p>An API would allow the server to track usage of individuals (through keys);<br/>To identify when certain users were overusing services;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "19N.3.HL.TZ0.1",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a new computer aided dispatch system for Bangbai, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Some people have asked if the informing function of the Bangbai app could allow the anonymous reporting of incidents and issues. They believe that potentially useful information (for example, information about criminals) might not be reported because people are afraid of their identities being discovered.</p>\n<p>To what extent might it be technically possible for the Bangbai app to guarantee the anonymity of its users if this feature was approved?</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>The answer could include the following</em>:</p>\n<ul>\n<li>It is very difficult to guarantee anonymity as so many technologies and levels of logging are involved.</li>\n<li>Encryption can be used to make the contents of the communication inaccessible (or at least much more difficult to access).</li>\n<li>Information such as IP address, can be used to trace somebody but would need the cooperation of an ISP etc.</li>\n<li>IP Addresses are logged at various different levels: Client OS, ISP, routers on the internet (many of them), host webserver (in a weblog file). The server could be set up to not log this information.</li>\n<li>Logging of IP addresses by the ISP, local router at client’s point of origin and routers all along the internet cannot necessarily be controlled or secured to prevent them logging accesses.</li>\n<li>MAC addresses that identify the specific device used are logged by switches.</li>\n<li>VPNs or proxy servers could be used to make the users’ origin difficult to obtain.</li>\n<li>IP addresses can be shared between many different computers in one area/organization, using NAT (network address translation) so might not uniquely identify a person.</li>\n<li>The client device itself could be compromised with key loggers, spyware etc. and therefore even if all transmission risks were removed, someone could still get access to the information and source.</li>\n<li>Various products/services/protocols exist which try to make anonymity easy (such as Tor browser) but this is still an area that is developing</li>\n<li>If the servers are vulnerable to physical attack, then people could forcefully enter the hosting facility and install monitoring software or steal data. Sufficient security, biometric access locks etc. could help to prevent this.</li>\n<li>If the data is backed-up, then this historic data should be anonymised or destroyed.</li>\n<li>How ethically correct is it for the providers of the emergency services to receive what could be hoax calls and have no way of knowing themselves who has made them. Could this be counterproductive and therefore allow people to drain emergency resources and potentially send police to unnecessary operations? The equivalent to this online service would be the “confidential telephone” services available by the police in several countries, but these are not anonymous either (though they don’t necessarily pass through an open communications platform like the Internet).</li>\n</ul>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "19N.3.HL.TZ0.4",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a local economy driven by blockchain, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> characteristics of a peer-2-peer (P2P) network.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> sources of entropy. </p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Many clients connect <span style=\"text-decoration:underline;\">directly</span> to many other clients;<br/>Clients also act as servers;<br/>No centralized administration for the network/decentralized network;<br/>Network is more resilient to failure;<br/>Is more scalable than a client server network;<br/>There are no \"bottlenecks\" as with Client Server model; </p>\n<p><em><strong>Note</strong>: Do not accept “widely used for illegal file sharing” (or similar)</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Answers may include</em>:</p>\n<p>atmospheric noise;<br/>radioactivity;<br/>thermodynamics;<br/>Brownian motion of particles;<br/>mouse movements;<br/>algorithmic sources;</p>\n<p><em><strong>Note</strong>: Do not accept “Entropy can be obtained from physical sources” as this is clearly stated in the case study. A physical source must be stated (e.g. radioactivity) to get that mark</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "20N.3.HL.TZ0.1",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a new computer aided dispatch system for Bangbai, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how a smartphone uses data from GPS satellites to obtain its location.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Rahul has stated the importance of a multi-tier architecture using standard protocols. Explain why this approach is important.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <em><br/>Award<strong> [1]</strong> for identifying part of the process that a smartphone uses to obtain its location up to <strong>[4 max]</strong></em>.</p>\n<p>Trilateration;<br/>Uses signal strength and latency based on very accurate atomic clock;<br/>Complex formula taking into consideration the curvature of the earth to arrive at latitude, longitude and altitude;<br/>The smartphone uses the distance between satellites to create overlapping “spheres” that intersect in a circle (which is the phones location);<br/>When fewer satellites are available the accuracy diminishes and may be specified to within a radius only;<br/>Assisted/augmented GPS can help accuracy by adding location information received from or about WIFI networks and the triangulation of cell towers;<br/>The smartphone depends on data received from GPS satellites, but that can be obstructed or distorted by obstruction (e.g. tall buildings), weather or water;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>The answer could include the following</em>:</p>\n<p><strong>A multi-tier approach for developers provides</strong>:<br/>Abstraction of layers;<br/>Less complexity;<br/>Faster development time;<br/>Easier testing;<br/>Work can be divided better amongst teams;<br/>Performance – system can be divided and allocated to many processors/nodes;<br/>Easier addition of clients, databases or logic which does not “break” other layers;</p>\n<p><strong>The use of standards and protocols provides</strong>:<br/>Future proofing;<br/>Interoperability;<br/>Communication with legacy devices;<br/>Compatibility with best of breed 3rd party products (e.g. firewalls, load balancers, Quality of Service and network monitoring software etc.).<br/>Quick patching of discovered errors, exploits etc.;<br/>Standards and protocols may already be implemented and have available code references or libraries which would reduce development time etc.;<br/>Security updates and upgrades from the community; </p>\n<p><em><strong>[1–2 marks]</strong></em><br/>A limited or superficial response that indicates a basic understanding of one or both approaches. Uses little appropriate subject specific terminology.</p>\n<p><em><strong>[3–4 marks]</strong></em><br/>A competent explanation of the importance of one or both approaches. There is appropriate use of subject specific terminology throughout the response.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "19N.3.HL.TZ0.2",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a local economy driven by blockchain, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the steps that need to be carried out by the blockchain system to find a user’s current MONS balance.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Dolores states, “one of the great things about the blockchain is that we can ensure that the solution time remains at 10 minutes, and we can do this even as the number of MONS miners increases” (lines 63–65).<br/><br/>Explain why it is important to ensure the solution time remains at 10 minutes.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>Balances are not stored in the blockchain/calculated in real time;<br/>A digital signature/hash address is used to identify the user;<br/>An algorithm must go through the entire blockchain examining all transactions that match the signature/address;<br/>Relevant transactions debits and credits are added to calculate the balance;<br/>Third party services are available to monitor the blockchain and provide a balance for the specified addresses;<br/>It is likely that the wallet (app) will regularly compute the balance by verifying all the MONS it contains, but to do a complete confirmation could take a long time (e.g. 10–60 mins on bitcoin);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>Proof of work delays the creation of new blocks and therefore avoid spamming and/or instant re-writing of the blockchain;<br/>A certain amount of time is required to make sure that there are not too many blocks mined;<br/>If mining takes much longer than 10 minutes, it may discourage miners from mining<br/>If mining takes much longer than 10 minutes it may make cryptocurrency transactions too slow;<br/>Miners are required by the network so therefore a balance must be found which takes miners with standard hardware the correct time to solve;<br/>Complexity of the PoW (and therefore time required) can be altered by changing the nonce value used to create a valid hash;<br/>Difficulty of PoW can be adjusted so that miners take that time to create blocks;<br/>if the number of miners rises too much so the time drops, the reward can be decreased to try to reduce the attractiveness of mining;<br/>Many cryptocurrencies (e.g. Bitcoin) modify the difficulty of their PoW to attract miners while maintaining the minimum time for a candidate block hash to be generated;</p>\n<p><em><strong>Note</strong>: Do not accept “adding more (powerful) GPUs”, as this will simply increase the chance of a particular miner solving the proof of work first, not the difficulty of the task for all miners</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "20N.3.HL.TZ0.2",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a new computer aided dispatch system for Bangbai, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>It is expected that at any given time during a normal day, there will be between 50 and 100 members of the public interacting with each individual server in the cluster. If the network card in one of the servers breaks while being used, it is very likely that the users connected to it would still be able to complete their current operations without any inconvenience.</p>\n<p>Explain why this hardware problem would not seriously affect the users who are currently connected to that particular server.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>The answer could include the following</em>:</p>\n<p><strong>Redundancy</strong>:</p>\n<ul>\n<li>There is another network card in the server which is waiting to take the role of the first.</li>\n<li>The user session information is replicated onto another server so that the other server can take over the operation of that client, should the first one be completely unavailable (e.g. If there is no redundant network card).</li>\n</ul>\n<p><strong>Failover</strong>:</p>\n<ul>\n<li>At the point failure, the OS realises that the network card is not working and automatically switches to the redundant network card to continue conversation with the client.</li>\n<li>At the point of failure, the load balancer/application server/partner server realises that the server is no longer reachable and from that point onwards all requests by the owner of that session are directed to the server which contains a replicated copy of the original session. The session is then replicated to a third machine.</li>\n</ul>\n<p><strong>Replication of session information</strong>:</p>\n<ul>\n<li>The information contained in the session of a user can either be stored only in one node of the cluster (sticky sessions), or it can be stored in shared memory or secondary storage accessible by the whole cluster. There are performance overheads, because if the session information is constantly changing, or it has to be accessed with each request then it would usually be much faster to keep it in primary memory in one server (sticky sessions) to which the user is always directed by the load balancer / application server.</li>\n</ul>\n<p><em><strong>[1–2 marks]</strong></em><br/>A limited response that indicates very little understanding of the topic or the reason is not clear. Uses little or no appropriate subject specific terminology. No reference is made to the scenario in the stimulus material. The response is theoretical and descriptive.</p>\n<p><em><strong>[3–4 marks]</strong></em><br/>A superficial explanation of why this hardware failure would not seriously affect the users who are currently connected to that particular server. There is some use of appropriate subject specific terminology in the response.</p>\n<p><em><strong>[5–6 marks]</strong></em><br/>A thorough explanation of why this hardware failure would not seriously affect the users who are currently connected to that particular server. Explicit and relevant references are made to the scenario in the stimulus material. There is appropriate use of subject specific terminology throughout the response.</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "19N.3.HL.TZ0.3",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a local economy driven by blockchain, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Critics have complained about the potential environmental effects caused by the computing resources required by a blockchain network.</p>\n<p>Analyse the potential effects that the use of MONS could have on the environment.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><strong>Negative impacts on the environment</strong>:<br/>Miners which work on the network require energy to process proof of works;<br/>Farms of miners will need energy for cooling systems such as AC, which have negative environmental results (e.g. greenhouse gases);<br/>The use of computers to maintain the network may result in e-waste, which would be detrimental to the environment;<br/>The mining of raw materials for electronic products (e.g. silicon, aluminum, copper, lead, and gold) can damage natural habitats for animals/pollutes water;</p>\n<p><strong>Positive/Mitigating factors</strong>:<br/>Renewable energy may be used (solar energy is used by Bitcoin Miners now)<br/>Low power specific computational devices (ASICS) are now widely used which reduces power consumption;<br/>As miners aim to make a profit, they will always use the cheapest source of energy and therefore prefer solar etc.;<br/>A moving towards a proof of stake rather than a proof of work would reduce the amount of processing required, therefore reducing cost and environmental damage;<br/>Moving away from physical currency would reduce cotton/paper/plastic production;<br/>The new computing machinery would replace the older physical technology (banks, counting machines, printing, etc.);</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "20N.3.HL.TZ0.3",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: a local economy driven by blockchain, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Pablo states: “In a traditional banking system, users trust the banks to keep everyone’s money safe; but with MONS, the whole blockchain, right from the very first transaction, would be visible to all MONS users, so it is important to be able to explain to citizens how their money is guaranteed to be safe” (lines 109–112).</p>\n<p>With reference to the key technologies, to what extent do you believe the MONS project will ensure the safety of the residents’ money?</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[12 max]</strong></em>.<br/><em>Answers may include</em>:</p>\n<p><strong>Security features</strong><br/>All transactions are recorded into files called blocks.<br/>Each block contains a hash of the previous block as well as some transactions.<br/>Every transaction is visible to everyone, which makes it difficult to change existing data which may be replicated on thousands of computers (decentralisation).<br/>Any change to any historic transaction would be noticeable because the hashes of all subsequent blocks would not agree.<br/>Transactions are confirmed many times (consensus control).<br/>The more users of MONS there are, the more likely that there will be additional miners, which will increase the security of the network.<br/>A proof of work is required when creating a new block, which makes the effort required to falsify many blocks unfeasible.<br/>Each user has his own private key which is unknown to anyone else, as well as a public key (cryptography).<br/>With no central authority there is no focus point for hackers to attack.<br/>As MONS uses a private blockchain then only verified and approved computers could mine.<br/>The larger and more distributed the network is, the safer it is considered to be.</p>\n<p><strong>Security concerns</strong><br/>Ledgers are technically not immutable (but to do so would require unfeasible computing power and taking over >51% of the network within the space of 10 minutes (i.e. a 51% attack).<br/>The 51% attack is more likely to be successful on a small private blockchain rather than a large public one.<br/>Attacks on cryptocurrencies have been documented (reference opportunities).<br/>These attacks related to access to wallets (obtaining private keys).<br/>Currency transfer websites are a target and have been hacked with cryptocurrencies stolen.<br/>With no central control it is difficult to rollback transactions.<br/>DDoS attacks on cryptocurrency services may slow transactions slightly/may affect MONS value.<br/>Future concerns have been expressed about the scalability of the blockchain, lack of standards, and how it can be used if laws on data privacy become tighter.</p>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "20N.3.HL.TZ0.4",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: Genetic algorithms, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> characteristics of a genetic algorithm.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline what is meant by the term “elitism”.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>(Search) heuristic / Finds a near optimal solution;<br/>Based on the theory of evolutionary biology / natural selection;<br/>Uses convergence;<br/>Uses a stochastic approach;<br/>Uses a mating pool;<br/>Uses elitism;<br/>Uses a stopping condition;<br/>Uses selection;<br/>Uses crossover;<br/>Uses mutation;<br/>Uses a fitness function;<br/>Uses offspring/generations;<br/>Uses stochastic universal sampling;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Taking only the fitness members of a population to the mating pool;<br/>Based on a calculated fitness value;<br/>Unfit population members are discarded / fit members are carried forward;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.3.HL.TZ0.1",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: Genetic algorithms, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Calculate the offspring from parents P1 and P2 using the cycle crossover (CX) method.</p>\n<p><img src=\"\"/></p>\n<p>Show all your working.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The partially matched crossover (PMX) operator is a genetic operator that can be used with a genetic algorithm written to solve the travelling salesman problem.</p>\n<p>PMX combines two chromosomes (parents) to produce a new chromosome (offspring).</p>\n<p>Outline how the parental characteristics (cities) are preserved when two offspring are generated through PMX crossover.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p><strong>Solution 1</strong></p>\n<p><strong><img src=\"\"/></strong></p>\n<p><em>Award <strong>[1]</strong> for B D in correct place</em><br/><em>Award <strong>[1]</strong> for G I F J in correct place</em><br/><em>Award <strong>[1]</strong> for C E in correct place</em><br/><em>Award <strong>[1]</strong> for A H in correct place</em></p>\n<p><strong>Solution 2</strong></p>\n<p><strong><img src=\"\"/></strong></p>\n<p><em>Award <strong>[1]</strong> for D G in correct place</em><br/><em>Award <strong>[1]</strong> for I F J B in correct place</em><br/><em>Award <strong>[1]</strong> for A C in correct place</em><br/><em>Award <strong>[1]</strong> for H E in correct place </em></p>\n<p><em>Note to examiners: allow follow through errors, so that if a candidates’ logic is correct from the point of an error, they are awarded marks that point onwards</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p><strong>Offspring 1</strong><br/>PMX algorithm <span style=\"text-decoration:underline;\">randomly</span> selected sub-sequence of P1 is copied into the first offspring;<br/>P2 contributes the remaining cities to the first offspring;<br/>To ensure that P2 cities are not duplicated, they are mapped against P1;</p>\n<p><strong>Offspring 2</strong><br/>The remaining cities in P1 (i.e. not copied to offspring 1) are copied into the second offspring;<br/>P2 contributes the remaining cities to the second offspring;<br/>To ensure that P2 cities are not duplicated, they are mapped against P1;</p>\n<p><em>Award <strong>[1]</strong> for this alternative offspring 2 solution if offspring 1 is correctly described</em></p>\n<p><strong>Alternative Offspring 2</strong><br/>The process for offspring 1 is repeated but with a different P1 random subsequence;</p>\n<p><em>Mark as <strong>[2 max]</strong> for Offspring <strong>1</strong> and <strong>[2 max] for</strong> Offspring 2</em></p>\n<p><em>Accept a correct example that explains the process but not replicated from the case study</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.3.HL.TZ0.2",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: Genetic algorithms, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Compare and contrast the effectiveness of heuristic and non-heuristic algorithms for optimizing solutions.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/>A heuristic is an algorithm that does not guarantee an optimal solution;<br/>Instead, a stopping criterion is determined before running;<br/>Heuristic sacrifices accuracy (optimization) for speed;<br/>Heuristics use randomness to escape local extrema / for exploration;<br/>Unlike heuristics, brute-force does not build off previous success/is entirely explorative and novel;<br/>Given enough processing power/time, a brute force approach will always produce an optimal solution;<br/>A brute-force approach is not suitable / heuristic only suitable approach for non-polynomial (computationally intractable) problems;<br/>The number of different permutations if the number of cities is high will make the problem difficult to solve computationally;<br/>In some situations, an optimal solution may be necessary ethically (e.g. where people’s;<br/>lives are at risk) / In other situations, a non-optimal solution can be used; </p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.3.HL.TZ0.3",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The following flowchart is intended to represent an algorithm in which numbers that are input cannot be negative.</p>\n<p>The flowchart contains a logic error that will affect the algorithm’s functionality.</p>\n<p style=\"text-align: center;\"><img src=\"\"/><img src=\"\" style=\"display: block; margin-left: auto; margin-right: auto;\"/></p>\n</div><div class=\"specification\">\n<p>The algorithm is to be altered to restrict the values that are input to whole numbers between 0 and 1000.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the logic error in the algorithm.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how the error in the algorithm identified in part (i) can be corrected.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the name of the method that could be used to restrict the values that are input.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A further change has been requested for the algorithm to enable it to calculate the average of all the numbers entered. The average will be output when the algorithm terminates.</p>\n<p>Based on the flowchart, construct this algorithm using pseudocode. You must include the required changes:</p>\n<ul>\n<li>correction of logic error</li>\n<li>only allow input of integers between 0 and 1000</li>\n<li>calculation of average of all numbers entered</li>\n<li>output of final average.</li>\n</ul>\n<div class=\"marks\">[8]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em></p>\n<p>The algorithm will always output zero as the value of LOWEST, for any set of the input values (because all input values are greater than or equal to 0);<br/>The LOWEST is initialized to 0 and negative inputs are not allowed, zero will be the permanently lowest number;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em></p>\n<p>Example 1:</p>\n<p>Replace LOWEST = 0;<br/>With LOWEST=99999999/ any very high number;</p>\n<p>Example 2:</p>\n<p>Before the loop/ <em>Accept “at the beginning”</em>;<br/>The first number NUMBER should be inputted and LOWEST set to NUMBER / LOWEST=input(NUMBER);<br/>Loop only 999 times (because 1 number already inputted)/ condition in the loop should be changed to COUNTER>998;</p>\n<p>Example 3:</p>\n<p>If statement should be used within the loop;<br/>after the statement ‘input NUMBER’;<br/>For example, if COUNTER==0 then LOWEST = NUMBER/ set LOWEST to the first inputted number;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>Validation (check);<br/>Data type check;<br/>Range check;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[8 max] </strong></em></p>\n<p>Correct initialization of HIGHEST, LOWEST and TOTAL;<br/>Correct use of loop for 1000 inputs (doesn’t have to be while loop);<br/>Checking if NUMBER is between 0 to 1000(accept inclusive or exclusive range);<br/>Checking if NUMBER is a whole number;<br/>Running total of numbers (for average calculation);<br/>Correct comparison and changing the value of HIGHEST if needed;<br/>Correct comparison and changing the value of LOWEST if needed;<br/>Appropriate calculation of AVERAGE;<br/>Output of AVERAGE, HIGHEST and LOWEST (outside loop);</p>\n<p>Example answer 1</p>\n<pre>HIGHEST = −1 //any value lesser than or equal to 0<br/>LOWEST = 10000 //any value greater than or equal to 1000<br/>COUNTER = 0<br/>TOTAL = 0<br/>loop while COUNTER < 1000 // allow COUNTER <= 999<br/> input NUMBER<br/> if NUMBER<0 or NUMBER>1000 or NUMBER div 1 ≠ NUMBER/1<br/> //accept NUMBER<1 or NUMBER>999 or NUMBER mod 1 ≠ 0<br/> output \" Your number is invalid, please try again\"<br/> else<br/> if NUMBER > HIGHEST then<br/> HIGHEST = NUMBER<br/> end if<br/> if NUMBER < LOWEST then<br/> LOWEST = NUMBER<br/> end if<br/> TOTAL = TOTAL + NUMBER<br/> COUNTER = COUNTER + 1<br/> endif<br/>end loop<br/>AVERAGE = TOTAL / COUNTER // allow TOTAL / 1000<br/>output HIGHEST<br/>output LOWEST<br/>output AVERAGE</pre>\n<p>Example answer 2: (the lowest and the highest are set to the value of the first inputted number)</p>\n<pre>input NUMBER<br/>loop while NUMBER<0 or NUMBER>1000 or NUMBER div 1 ≠ NUMBER/1<br/> output \" Your number is invalid, please try again\"<br/> input NUMBER<br/>end loop<br/>HIGHEST = NUMBER<br/>LOWEST = NUMBER<br/>TOTAL = 0<br/>loop COUNTER FROM 0 to 998<br/> input NUMBER<br/> loop while NUMBER<0 or NUMBER>1000 or NUMBER div 1 ≠ NUMBER/1<br/> output \" Your number is invalid, please try again\"<br/> input NUMBER<br/> end loop<br/> if NUMBER > HIGHEST then<br/> HIGHEST = NUMBER<br/> end if<br/> if NUMBER < LOWEST then<br/> LOWEST = NUMBER<br/> end if<br/> TOTAL = TOTAL + NUMBER<br/><br/>end loop<br/>AVERAGE = TOTAL / 1000<br/>output HIGHEST, LOWEST, AVERAGE</pre>\n<p>Example answer 3</p>\n<pre>HIGHEST = -1 //any value lesser than or equal to 0<br/>LOWEST = 10000 //any value greater than or equal to 1000<br/>C = 0<br/>TOTAL = 0<br/>loop while C<1000<br/> input NUMBER<br/> if NUMBER>=0 and NUMBER<=1000<br/> if NUMBER mod 1 == 0<br/> if NUMBER > HIGHEST then<br/> HIGHEST = NUMBER<br/> else<br/> if NUMBER < LOWEST then<br/> LOWEST = NUMBER<br/> endif<br/> end if<br/> TOTAL = TOTAL + NUMBER<br/> C=C+1<br/> endif<br/> else<br/> output(“invalid input, enter another number”)<br/> endif<br/>end loop<br/>output HIGHEST, LOWEST, TOTAL/1000</pre>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The term logic error was not always familiar to candidates. Many candidates correctly identified the logic error in Part(a)(i).</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A large number gave less precise or incorrect answers to Part(a)(ii).</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A large number of candidates did not score any marks for question in Part (b) because they were not able to state the name of the method that could be used to restrict the values that are input.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>In Part (c) candidates were required to produce an algorithm based on the flowchart given in the question. Most candidates achieved some marks for this algorithm, but full marks were rare.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "21M.1.HL.TZ0.14",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: Genetic algorithms, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Fenna has decided to use roulette wheel selection and cycle crossover (CX) for her genetic algorithm. She has two other important decisions to make:</p>\n<ul>\n<li>What values to assign to the variables when they are first initialized. These variables<br/>include population size, initial population routes, and mutation rate.</li>\n<li>What stopping criteria to use for the genetic algorithm.</li>\n</ul>\n<p>Discuss the impact that these decisions may have on the success of the genetic algorithm.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[12 max]</strong></em>.</p>\n<p><strong>Roulette wheel selection</strong></p>\n<ul>\n<li>Effective with large-sized problems.</li>\n<li>Low fitness parents of the population have a chance for be selected.</li>\n<li>This is important in hill climbing/avoiding local minima.</li>\n<li>When a population contains only individuals with scores of large, nearly equal values, the selection probability of all individuals becomes nearly identical.</li>\n<li>Other types of selection may be more suitable for smaller search spaces.</li>\n<li>Prevents overly quick convergence.</li>\n<li>Populations must be sorted on every cycle.</li>\n</ul>\n<p><strong>Cyclic crossover (CX)</strong></p>\n<ul>\n<li>Allows for two parents chromosomes/cities to be combined/preserved.</li>\n<li>And not be duplicated during crossover.</li>\n<li>Ensures diversity of chromosomes/cities from parents.</li>\n<li>Accelerates the search process in genetic algorithms.</li>\n</ul>\n<p><strong>Population size</strong></p>\n<ul>\n<li>It is difficult to decide upon a population size.</li>\n<li>Too large a population will increase the likelihood of a near-optimal solutions but will increase the length of time to run through a generation.</li>\n<li>A large enough population may have enough diversity to arrive at a near-optimal solution without any mutation.</li>\n<li>Too small a population may mean that you may never arrive at a near-optimal solutions;</li>\n<li>Because there is not enough variation in the parents.</li>\n<li>This may require you to increase the mutation rate, which will add greater variation.</li>\n<li>But may also not arrive at a near-optimal solution.</li>\n</ul>\n<p><strong>Initial routes</strong></p>\n<ul>\n<li>A random generation of cities would not be an optimal initial population.</li>\n<li>Some form of optimization of the initial population could be done.</li>\n<li>A scale map of the cities could be created and people attempt an optimal route by drawing the path between.</li>\n<li>These human attempts at the optimal solution could be used for the initial population.</li>\n<li>Along with some random routes to ensure variation.</li>\n</ul>\n<p><strong>Mutation rate</strong></p>\n<ul>\n<li>Typical mutation rate is around 1%.</li>\n<li>A higher value will result in a more random population.</li>\n<li>Too high and the population will not evolve towards a near-optimal solution.</li>\n<li>Too low and there may not be enough diversity in the population to find a near-optimal solution.</li>\n<li>Mutation allows you to escape from local minima optimisation.</li>\n</ul>\n<p><strong>Stopping criterion</strong></p>\n<ul>\n<li>A set number of iterations (generations). This could be based on run for 100 iterations or run for a set period of time. This solution would rely on chance for estimating the number of iterations required to ensure convergence.</li>\n<li>A set number of iterations (generations) when the best route does not change. For example, if after 100 generations the value doesn’t change for another 30 generations (i.e., 30%) then the algorithm stops. This would increase the likelihood of convergence.</li>\n<li>Set a target distance for the route and run the algorithm until that distance is reached.</li>\n</ul>\n<p><strong>Conclusion</strong></p>\n<ul>\n<li>A final measured conclusion is included in which the candidate links together the various points in evaluating the probability of success.</li>\n</ul>\n<p><em>Please see markband</em>.</p>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.3.HL.TZ0.4",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The names of vegetables must be always held in <strong>alphabetical</strong> order in a list in the main memory.</p>\n<p>The application program should allow insertion and deletion of the names of vegetables from this list.</p>\n</div><div class=\"specification\">\n<p>Given the following vegetables: potato, asparagus, lettuce, radish.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare the use of a dynamic linked list for holding these names of vegetables with a static one-dimensional array.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Sketch a single linked list holding these vegetables.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>List the steps required to insert cabbage into the linked list.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why deleting the first node in this list is different to deleting other nodes.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the dynamic data structure suitable for maintaining this list of vegetables which will allow faster searching for a given vegetable name.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The vegetable names are input in the following order</p>\n<p style=\"text-align:center;\">potato, asparagus, lettuce, radish.</p>\n<p>Sketch the data structure suggested in part (d) containing the vegetable names sorted in <strong>alphabetical</strong> order.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each comparison, up to <strong>[3 max]</strong></em>.</p>\n<p>The size of the dynamic list does not have to be predetermined as in an array;<br/>The size of the dynamic list is not fixed whilst the size of an array is always fixed;<br/>If names are sorted they can be added/deleted (more easily) by changing the pointers without having to shuffle the names;<br/>As records can be dynamically added/deleted the memory is better used because there are no wasted / missing spaces as in an array;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for a node containing two fields / data(name) and link (pointer) to the next node and <strong>[1]</strong> for showing an external pointer pointing to the first vegetable on the list, and null pointer in the last node, and pointers which link the nodes in alphabetical order up to <strong>[2 max]</strong></em>.</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each step identified up to <strong>[4 max]</strong></em>.</p>\n<p>Create a new node containing cabbage;<br/>Traverse the list (from the beginning) to find the place to insert a new node;<br/>Cabbage should be inserted before lettuce and after asparagus;<br/>The pointer in new (cabbage) node should be set to point to the node that is before the insertion point / lettuce;<br/>The pointer in node before insertion point / asparagus / should now point to the new node / cabbage;</p>\n<p><em><strong>Note</strong>: award marks for clearly labelled diagrams in candidates’ answers</em>.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying a reason why deleting the first node is different to deleting other nodes and <strong>[1]</strong> for an expansion up to <strong>[2 max]</strong></em>.</p>\n<p>External pointer (First) must be changed/only in situation when deleting the beginning node the external pointer must be changed;<br/>And set to the pointer in the link field of the first node (Asparagus) which points to the second node/Lettuce;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.</p>\n<p>Binary tree;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for clearly a binary tree and the root is Potato.</em><br/><em>Award <strong>[1]</strong> for the correct left subtree.</em><br/><em>Award <strong>[1]</strong> for the correct right subtree.</em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18N.1.HL.TZ0.11",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The following method, <code>swap(A,B)</code> is written to exchange the values of variables A and B.</p>\n<pre>swap(A,B)<br/> TEMP = A<br/> B = TEMP<br/> A = B<br/>end swap</pre>\n</div><div class=\"specification\">\n<p>Method <code>swapRows(MAT,K,L)</code> swaps the elements of two rows (row <code>K</code> and row <code>L</code>) in the two‑dimensional array <code>MAT</code>.</p>\n<p>For example,</p>\n<p><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>A game consists of four rounds. In each round a player can score up to 100 points.</p>\n<p>The data about the game is sorted in alphabetical order of names and stored in the memory as follows</p>\n<p><img src=\"\"/></p>\n<p>Where<br/><code>PLAYERS</code> is a one-dimensional array holding names of players (currently sorted in alphabetical order).<br/><code>ROUNDS</code> is a two-dimensional array holding players’ scores.<br/><code>TOTALS</code> is a one-dimensional array holding total scores.</p>\n<p>For example,<br/><code>PLAYER[1]</code> is Boris. The total number of points he scored is 180 and this can be found in <code>TOTALS[1]</code>.<br/>Boris scored 40 points in the first round which can be found in <code>ROUNDS[1][0]</code>.<br/>The value stored in <code>ROUNDS[1][2]</code> is 50 which means that Boris scored 50 points in the third round.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State Paul’s total score. </p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State where Hugh’s score in the fourth round can be found. </p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>All the data stored in memory should be sorted in ascending order of total score using selection sort.</p>\n<p>For example, after sorting, the data given opposite will be held in memory as follows</p>\n<p><img src=\"\"/></p>\n<p>Construct an algorithm that will sort all the data in ascending order.</p>\n<p>In your solution you should call methods <code>swap()</code> and <code>swapRows()</code> given in part (a) and part (b).</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.</p>\n<p>105;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.</p>\n<p><code>ROUNDS[2][3]</code>;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for the correct outer loop (loops through the array <code>TOTALS</code>)</em>.<br/><em>Award <strong>[2 max]</strong> for correct determination of <code>MINIM</code> / the position of smallest element in part of array <code>TOTALS</code> (range should be from J + 1 to 5), <strong>[1]</strong> for minor error</em>.<br/><em>Award <strong>[1]</strong> for correct condition / to check whether swaps are needed or not</em>.<br/><em>Award <strong>[1]</strong> for correct swap of elements in array <code>TOTALS</code></em>.<br/><em>Award <strong>[1]</strong> for correct swap of elements in array <code>PLAYERS</code></em>.<br/><em>Award <strong>[1]</strong> for correct swap of rows in two-dimensional array <code>ROUNDS</code></em>.</p>\n<p><em>Example answer</em>:</p>\n<pre>loop for J from 0 to 5<br/> MINIM = J<br/> loop for I from J + 1 to 5<br/> if TOTALS[I] < TOTALS[MINIM]:<br/> MINIM = I<br/> end if<br/> end loop<br/> if MINIM != J<br/> swap(TOTALS[MINIM],TOTALS[J])<br/> swap(PLAYERS[MINIM], PLAYERS [J])<br/> swapRows(ROUNDS, MINIM, J)<br/> end if<br/>end loop</pre>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.1.HL.TZ0.12",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A business has a range of different computers within the organization, including laptops, desktops and file servers. Wherever possible the organization uses a common operating system on its computers.</p>\n</div><div class=\"specification\">\n<p>Memory requirements and processor speed will vary depending on the tasks required of the computer.</p>\n</div><div class=\"specification\">\n<p>The business has decided to implement a computer-based system to switch the room lights on and off automatically. The lights will only be switched on if the level of light is below a specific reading and there are people in the room. The lights will be switched off when the room has been unoccupied for at least five minutes.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> resource management techniques that are likely to be carried out by the operating system of a desktop computer.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> way the operating system hides the complexity of the hardware from the computer user.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Contrast the memory requirements of a laptop computer and a file server.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Contrast the processor speed requirements of a laptop computer and a file server.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>two</strong> types of sensor that are required to control the lighting to ensure it switches on when it is required.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the system makes use of the data it receives from the sensors to determine when to switch the lights on.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how the system will prevent the lights from being switched off too quickly when it thinks the room is unoccupied.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em> </p>\n<p>Virtual memory;<br/>to enable the hard drive to act as primary memory if required;</p>\n<p>Paging;<br/>scheme by which a computer stores and retrieves data from secondary storage for use in main memory;</p>\n<p>Multitasking;<br/>to enable more than one application to run at the same time;</p>\n<p>Scheduling (method by which work is assigned to resources that complete the work);<br/>to determine which process will own CPU for execution while another process is on hold.;</p>\n<p>Policies (ways to choose which activities to perform);<br/>according to which decisions are made about which operations should be authorized/ which resources should be allocated;</p>\n<p>Interrupt handling;<br/>so that urgent tasks required by parts of the system may be executed;</p>\n<p>Polling;<br/>to sampling the status of an external device;</p>\n<p><em>Mark as 2 and 2</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em> <br/><em>Award 1 mark for the virtual machine (presented by the OS to the user, hiding all the complexities of the hardware behind layers of OS software) and 1 mark for an expansion</em>.</p>\n<p>The virtualization of real devices;<br/>such as the use of drive letters for partitions to represent a virtual hard drive;</p>\n<p>Use of icons;<br/>to represent peripherals/to access different drives; </p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em> <br/>The primary memory/secondary memory in a laptop will be less / smaller than would be found on a file server;<br/>because it is a smaller device that is used by an individual, so doesn’t need to store / run so many programmes simultaneously;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em> <br/>The processor of a file server would be faster/have more cores than that of a laptop;<br/>as it has many more resources to manage/as it needs to keep track of many workstations/printers/peripherals;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em> <br/>Light sensor;<br/>infra-red/motion sensor;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em> <br/>The sensors send data to the processor continuously;<br/>The data received from the sensors is converted to digital (using an analogue to digital convertor);<br/>The readings are compared to pre-set values in the controller/system;<br/>If the light level is found to be below the pre-set value <span style=\"text-decoration:underline;\"><strong>and</strong></span> a presence is detected (in the room);<br/>A signal is sent to the actuator to turn on the lights;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em> <br/>A timer (set to 5 minutes);<br/>If the light level is found to be below the pre-set value a timer is activated but the lights remain on;<br/>When the timer reaches 5 minutes, the lights switch off (if no further presence is detected);</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question was answered well by many students. Part (a) was reasonably well answered with many gaining at least two of the marking points.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Part (b) was well answered.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Students generally have problems with compare/contrast questions, describing the requirements individually without contrasting, as was the case in Part(c).</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Students generally have problems with compare/contrast questions, describing the requirements individually without contrasting, as was the case in Part(c).</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A large number of candidates scored full or nearly full marks for the questions (d)</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A large number of candidates scored full or nearly full marks for the questions (e)</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A large number of candidates scored full or nearly full marks for the questions (f)</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "21M.1.HL.TZ0.15",
|
||
"topics": [
|
||
"topic-6-resource-management",
|
||
"topic-7-control"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management",
|
||
"topic-7-1-control"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline <strong>one</strong> usability issue of a cell phone (mobile phone).</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Screen size/ larger screen;<br/>Easier to view large amounts of data without excessive scrolling / reduced eyestrain / more accessible to those with weak eyesight;</p>\n<p>Screen size/smaller screen;<br/>Difficult to accurately select the correct character on the virtual keyboard;</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.1",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> fundamental operation of a computer.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between fundamental and compound operations of a computer.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>Retrieve;<br/>Compare;<br/>Store;<br/>Add;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Fundamental operation requires one machine instruction cycle/do not require the processor to go through many machine instruction cycles to reach a result;<br/>A compound operation is complex / it is an operation that involves a number of other operations to reach the result;<br/>For example, find the largest number in an array/ sort the array in ascending order etc.;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were generally able to identify a fundamental operation of a computer, such as retrieve, compare, store or add.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were generally able to describe correctly the meaning of complex operations of a computer but were less clear in their descriptions of fundamental operations, so as to distinguish the two terms.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.1",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>State <strong>two</strong> differences between primary storage and secondary storage.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Primary storage is accessed by a computer's central processing unit (CPU) and secondary storage is not accessed directly by the CPU;<br/>Primary storage has lower access time / has smaller capacity/ more expensive type of memory than secondary storage (which is slower than primary storage, with larger capacity but it is cheaper);<br/>Primary storage is volatile (uses random-access memory (RAM), cache memory, or some other specialized hardware to store data while the computer is powered on/ volatile devices), whilst secondary storage on a computer is provided by non-volatile devices (such as SSD or HDD);<br/>Primary storage holds data temporarily whilst data is kept permanently/ for a long time in secondary storage;<br/>Primary storage holds currently running programs/data/operating system, secondary storage does not.</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.2",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A new computerized system is being planned for a school library.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>one</strong> method by which systems requirements can be obtained from the stakeholders.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> reason for providing a prototype for this new system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2]</strong> for one method that is suitable for the given scenario</em>.</p>\n<p>Answers may include:<br/><span style=\"text-decoration:underline;\">Interviews</span> could be held (with the <span style=\"text-decoration:underline;\">librarian/stakeholders</span>);<br/>To establish the functions required by the system;</p>\n<p><span style=\"text-decoration:underline;\">Direct observation</span> could be made of the users/<span style=\"text-decoration:underline;\">students</span> using the present system;<br/>To gain an insight on how the library is being used;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Allows stakeholders to gain an idea of how the system would be/work/look;<br/>so they can provide feedback / suggest improvements;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.1",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A parasite is destroying olive trees in a region in southern Europe. This area is monitored by taking aerial digital images at midday each day. A neural network is then used in the analysis of these images.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Genetic algorithms follow an iterative process in developing a solution to a problem.</p>\n<p>Outline the steps involved in this iterative process.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why neural networks need to be trained before they can be used in this analysis.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why supervised learning may be preferred to unsupervised learning for training these networks to make predictions on the progress of this parasitic disease.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Many companies now use an automated response system when answering basic telephone queries from customers. This system uses speech analysis together with recorded messages.</p>\n<p>Explain why the content of the messages given by these systems must be carefully chosen.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The initial population set is chosen randomly/pseudo randomly;<br/>A fitness function is applied to each population;<br/>The fittest members are selected for the next stage;<br/>Genetic operators are applied;<br/>Such as crossover / mutation;<br/>The process is repeated until;<br/>An acceptable level of fitness is found / a plateau is reached / a maximum number of iterations has been reached;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Network networks initially have a randomly chosen set of weights;<br/>Which will not solve any problem;<br/>These weights must be altered;<br/>Until they fulfil their objective;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6 max]</strong></em>.<br/><em>Award <strong>[3 max]</strong> for considerations linked to each of the two forms of learning</em>.<br/>With supervized learning the processing of the image is guided (supervised) by the output dataset to the purpose of classifying certain features of the image;<br/>For example, to the value of the pixel (grey or colour) one can assign likelihood of belonging to neighbouring values of greys/colours;<br/>And this can be defined in advance as a way to represent a potential value for an infected tree;</p>\n<p>However, with unsupervised learning the processing of the image is not guided in any way / the output is not known;<br/>And the purpose is to discover and build clusters that have common characteristics;<br/>Therefore, this may clearly help in building up the main regions, but not specifically on focussing on the infected trees;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/>Questions/requests must be short so repetition is not required / so they are immediately understood;<br/>And chosen so that there is a restricted response set;<br/>That can be recognised by the system / that can be stored by the system;<br/>The requests must lead to a satisfactory end;<br/>Or customers will get frustrated / hang up / the company will lose business etc.;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "18N.2.HL.TZ0.8",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline why computers use the binary number system.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>because the binary system uses only two digits (0 and 1);<br/>and computer uses bi-stable devices / devices that can be either in one of the two possible states(such as pulse or no pulse, on or off, 0 or 1, true or false) /;</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.3",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> cause of data loss.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>one</strong> way offsite storage can be used to prevent data loss.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>Any malicious activity;<br/>Natural disasters;<br/>Human error;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Internet backup service could automatically back up (all important) data files;<br/>to a remote server that could be accessed/controlled over the internet;</p>\n<p>Copies of all important data files (backup) could be placed on two separate hardware devices;<br/>which are placed in two different physical locations;</p>\n<p>A remote file server could be set up;<br/>for uploading all important data files;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates identified a relevant cause of data loss, such as malicious activity, natural disasters or human error.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were generally able to identify appropriate methods of offsite data storage, but clear descriptions of how these could be used to prevent data loss were less common, with answers simply describing the method rather than how it could prevent data loss.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.2",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Explain why compression of data is beneficial when transmitting data files across a network.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em></p>\n<p>Compressing a data file reduces the file size;<br/>The amount of time it takes to send a file over the network depends on the size of the transmitted file, so the amount of time needed to transmit the file is reduced /transmission of a compressed file takes less time than transmission of that same uncompressed file;<br/>Also, compression of data files before transmission reduces the financial cost of running a network/ less equipment / bandwidth is needed to transmit the data file;</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.4",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline the role of the memory data register in the machine execution cycle.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>Holds (a copy of) the contents of the memory;<br/>Which are to be transferred from/to memory to/from other CPU components;<br/>Allowing the processor and memory to act independently/processor not affected by differences in the speed of operation;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.2",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A group of programmers are involved in creating a new software product. They create many new sub-programs but also use existing sub-programs within the product.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why a sub-program is considered an example of abstraction.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the use of designing and developing different parts of software products concurrently.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> way in which users can be informed of software updates.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em></p>\n<p>A sub-program is a named section of code that performs a specific task (in a program) / can be called by name / referred by the identifier when needed;<br/>without knowing the details (of code and data structures) as these are wrapped / hidden within the sub-program;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em></p>\n<p>different stages (of programming) (<em>Accept examples!</em>) run simultaneously (rather than consecutively);<br/>this decreases product development time / decreases the time to market;<br/>leading to improved productivity/reduces costs;<br/>however, it requires more resources/more software developers;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em></p>\n<p>A message can be sent to the user (When the software is installed and registered, the user provides an email address / phone number);<br/>With a link to the update;</p>\n<p>notifications/alerts are sent to the computer (a cookie is placed on the user's computer which communicates with the software developer);<br/>about automatic updates;</p>\n<p>(when the program is run) it queries a URL the program developer has built in to check whether the current version matches the latest version;<br/>if not, notifications/alerts are sent;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.5",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the function of the control unit (CU) in the central processing unit (CPU).</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the purpose of cache memory.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>It decodes the instructions and controls all the other internal components of the CPU to make it work;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Cache memory is a memory that a computer microprocessor can access more quickly than it can access regular RAM;<br/>It is integrated directly with the CPU chip or placed on a separate chip which has a separate bus interconnect with the CPU;<br/>and stores frequently used data only until a computer is powered down;<br/>Thus, when a processor requests data that already has an instance in the cache memory; it does not need to go to the main memory or the hard disk to fetch the data;</p>\n<p>Cache memory is a small-sized type of volatile computer memory;<br/>that provides high-speed data access to a processor;<br/>and stores frequently used computer programs, applications and data;<br/>Cache memory can be primary or secondary cache memory, where primary cache memory is directly integrated to the processor;<br/>And secondary cache memory is a reserved portion on a disk stores and provide access to frequently accessed data/applications from the disk.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally provided appropriate statements to illustrate their understanding of the function of the control unit in the CPU.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question was generally well answered with many full or nearly full marks answers seen. Candidates demonstrated a good understanding of the purpose of cache memory.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.3",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how data is sorted by the selection sort.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> difference between a bubble sort algorithm and a selection sort algorithm.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/>The selection sort algorithm maintains two subarrays of a given array, the subarray which holds already sorted elements;<br/>And the subarray which is unsorted;<br/>In every iteration, the minimum element (considering ascending order OR maximum element considering descending order) from the unsorted subarray is found/selected;<br/>And then swapped with the item in the next position (at the appropriate place / in the last position) to be filled in the sorted subarray;</p>\n<p><em><strong>OR</strong></em></p>\n<p>The selection sort algorithm searches through the entire array for the smallest (considering ascending order OR the largest element considering descending order) element;<br/>When found, it (the smallest/largest element) is swapped with the first element of the array;<br/>Then searches for the smallest / largest element in the <strong>remaining</strong> array (an array without the first element) and swap it with the second element;<br/>This process <strong>repeats</strong> on the remaining items (searches for the smallest / largest element in the remaining array (an array without first and second elements)) and swap it with the third element, and so on);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em></p>\n<p>Bubble sort swaps adjacent items;<br/>selection sort finds the next smallest (each time it goes through the list);</p>\n<p>Bubble sort can exit early/ is faster if already the list is sorted;<br/>selection sort will need to complete the procedure for the entire list every time;</p>\n<p>(The efficiency of Bubble and selection sort is different when applied on <strong>already sorted</strong> list) in the best-case bubble sort takes an order of N time;<br/>whereas selection sort consumes an order of N<sup>2</sup> time (where N is the number of items on the list));</p>\n<p><em><strong>Note</strong>: To award marks for such an answer it should be evident that the list is already sorted OR the term 'the best-case' should appear because the worst-case /average-case complexity/efficiency is same in both algorithms (O(N<sup>2</sup>))</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.6",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Calculate how many different colours can be represented using two hexadecimal characters.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>2 hex = 4 + 4 = 8 bits;<br/>hence 2^8/16^2/256 colours;<br/><em><strong>Note</strong>: Allow <strong>[2]</strong> for 16^2 = 256 colours with no workings and also ONLY 256</em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.3",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Tapetum lucidum</em> refers to the layer of tissue in the eyes of many animals, such as cats and owls, which helps to improve their night vision by reflecting light. The eyes of these animals glow in the dark.</p>\n<p>A student wishes to identify a particular animal which belongs to the above group.</p>\n</div><div class=\"specification\">\n<p>The web and social media are increasingly populated by pictures of pets and other animals. Most of these pictures are annotated with tags, such as those used on social networks.</p>\n</div><div class=\"specification\">\n<p>Search engines use indexing for the storing of keywords that might be used in a search engine query.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With the use of an example, explain how a multimedia search in the semantic web would be preferable to a text based search for this student.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> differences between an ontology and a folksonomy.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Discuss whether it is possible to integrate the expressivity of folksonomies with the authoritativeness of ontologies.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the role that web crawlers perform in developing this index.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Open source software, such as Linux, is often developed by using the collective intelligence of the developer community.</p>\n<p>Explain how collective intelligence can lead to the successful development of open source software.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[2 max]</strong> for a general knowledge and understanding of multimedia web.</em><br/><em>Award <strong>[2 max]</strong> for describing a situation where the multimedia web may be beneficial to using a text based search</em>.</p>\n<p><strong>Knowledge of multimedia web</strong><br/>The multimedia web makes an expanded use of the semantic web (formally and semantically interlinked data of any kind) making possible to provide input in a form other than text, and possibly return output in various forms;<br/>Therefore, the search is made at the level of “concepts” and not just textual terms;<br/>In a way that the computer can retrieve semantical links among different concepts/concepts presented in different formats;<br/>That includes the ability for crawlers to go through scientific classifications of text/captions/description of images;<br/>That can all be indexed and clustered into a common “concept”;</p>\n<p><em><strong>Example 1</strong></em>:<br/><em>To detect/discover/verify/monitor the presence of species based on sound</em><br/><em>For example</em>:<br/>We might aim in recognising and searching on the web starting from the sound of some nocturnal animal that we don’t see/we don’t know, but whose presence is revealed by their eyes;<br/>Giving the sound as input would allow to perform a search based on registration/audio that would run on multimedia sources linked with semantical links;</p>\n<p><em><strong>Example 2</strong></em>:<br/><em>To detect/discover/verify/monitor the presence of species based on images</em><br/><em>For example</em>:<br/>We might start a multimedia search based on images/photos of nocturnal animals we may have taken;<br/>To see whether those sightings were associated to dangerous species or not;<br/>To signal the presence of some unusual species in the region;<br/>To signal the presence of some animal in difficulty to the protection agency;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each difference up to <strong>[3 max]</strong></em>.<br/>Designed or extracted by knowledge engineers VS;<br/>Created collaboratively by users;<br/>Laborious and expert VS quick/easy non-expert;<br/>Controlled vocabulary/dictionary VS no control of vocabulary/informal;<br/>Formal specification of knowledge domain (taxonomies) VS;<br/>Informal metadata on documents;<br/>Not just for the web VS mostly for the web;<br/>Essential for the semantic web VS important for social web;<br/>Explicit meaning and high expressive power VS;<br/>Ambiguity and low expressive power;<br/>Experts’ view of the domain VS social aspect of meaning;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6 max]</strong></em>.<br/><em>Award <strong>[2 max]</strong> for a superficial response that uses generic terminology.</em><br/><em>Award <strong>[4 max]</strong> for a response that shows some analytical comments, unsubstantiated conclusions and some use of appropriate terminology.</em><br/><em>Award <strong>[6 max]</strong> for a coherent analysis leading to substantiated conclusions with the appropriate use of subject specific terminology.</em><br/><strong>General, possibly described through examples</strong><br/>The ontology of the semantics web is extracted with expert means from documents;<br/>(For example, by making features analysis / aggregating concepts / eliminating disambiguation;)</p>\n<p>Whereas, the folksonomy is the result of adding different vocabulary (done by the users) via tags in posts/web pages/social web (like <em>Tumblr</em>);<br/>(For example, tagging the photo of a cat under an informal “cat’s eye” would add a different perspective to the ontology);</p>\n<p><strong>The problem</strong>:<br/>If not monitored, tagging may be source of “garbage” and hinder the research for the ontology;<br/>The ambiguity problem of tagging needs to be addressed so to extract a weight to ambiguous use of tags;</p>\n<p><strong>Possible countermeasures</strong>:<br/><span style=\"text-decoration:underline;\">Expand the query within social tagging platforms</span>;<br/>In order to extract a weight to ambiguous use of tags and use this weight to cut-out some irrelevant retrieved information;</p>\n<p><strong>OR</strong><br/>Use the <span style=\"text-decoration:underline;\">folksonomy tags</span> (at least some) <span style=\"text-decoration:underline;\">to update</span> (possibly as metadata) <span style=\"text-decoration:underline;\">the ontology vocabulary</span>;<br/>However, depending on the context, this may not always be feasible/applicable and depends on the domain of discourse;</p>\n<p><strong>OR</strong><br/><span style=\"text-decoration:underline;\">Re-engineer the ontology to include</span> a collaborative form of construction from tagging;<br/>However, this is method is not applicable in expert fields where quality of content must be preserved;</p>\n<p><strong>OR</strong><br/>Keep <span style=\"text-decoration:underline;\">the ontology and folksonomy well separated</span>, but let them work in tandem;<br/>In a way to have feedback from folksonomies, but merged in a controlled way;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each comment that indicates the role that web crawlers perform in developing an index that is used by a search engine up to <strong>[4 max]</strong></em>.<br/>A web crawler is given a “seed” page which is where it starts;<br/>It searches for hyperlinks;<br/>Which it recursively follows;<br/>Making a copy of each web page visited;<br/>Which can be indexed by the search engine;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/><em>Award <strong>[1]</strong> some example to fix the scenario of open source;</em><br/><em>Award <strong>[1]</strong> what is meant by collective intelligence;</em><br/><em>Award <strong>[1]</strong> some explanation/expansion to link the concepts;</em></p>\n<p><strong>The focus</strong>:<br/>“Software for Public Interest”;</p>\n<p>Open source and free software development is the result of initiatives taken by <span style=\"text-decoration:underline;\">sparse communities of programmers</span> that <span style=\"text-decoration:underline;\">collaborate</span> effectively to maintain complex programs/packages of code;</p>\n<p>(For example, Debian Foundation, Linux Foundation, Mozilla Foundation, Apache Foundation, Free Software Foundation, Wikipedia…;)</p>\n<p><strong>The structure</strong>:<br/><span style=\"text-decoration:underline;\">A distributed system of development</span> AND <span style=\"text-decoration:underline;\">tightly governed</span> /<br/>Each developer codes individually, but the whole project relies on the fact that portions of code may be integrated as components of other parts;</p>\n<p>Organisations may have different modes of governance, and have precise ways (processes) to contribute to a project, both technical and social;</p>\n<p>The objective is to guarantee coordination, quality and relevance for the project development (technical) based on contributions of the individuals;<br/>While modulating possible clashes/conflicts between different personalities;</p>\n<p><strong>Examples</strong>:<br/>OS kernels, Wikipedia, mail programs, GNU, …;<br/>Build a deposit of old software (free/open source), for preservation and sharing (with everybody);<br/>Old open source SW may in fact be at risk of not being publicly available for a variety of reasons, such as sites become proprietary and limit public access, crash of the systems, business decisions;</p>\n<p><strong>Role of collective intelligence</strong><br/>Individuals are expert developers, but act collectively, for public interest, and this becomes a movement that may make a cultural/political difference/impact (the key is high quality, not populism!);<br/>e.g. the French Public Administration adopts Open Source software and has rejected proprietary products (Microsoft, specifically)</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18N.2.HL.TZ0.12",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-6-the-intelligent-web",
|
||
"c-5-analysing-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Explain the importance of the memory management function of an operating system.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3]</strong> as follows</em>:<br/>The function of the memory management <strong>[1]</strong>.<br/>An example if its use <strong>[1]</strong>.<br/>Reason for the importance <strong>[1]</strong>.</p>\n<p><em><span style=\"text-decoration:underline;\">Example</span></em>:<br/><em>Allocates and de-allocates memory/ assigns blocks of memory to programs;</em><br/><em>Ensures a program has sufficient memory to run/manages virtual memory if needed;</em><br/><em>To avoid overwriting /clashing of programs/optimise system performance/maximise memory usage</em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.4",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A network is set up with shared printers so that when a user wishes to print, print jobs are sent to a queue until the printer is available.</p>\n</div><div class=\"specification\">\n<p>The <em>factorial</em> of the positive integer <em>n</em>, which is written <em>n</em>!, is the product of all the positive integers less than or equal to <em>n</em>. A stack may be used to perform a factorial calculation as shown by the algorithm:</p>\n<pre>//stack for factorial(NUM)<br/>//creates a stack of (NUM - 1) elements<br/>//when NUM = 6<br/>NUM = 6<br/>loop while NUM > 1<br/> stack.push(NUM)<br/> NUM = NUM – 1<br/>end loop<br/>PRODUCT = 1<br/>loop while not stack.isEmpty()<br/> NUM = stack.pop()<br/> PRODUCT = PRODUCT * NUM<br/>end loop<br/>output PRODUCT</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why a queue is the appropriate data structure to manage print jobs.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Draw a diagram to show how a print queue may be implemented using a linked list.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why a stack would not be appropriate as a data structure for managing print jobs.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the trace table for the algorithm shown for <code>NUM = 6</code>.</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how a stack may be used in the implementation of a recursive function.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em> <br/>Print jobs are to be completed in the order received;<br/>Queue is appropriate because print jobs are added/enqueued at the back/rear and dequeued/removed from the front / because queue is a FIFO data structure;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em> </p>\n<p>Correct use of pointers and null pointer in the last node;<br/>External pointer to the beginning of the list (head);<br/>External pointer to the end of the list (tail);<br/>Each node consists of at least 2 parts/fields: data (print jobs) and pointer;</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em> <br/>Print jobs would not be managed in an orderly manner;<br/>Because stack is LIFO data structure / elements are added/pushed and removed/popped at only one end;<br/>And each time another one is added it takes precedence over those that are already in the data structure; </p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em></p>\n<p>NUM column correct;<br/>PRODUCT column correct;<br/>OUTPUT column correct;</p>\n<p><em><strong>Note</strong>: The trace table may be differently presented</em>. </p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em></p>\n<p>A recursive function calls itself during its execution;<br/>First call (all local variables, data, return addresses, etc.) is pushed onto stack;<br/>Second/subsequent recursive calls are pushed on to the stack (added above previous call(s));<br/>When the terminating condition is met/ execution of recursive function ends;<br/>The function calls pop from the stack;<br/>In the reverse order to which they were pushed/LIFO;</p>\n<p> </p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21M.1.HL.TZ0.16",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Assume X = 5 and Y = 3.</p>\n<p>Determine the value of the following expression:</p>\n<p style=\"text-align:center;\"><math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mo>(</mo><mi mathvariant=\"normal\">X</mi><mo> </mo><mo><</mo><mo>=</mo><mo> </mo><mn>5</mn><mo>)</mo><mo> </mo><mi>XOR</mi><mo> </mo><mo>(</mo><mi mathvariant=\"normal\">Y</mi><mo> </mo><mo>></mo><mo> </mo><mi mathvariant=\"normal\">X</mi><mo>)</mo></math></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1 max] <br/></strong></em><math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mo>(</mo><mn>5</mn><mo><</mo><mo>=</mo><mn>5</mn><mo>)</mo><mo> </mo><mi mathvariant=\"bold\">XOR</mi><mo> </mo><mo>(</mo><mn>3</mn><mo>></mo><mn>5</mn><mo>)</mo><mo> </mo><mo>(</mo><mo>=</mo><mo> </mo><mi>TRUE</mi><mo> </mo><mi mathvariant=\"bold\">XOR</mi><mo> </mo><mi>FALSE</mi><mo> </mo><mo>)</mo><mo> </mo><mo>=</mo><mo> </mo><mi>TRUE</mi><mo>;</mo></math> </p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.7",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> essential features of a computer language. </p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Fixed vocabulary;<br/>Unambiguous meaning;<br/>Consistent grammar;<br/>Consistent syntax;<br/>Provide a way to define basic data types and operations on those types (ability to write functions/procedures);<br/>Provide ability of Input and output handling;<br/>Provide some kind of loop that can be stopped / conditional statement / branching (conditional and unconditional branching);<br/>It should have variables that reference computer memory, syntax for basic arithmetic and logical;<br/>Operations on those memory locations;<br/>It has to run on/be able to be processed by a computer (i.e. it must have a compiler/interpreter)</p>\n<p><em><strong>Note</strong></em>: do not accept aspects that address interoperability/portability/standards/user friendliness</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.1",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct a logic diagram for the following Boolean expression.</p>\n<p style=\"padding-left:270px;\"><math style=\"font-family:Arial;\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mstyle mathsize=\"12px\"><mi>NOT</mi></mstyle></math> <math style=\"font-family:Arial;\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi mathvariant=\"normal\">A</mi></math> <math style=\"font-family:Arial;\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mstyle mathsize=\"12px\"><mi>OR</mi><mo> </mo><mo> </mo><mo> </mo><mo>(</mo></mstyle></math><math style=\"font-family:Arial;\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi mathvariant=\"normal\">A</mi></math> <math style=\"font-family:Arial;\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mstyle mathsize=\"12px\"><mi>AND</mi></mstyle></math> <math style=\"font-family:Arial;\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi mathvariant=\"normal\">B</mi></math><math style=\"font-family:Arial;\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mstyle mathsize=\"12px\"><mo>)</mo></mstyle></math></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3]</strong> as follows</em>:<br/>Clearly a logic diagram with 2 inputs, 1 output and 3 logic gates <strong>[1]</strong>;<br/>OR gate has two inputs one of which is NOT A <strong>[1]</strong> and the other is A AND B <strong>[1]</strong></p>\n<p><strong><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></strong></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.5",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Colours are represented by a computer as a combination of the three primary colours: red, green and blue.</p>\n<p>Numerical values are used to represent the different shades of each primary colour. These values range from 0 to 255 in decimal, or 00 to FF in hexadecimal.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State why hexadecimal numbers are frequently used in computing.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the number of bits used to represent a non-primary colour, such as yellow.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the maximum number of colours that can be represented in a computer pixel.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>Hexadecimal numbers are used for shorter representation of data because a (modern) byte can be represented exactly by two hexadecimal digits;<br/>Hexadecimal numbers are used for shorter representation of data, because computers store and handle binary digits, and four binary digits make one hexadecimal digit;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>24;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>256 × 256 × 256 / (2<sup>8</sup>)<sup>3</sup> / 2<sup>24</sup>;<br/>256<sup>3</sup>;<br/>16 777 216;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question required candidates to recognise that hexadecimal numbers are used for shorter representation of equivalent binary numbers, and the relationship between groups of binary digits and individual hexadecimal digits. Answers seen, were often too vague, simply stating that, for example, the numbers are easier to use.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question required candidates to realise that non-primary colours are stored as a combination of the three primary colours red, green and blue. 8 bits are required for each of these, making 24 bits necessary to store each non-primary colour. Many answers seen incorrectly gave 8 bits as the requirement.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>As with part b, candidates were expected to recognise that each computer pixel would be made up from a combination of each of the three primary colours, with one byte, 8 bits, or 2<sup>8</sup> = 256 combinations for each primary colour. The answer would therefore be 256 × 256 × 256, or 16 777 216 combinations. Many answers seen incorrectly gave 256 combinations.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.4",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct a trace table for the following algorithm:</p>\n<pre>I = 0<br/>loop while 6 > I<br/> K = K + I<br/> I = I + 2<br/>end loop<br/>output(K)</pre>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max] </strong></em></p>\n<p><em><strong>Award</strong> <strong>[1]</strong> for correct values in column <code>I</code></em><br/><em><strong>Award [1]</strong> for correct values in column <code>K</code></em><br/><em><strong>Award [1]</strong> for correct output</em><br/><em><strong>Note</strong>: Column </em><code>6 > I</code><em> </em>may not appear in the trace table.</p>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.8",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> characteristics of a data packet.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>It contains a set amount of data;<br/>It contains a fixed structure (or identify elements of the structure other than data);<br/>It contains data that is to be sent via a communications channel;<br/>It contains specific details for transmission e.g. address of sender and receiver, error codes etc.;</p>\n<p><em>Award 2 marks if <strong>two</strong> of the contents of a packet are given and expanded</em>.</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.6",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Two fundamental operations of a computer are <em>add</em> and <em>retrieve</em>. State another <strong>two</strong> fundamental operations.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>Compare (<em>accept</em> Check);<br/>Store (<em>accept</em> Write / Save);</p>\n<p><em><strong>Note</strong></em>: Accept the following wording for categories of operations<br/>Input (Read);<br/>Processing/execution (e.g. calculate, decode, fetch, delete, evaluate, sort, transfer, transmit);<br/>Output;<br/>Control;</p>\n<p><em><strong>Remark</strong>: Beware of repetitions with the wording in the question paper, or repetitions between the two given examples. Marks should not be awarded twice in those cases.</em><br/><em>For example,</em><br/><em>Search/look up, or comparable wording, are synonyms of the given Retrieve;</em><br/><em>Insert/put, or comparable wording, are synonyms of the given Add;</em><br/><em>Lists of repeated arithmetic operations that fall under examples of calculations (subtract, divide, multiply, square) are all examples of calculations, and hence processing.</em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.2",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Explain why protocols are used in network communications.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>Protocols are a set of rules;<br/>(That are used) so that both sender and receiver are using/expecting the same formats/methods;<br/>To allow data to be transmitted <span style=\"text-decoration:underline;\">successfully / without errors</span>;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.7",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A new computer system is being developed using prototypes.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage of using surveys as a method of obtaining requirements from stakeholders.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> disadvantage of using surveys as a method of obtaining requirements from stakeholders.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> <strong>other</strong> method of obtaining requirements from stakeholders.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> advantages of using prototypes.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why more than one cycle of analysis and design might be needed.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why this computer system should be tested thoroughly before being put into operation.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em><br/>Surveys allow analysts to obtain appropriate information quickly;<br/>from a large number of persons / stakeholders;</p>\n<p>Standardized question formats are prepared;<br/>that can provide data that can be easily quantified/allow quantitative analysis (the success of a survey depends on the effectiveness of questions);</p>\n<p>The use of standardized formats;<br/>minimizes the risk if the analyst adding their opinion;</p>\n<p>Survey is a straightforward/easy/practical way of gathering data;<br/>it can be distributed using various methods (printed copies, e-mail, embedded in a website, online forms)</p>\n<p>Surveys allow greater anonymity for respondents;<br/>which can lead to more honest responses;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em></p>\n<p>Poorly designed surveys;<br/>May make it difficult to analyse the data;<br/>(Response may be limited/not all questions answered / not all forms will be returned;<br/>Can be challenging to analyse the collected data ;)</p>\n<p>Questions in the survey were not effective;<br/>Can be differences in how people understand the survey questions;<br/>Data gathered cannot be quantified;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>Direct observation;<br/>Interviewing;<br/>Focus groups;<br/>Examining existing documents/ Literature searches;<br/>Investigating previous solutions;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em><br/>The final product meets the requirements/ is more successful;<br/>as feedback is provided by the users during the development process;</p>\n<p>Costs/time saved at a later stage;<br/>as early feedback avoids later changes (which may require a considerable amount of time/cost);</p>\n<p>The best design can be decided upon early;<br/>As it allows different prototypes can be tried out/tested;</p>\n<p><em>Mark as 2 and 2</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/>Another cycle of analysis and design might be needed because the stakeholder could ask for modifications;<br/>because errors or omissions are found that need to be corrected;<br/>new/different features could be added that affect the current design;<br/>which affects the costs/ delivery time / hardware requirements/ contributes significantly to system quality and performance;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/>so that it functions the way it is supposed to / to ensure that the actual outcomes are equal to the predicted outcomes;<br/>so that it meets its design specifications functions;<br/>so that functions correctly / to eliminate any errors/bugs;<br/>so that the speed/capacity/compatibility issues are solved;<br/>so that all security features are configured and enabled;<br/>because wrong/incorrect/stolen information could have serious consequences for its customers (accept an actual consequence);<br/>because wrong information could harm the company’s reputation / loss of earnings / sued/ etc.;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.9",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>In the context of the networked world, state the role of a client.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>In the context of the networked world, state the role of a server.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>A piece of computer hardware or software that accesses a service made available by a server /<br/>The role of a client is to access a service made available by a server by sending a request for service;</p>\n<p><em><strong>Note</strong>: the term client is to be understood only from the computing perspective, i.e. this is not a human</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A program/host computer that awaits and fulfills requests from client programs (in the same or other computers) /<br/>The role of a server is to fulfill requests from client programs (which can reside in the same or in other computers)</p>\n<p><em><strong>Note</strong>: the term server is to be understood only from the computing perspective, i.e. this is not a human.</em></p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.3",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A company has a large networked computer system.</p>\n<p>Some of its data is non-sensitive data that would cause no risk to the company if accessed. Some data, however, is sensitive, such as the company’s financial records and documents that contain trade secrets and personal information about employees or clients.</p>\n</div><div class=\"specification\">\n<p>Data corruption can result in data loss.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> ways in which access to sensitive data can be managed.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> ways to improve the security of the company’s network.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how corrupted data files can be recovered.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The company is considering implementing a virtual private network (VPN).</p>\n<p>Explain one benefit to the company of using a VPN.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em></p>\n<p>Each user should have appropriate access rights;<br/>Managers, employees and clients/customers are permitted to access different parts of the data;</p>\n<p>Sensitive data can be protected by locking it with a password;<br/>preventing unauthorised access who doesn't have this;</p>\n<p>Administrator should record who has logged on and from which computer / and for how long;<br/>to discourage security violations/ to avoid undesirable events from occurring;</p>\n<p>File systems should be encrypted (as it passes throughout a network / resides on computers);<br/>to make data unusable if accessed by unauthorized user;</p>\n<p>Each computer should have access rights depending on its location;<br/>Logged in computers should not be unattended;</p>\n<p><em>Mark as 2 and 2</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em></p>\n<p>Each user should have a user ID and a personal password;<br/>Passwords should be regularly changed;</p>\n<p>Two-factor authentication for remote users and administrators could be required (this could be a digital certificate, tokens, thumbprint scanners);<br/>In addition to the usual user ID and password;</p>\n<p>In order to prevent intruders/strangers from accessing the company's network;<br/>the router is set to accept only specific MAC addresses;</p>\n<p>Regularly installing updates and patches;<br/>to ensure the network is protected against new threats such as malware;</p>\n<p><em>Mark as 2 and 2</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em><br/>Restore files from a backed-up data file;<br/>ensuring it is a recent copy to minimize loss;<br/>a parallel/failover system could be operated;<br/>that could be switched to (if the live system is corrupt);<br/>data recovery software could be (installed and) run;<br/>to repair corrupted files;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><br/>A VPN improves data security;<br/>By passing the company’s data through a hidden tunnel;<br/>And encrypting the internet traffic inside encapsulated data packets;</p>\n<p>A VPN improves the company’s productivity;<br/>as the workers will not have to be in a particular location to get to be productive;<br/>VPN is not dependent on any particular network or Wi-Fi connection to work/ can be used on any type of device;</p>\n<p>Remote access;<br/>VPNs is not dependent on any particular network or Wi-Fi connection to work;<br/>The company can have a remote workforce /employees or freelance staff working from different geographic locations/can connect their different office locations;</p>\n<p>Some databases/websites that support the company’s business operations may not be directly accessible in some countries;<br/>A VPN helps to unblock geo restricted contents / has ability to bypass geo-blocking;<br/>By hiding IP addresses / obscuring the access requests to appear to be originating from various IP address which are not in an unrestricted location;</p>\n<p>A VPN can reduce a company’s infrastructure costs;<br/>Because can be used on any type of device;<br/>So, the company can offer BYOD options to employees;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.10",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A different airport has two runways for arriving flights. Two objects of the <code>LinkedList</code> class, named <code>runway1</code> and <code>runway2</code>, are associated with these two runways.</p>\n</div><div class=\"specification\">\n<p>Arriving flights are added to a list depending on the runway they are assigned to.</p>\n<p>Both linked lists contain <code>Arrival</code> objects, corresponding to arriving flights, and are sorted by ETA.</p>\n</div><div class=\"specification\">\n<p>The following diagram represents <code>runway1</code>.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>Consider the following method.</p>\n<pre><strong>void</strong> process(LinkedList<Arrival> myList, <strong>int</strong> i)<br/>{ <strong>if</strong> (i < myList.size())<br/> { process(myList, i + 1);<br/><strong> System.out.println</strong>(myList.get(i).getETA());<br/> }<br/>}</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline an advantage of using a library.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the use of dynamic linked lists to static arrays when managing arriving airplanes.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Sketch the resulting linked list when an airplane with ID RO225, STA 12:05 and delay 0 is added to this list.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>recursion</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Trace the call <code>process(runway1,0)</code> given the diagram of <code>runway1</code> as drawn above. Copy and complete the following table.</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>In case of bad weather it is possible that one of the runways has to be closed and the two linked lists (<code>runway1</code> and <code>runway2</code>) need to be merged using a method <code>mergeLists()</code> into one new linked list <code>runway</code>.</p>\n<p>Construct the method <code>public LinkedList<Arrival> mergeLists()</code> that merges the two sorted linked lists in to one sorted linked list <code>result</code> which needs to be returned. You may assume that <code>runway1</code> and <code>runway2</code> are accessible to the method and do not need to be passed. The original two lists are allowed to become <code>null</code> as a result of the merging. </p>\n<p>In answering this question, you may use the following methods from the JETS <code>LinkedList</code> class, in addition to any method provided or developed in this exam paper.</p>\n<pre>addFirst(<object>) // adds the object at the head of the list<br/>addLast(<object>) // adds the object at the tail of the list<br/>getFirst() // returns the head object in the list<br/>getLast() // returns the tail object in the list<br/>removeFirst() // removes and returns the head object<br/>removeLast() // removes and returns the tail object<br/>size() // returns the number of objects in the list<br/>isEmpty() // returns true if the list is empty</pre>\n<div class=\"marks\">[7]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying an advantage.</em><br/><em>Award <strong>[1]</strong> for an elaboration of the advantage.</em></p>\n<p><em><strong>Example answers</strong>:<br/></em>Convenience;<br/>Because implementations of common tasks are available;<br/>Reliability;<br/>because these implementations are fully developed, functional and robust.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying an issue and <strong>[1]</strong> for a valid comparison related to the issue.</em><br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em></p>\n<p><em><strong><img src=\"\"/></strong></em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for a good attempt (for example the new node being added as the 3rdnode in the list).</em><br/><em>Award <strong>[2]</strong> for a fully correct diagram.</em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>When a method calls on itself.</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for correct recursion levels i including i = 3.</em><br/><em>Award <strong>[1]</strong> for the correct flight id's (with or without the line for i = 3.</em><br/><em>Award <strong>[1]</strong> for 12:55 and 11:05 in the correct order.</em><br/><em>Award <strong>[1]</strong> for 12:30 (ETA) in the correct order.</em><br/><em><strong>Note</strong>: that there are many ways to trace a recursive algorithm.</em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>For answers without iterators<br/><em>Award up to <strong>[7 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for correctly instantiating the <code>LinkedList </code>variable <code>result</code>.</em><br/><em>Award <strong>[1]</strong> for declaring (and instantiating) all other variables.</em><br/><em>Award <strong>[1]</strong> for correct main loop.</em><br/><em>Award <strong>[1]</strong> for correctly comparing the first Arrivals in the two lists.</em><br/><em>Award <strong>[1]</strong> for correctly removing the earlier Arrival from its original list.</em><br/><em>Award <strong>[1]</strong> for correctly adding this Arrival to the end of the resulting list.</em><br/><em>Award <strong>[1]</strong> for attempting to add the remainder of a non-empty linked list.</em><br/><em>Award <strong>[1]</strong> for correct loop for copying the remainder of <code>runway1</code>.</em><br/><em>Award <strong>[1]</strong> for correctly removing/adding the remainder of <code>runway1</code>.</em><br/><em>Award<strong> [1]</strong> for also copying a possible remainder of <code>runway2</code>.</em></p>\n<p><em><strong>Example without iterator</strong></em>:</p>\n<pre><strong>public</strong> LinkedList<Arrival> mergeLists()<br/>{<br/> LinkedList<Arrival> result = <strong>new</strong> LinkedList<Arrival>();<br/> Arrival temp = <strong>null</strong>;<br/><strong> while</strong> (!runway1.isEmpty() && !runway2.isEmpty())<br/> {<br/><strong> if</strong> (runway1.getFirst().compareWith(runway2.getFirst())<0)<br/> { temp = runway1.removeFirst(); }<br/><strong> else</strong><br/> { temp = runway2.removeFirst(); }<br/> result.addLast(temp);<br/> }<br/><strong><br/> while</strong> (!runway1.isEmpty())<br/> { temp = runway1.removeFirst();<br/> result.addLast(temp);<br/> }<br/><strong> while</strong> (!runway2.isEmpty())<br/> { temp = runway2.removeFirst();<br/> result.addLast(temp);<br/> }<br/><strong><br/> return</strong> result;<br/>}</pre>\n<p><em><strong>Alternative example without iterator</strong></em>:</p>\n<pre><strong>public</strong> LinkedList<Arrival> mergeLists()<br/>{<br/> LinkedList<Arrival> result = <strong>new</strong> LinkedList<Arrival>();<br/> Arrival head1 = runway1.peekFirst();<br/> Arrival head2 = runway2.peekFirst();<br/><strong><br/> while</strong> ((head1 != <strong>null</strong>) && (head2 != <strong>null</strong>))<br/> { <strong>if</strong> (head1.compareWith(head2) <= 0) // or <<br/> { result.addLast(head1);<br/> runway1.removeFirst();<br/> head1 = runway1.peekFirst();<br/> }<br/><strong> else</strong><br/> { result.addLast(head2);<br/> runway2.removeFirst();<br/> head2 = runway2.peekFirst();<br/> }<br/> }<br/><strong> while</strong> (!runway1.isEmpty())<br/> {<br/> result.addLast(runway1.removeFirst());<br/> }<br/><strong> while</strong> (!runway2.isEmpty())<br/> {<br/> result.addLast(runway2.removeFirst());<br/> }<br/><strong> return</strong> result;<br/>}</pre>\n<p>For answers that use iterators<br/><em>Award up to <strong>[7 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for correctly instantiating the <code>LinkedList</code> variable <code>result</code>.</em><br/><em>Award <strong>[1]</strong> for declaring and instantiating iterators and all other variables.</em><br/><em>Award <strong>[1]</strong> for correct main loop.</em><br/><em>Award <strong>[1]</strong> for correctly comparing the first Arrivals in the two lists.</em><br/><em>Award <strong>[1]</strong> for correctly adding the earlier Arrival to the end of the resulting list.</em><br/><em>Award <strong>[1]</strong> for testing <code>iter.hasNext()</code> and loop termination.</em><br/><em>Award <strong>[1]</strong> for attempting to add the remainder of a non-empty linked list.</em><br/><em>Award <strong>[1]</strong> for correct loop used for copying the remainder of <code>runway1</code>.</em><br/><em>Award <strong>[1]</strong> for correctly copying the remainder of <code>runway1</code>.</em><br/><em>Award <strong>[1]</strong> for also copying a possible remainder of <code>runway2</code>.</em></p>\n<p><em><strong>Example with iterator</strong>:</em></p>\n<pre><strong>public</strong> LinkedList<Arrival> mergeLists()<br/>{<br/> LinkedList<Arrival> result = <strong>new</strong> LinkedList<Arrival>();<br/> ListIterator<Arrival> iter1 = runway1.listIterator();<br/> ListIterator<Arrival> iter2 = runway2.listIterator();<br/> Arrival curr1 = <strong>null</strong>;<br/> Arrival curr2 = <strong>null</strong>;<br/><strong> if</strong> (iter1.hasNext()) {curr1 = iter1.next();}<br/><strong> if</strong> (iter2.hasNext()) {curr2 = iter2.next();}<br/><strong><br/> while</strong> ((curr1 != <strong>null</strong>) && (curr2 != <strong>null</strong>))<br/> { <strong>if</strong> (curr1.compareWith(curr2) <= 0) // or <<br/> { result.addLast(curr1);<br/><strong> if</strong> (iter1.hasNext()) {curr1 = iter1.next();}<br/><strong> else</strong> {curr1 = <strong>null</strong>;}<br/> }<br/><strong> else</strong><br/> { result.addLast(curr2);<br/><strong> if</strong> (iter2.hasNext()) {curr2 = iter2.next();}<br/><strong> else</strong> {curr2 = <strong>null</strong>;}<br/> }<br/> }<br/><strong><br/> while</strong> (iter1.hasNext()) result.addLast(iter1.next());<br/><strong> while</strong> (iter2.hasNext()) result.addLast(iter2.next());<br/><strong> return</strong> result;<br/>}</pre>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18N.2.HL.TZ0.16",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Consider the following algorithm.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<p style=\"text-align:left;\">Determine the outputs that will be produced by this algorithm.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>47, 23, 11<br/><em>Award <strong>[1]</strong> per output</em>.<br/><em><strong>Note</strong>: Allow FT if either of the first two outputs are wrong</em>.</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.8",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Copy and complete the following truth table where:</p>\n<p style=\"text-align:center;\">X = A XOR B<br/>Y = A NOR C<br/>Z = X OR NOT Y</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for all 8 input values correct;</em><br/><em>Award <strong>[1]</strong> for correct X column;</em><br/><em>Award <strong>[1]</strong> for correct Y column;</em><br/><em>Award <strong>[1]</strong> for correct Z column;</em><br/><em>Allow follow through from incorrect columns X or Y</em>.</p>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Generally, well answered, with many full or near full marks awarded. Some candidates lost marks by not giving a sufficient number of input combinations, so that instead of there being 8 possible input combinations, only 6 or 7 were supplied. Other candidates, due to not systematically filling the input columns, but using a more random approach, may have provided 8 input combinations, but at least one was a repeat of another.</p>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.5",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A bus company provides services within a city. The basic fare depends on the travel distance between the departure station and the destination station.</p>\n<p>The cost per kilometre is € 0.20.</p>\n<p>Children under the age of 5 can travel for free.</p>\n<p>Children between the ages of 5 and 15 <strong>inclusive</strong> can travel with a child age ticket, which gives a 50 % discount off the kilometre fare.</p>\n<p>The senior discount (age 65+) offers 30 % off the kilometre fare.</p>\n<p>The sub-program <code>costperkm(AGE)</code> accepts an integer <code>AGE</code> (the age of a passenger), then calculates and returns the cost per kilometre.</p>\n<p>For example,</p>\n<p><code>costperkm(10)</code> returns 0.1,<br/><code>costperkm(20)</code> returns 0.2,<br/><code>costperkm(80)</code> returns 0.14</p>\n</div><div class=\"specification\">\n<p>Passengers can find the distance between any two bus stations.</p>\n<p><strong>Figure 1</strong> shows the one-dimensional array <code>NAMES</code>. It is used to store the names of all bus stations on the route from Oppox to Dovely.</p>\n<p><strong>Figure 2</strong> shows the one-dimensional array <code>DISTANCES</code>. It is used to store the distances (in kilometres) on the route from Oppox to Dovely.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\"><code>DISTANCES[K]</code> holds the distance between the bus stations <code>NAMES[K-1]</code> and <code>NAMES[K]</code>.</p>\n<p style=\"text-align: left;\">For example, the distance between Kronos (<code>NAMES[7]</code>) and Longlines (<code>NAMES[8]</code>) is 1.2 km and can be found in <code>DISTANCES[8]</code>.</p>\n</div><div class=\"specification\">\n<p>The sub-program <code>calcdistance(P1,P2)</code> accepts the indexes of the names of two bus stations in the array <code>NAMES</code>, where index <code>P1</code> is always less than index <code>P2</code>, and returns the distance between them.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm in pseudocode for the sub-program <code>costperkm(AGE)</code>.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the distance between Kiko and Endsley.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the distance between Oppox and Brinkley.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how the distance between the two bus stations can be calculated in this sub‑program.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>An algorithm is needed that inputs the names of the two bus stations and the age of the passenger. It then calculates and outputs the price of a ticket.</p>\n<p>If any of the inputted names are not found, the algorithm outputs an appropriate message. <strong>Figure 3</strong> shows three examples of inputs and outputs.</p>\n<p style=\"text-align:center;\"><strong>Figure 3: Three examples of inputs and outputs from the algorithm</strong></p>\n<p style=\"text-align:center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align:left;\">Construct an algorithm as described. You should call sub-programs <code>costperkm()</code> and <code>calcdistance()</code> in your algorithm.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em></p>\n<p><em><strong>Award [1]</strong></em> <em>mark for correct condition (in if statement) and correct calculation of the cost per km for each type of tickets, <strong>x4</strong></em>.</p>\n<p><span style=\"text-decoration:underline;\">Example 1</span>:</p>\n<pre>costperkm(AGE)<br/> if AGE<5<br/> then COST=0.0<br/> else<br/> if AGE<=15<br/> then COST=0.20*0.50 // COST=0.20*50/100<br/> else<br/> if AGE<65 //accept AGE<=65<br/> then COST=0.20<br/> else COST=0.20*0.70 // COST=0.20*70/100<br/> endif<br/> endif<br/> endif<br/> return COST<br/>end costperkm</pre>\n<p><span style=\"text-decoration:underline;\">Example 2</span>:</p>\n<pre>costperkm(AGE)<br/> if AGE<5<br/> then COST=0.0<br/> endif<br/> if AGE>=5 and AGE<=15<br/> then COST=0.20*0.50 // COST=0.20*50/100<br/> endif<br/> if AGE>=15 and AGE<65<br/> //accept AGE>=15 and AGE<=65<br/> then COST=0.20<br/> endif<br/> if AGE>=65<br/> //if condition in the previous if statement is<br/> //AGE>=15 and AGE<=65, then this condition<br/> //should be AGE>65<br/> then COST=0.20*0.70 // COST=0.20*(100-30)/100<br/> endif<br/> return COST<br/>end costperkm</pre>\n<p><em><strong>Note</strong>: The method heading and the return statement may not appear in the candidates’ responses</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>1.3;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>1.2 + 1.0 or 2.2;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3] </strong></em><br/>The sum of elements;<br/>in the array <code>DISTANCES</code> from <code>P1+1</code>;<br/>to <code>P2</code>;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em><br/><em>Award <strong>[1]</strong> for all variables correctly declared and initialized;</em><br/><em>Award <strong>[1]</strong> for any correct loop through the array NAMES;</em><br/><em>Award <strong>[1]</strong> for to determine positions of <strong>both</strong> names in the array;</em><br/><em>Award <strong>[1]</strong> for outputting a message if one <strong>or</strong> other not present;</em><br/><em>Award <strong>[1]</strong> for comparison of positions to find smallest/largest;</em><br/><em>Award <strong>[1]</strong> for correct calculation and output of the price;</em><br/><em>Award <strong>[1]</strong> for correct invocation of methods</em> <code>calcdistance()</code> and <code>costperkm()</code></p>\n<p><span style=\"text-decoration:underline;\">Example 1</span>:</p>\n<pre>NAME1=input()<br/>NAME2=input()<br/>AGE= input()<br/>POS1=-1<br/>POS2=-1<br/>K=0<br/>loop while K<=9 and (POS1==-1 or POS2==-1)<br/> if NAMES[K].equals(NAME1) //<strong>accept</strong> <strong>'</strong>==<strong>' instead of</strong> equals()<br/> then POS1=K<br/> end if<br/> if NAMES[K].equals(NAME2)<br/> then POS2=K<br/> end if<br/> K=K+1<br/>end loop<br/>if POS1==-1 OR POS2==-1<br/> then<br/> output('stations are not found')<br/> else<br/> if POS1 > POS2<br/> then<br/> output( calcdistance(POS2,POS1)* costperkm(AGE))<br/> else<br/> output( calcdistance(POS1,POS2)* costperkm(AGE))<br/> end if<br/>end if</pre>\n<p><span style=\"text-decoration:underline;\">Example 2</span>:</p>\n<pre>ST1=input()<br/>ST2=input()<br/>AGE= input()<br/>PS1=-1<br/>PS2=-1<br/>loop K from 0 to 9<br/> if NAMES[K].equals(ST1) //accept '==' instead of equals()<br/> then PS1=K<br/> end if<br/> if NAMES [K].equals(ST2)<br/> then PS2=K<br/> end if<br/>end loop<br/><br/><br/>if PS1!=-1 AND PS2!=-1<br/> then<br/> if PS1 < PS2 <br/> then T=PS1 <br/> PS1=PS2 <br/> PS2=T <br/> end if<br/> PRICE= calcdistance(POS1,POS2)* costperkm(AGE)<br/> output(PRICE)<br/> else<br/> output('stations not found')<br/>end if</pre>\n<p><span style=\"text-decoration:underline;\">Example 3</span>:</p>\n<p><strong>Note</strong>: <em>Award marks for the algorithm written in Java/Python/Javascript/any other programming language. The following example is the solution written in Javascript</em>.</p>\n<pre>function findStation(station)<br/>{ var found = false;<br/> var i = 0;<br/> do<br/> { found = (ROUTE_X_NAMES[i] == station);<br/> if (!found) i = i + 1;<br/> } while (!found && i < 10);<br/> if (found) return i;<br/> else<br/> { output(\"No such bus station as \"+station);<br/> return -1;<br/> }<br/>}<br/><br/>var station1 = input();<br/> var P1 = findStation(station1);<br/> var station2 = input();<br/> var P2 = findStation(station2);<br/> var AGE = input();<br/> if (P1 >= 0 && P2 >=0)<br/> { if (P1 < P2)<br/> output(\"Cost = \"+costperkm(AGE)*calcdist(P1, P2));<br/> else<br/> output(\"Cost = \"+costperkm(AGE)*calcdist(P2, P1));<br/>}</pre>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "21N.1.SL.TZ0.11",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>State the hexadecimal representation of the binary number 10001010.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1 max]</strong></em></p>\n<p>8A;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates correctly stated the hexadecimal representation of the binary number 10001010.</p>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.2",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>For an identified application, explain why a binary search would be preferred to a linear search.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>For example, <strong>[2 max]</strong> if no application given</em>;<br/>Searching through a database of names;<br/>That contains a large amount of data;<br/>That is already sorted;<br/>And needs to be searched in the least amount of time;<br/>Is faster because binary search divides and searches smaller blocks of data/does not have to compare each element in the list;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.9",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A medical centre uses a computer system to manage both patients’ data and appointments. This system, which is used by the doctors, nurses and secretaries, has two unordered files: a patients’ file and an appointments’ file, both of which can only be accessed sequentially.</p>\n<p>Every evening the following processing takes place:</p>\n<ul>\n<li>a list of appointments for the next day is printed out</li>\n<li>reminders are sent by SMS text messages to the patients’ mobile devices.</li>\n</ul>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the pseudocode that the processing must follow when the system sends out the text reminders.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> different methods that the medical centre could use that would allow data to be restored should it be lost for any reason.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The medical centre is concerned about the privacy of the data it is storing and has to make decisions concerning:</p>\n<ul>\n<li>access to the data stored on this system</li>\n<li>storing the data locally or through the use of a cloud service.</li>\n</ul>\n<p>Discuss the issues that should be considered before making these decisions.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Award marks for a response which indicates the logical steps that have to be followed.</p>\n<p><em>Award <strong>[5 max]</strong> as follows</em>:<br/>Iterate through the appointments file;<br/>Check for correct day;<br/>Repeat for each appointment on that day;<br/>Using the patient ID for that appointment;<br/>Iterate through the patients file until record for that ID found;<br/>Retrieve phone number and send out SMS;</p>\n<p><em><span style=\"text-decoration:underline;\">Example</span>:</em></p>\n<p><img src=\"\"/></p>\n<p><em><strong>Note</strong>: Candidates are not requested to construct the (algorithm in) pseudocode</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for method and <strong>[1]</strong> for description – only accept TWO methods.</em><br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>Backup;<br/>Data files on a regular basis;</p>\n<p>Printed copies;<br/>Printouts can be kept of transactions;</p>\n<p>Transaction Log file;<br/>Written for each transaction can be used to restore;</p>\n<p><em>Accept any reasonable methods described including second server and cloud use</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>There are 2 possible issues here: who has what level of access to the data in the hospital and whether storing in the cloud is safer than storing locally</em>.</p>\n<p><em>For each of these 2 issues award <strong>[3 max]</strong> as follows</em>:<br/><em>Award <strong>[1]</strong> for identifying the issue.</em><br/><em>Award <strong>[1]</strong> for some valid development of the issue.</em><br/><em>Award <strong>[1]</strong> for a suitable discussion</em>.</p>\n<p><em>Example answers <strong>could</strong> include reference to the following but this is not an exclusive list. Award marks for any two reasonable issues discussed – one of which is access and the other security</em>.</p>\n<p><em><strong>Official access to the data [3 max]</strong></em>:<br/>Access to this sensitive data must be restricted.<br/>Only those directly concerned can be able to access it.<br/>Even less people should be able to edit it.<br/>Therefore access levels should be set up, with strong levels of authentication.<br/>Physical access to servers should be controlled if using the local system;</p>\n<p><em><strong>Data security [3 max]</strong></em>:<br/>Is the data safer stored locally or on the cloud?<br/>Cloud service providers are professionals – they should have stronger security than a hospital system.<br/>What track record / reputation does the cloud service provider have?<br/>If patient data could be sold/inspected, then both the patient and hospital could suffer serious consequences.<br/>Is the cloud governed by appropriate privacy laws?<br/>Is it located internationally or is it governed by the laws of the country in question?<br/>Could be intercepted in transmission;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.10",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming",
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"1-1-systems-in-organizations",
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Explain why abstraction is required in the design of algorithms.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Abstraction allows us to create a general idea of what the problem is and how to solve it;<br/>Abstraction removes all specific detail, and any patterns that will not help in solving a problem. This helps in forming a “model” (If designers don’t abstract they may end up with the wrong solution to the problem they are trying to solve);<br/>Abstraction is widely used because there exist a number of “patterns” in programming that keeps repeating in every application/program;<br/>The pattern corresponding to an issue can be found, then the abstract solution to it can be found and implemented, and the problem is solved;<br/>Most programming languages provide some built-in abstract patterns, which are easy to use (some API provides more advanced patterns);</p>\n<p>Abstraction is the process of taking away or removing characteristics from something in order to reduce it to a set of essential characteristics;<br/>In object-oriented programming, abstraction is one of three central principles (along with encapsulation and inheritance);<br/>Through the process of abstraction, a programmer hides all but the relevant data about an object in order to reduce complexity and increase efficiency;<br/>The resulting object itself can be referred to as an abstraction, meaning a named entity made up of selected attributes and behavior specific to a particular usage of the originating entity. Abstraction is related to both encapsulation and data hiding;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates generally found this question more difficult, with very few responses scoring more than 1 mark. Candidates who did gain marks recognised that abstraction enables a programmer to represent the main features of a problem, in order to solve it, without including irrelevant detail.</p>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.6",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-1-general-principles"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>one</strong> method of inputting data that can improve the accessibility of a computer system for some users.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award up to <strong>[1 max]</strong></em>.<br/>Text-to-speech;<br/>Voice recognition;<br/>Braille keyboards;<br/>Touch screen;<br/>Input from scanner;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.4",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline what is meant by a sorting algorithm.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> difference between a bubble sort algorithm and a selection sort algorithm.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em><br/>A sorting algorithm is a method for reorganizing a number of items;<br/>into a specific order (such as alphabetical order, highest-to-lowest value);</p>\n<p>Sorting algorithm performs specific operations on the input list/array;<br/>In order to deliver ordered list/array as output;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em></p>\n<p>Bubble sort swaps adjacent items;<br/>Selection sort finds the next smallest (each time it goes through the list);</p>\n<p>Bubble sort can exit early/ is faster if already the list is sorted;<br/>Selection sort will need to complete the procedure for the entire list every time;</p>\n<p>(The efficiency of Bubble and selection sort is different when applied on <strong>already sorted</strong> list)<br/>in the best-case bubble sort takes an order of N time;<br/>whereas selection sort consumes an order of N<sup>2</sup> time (where N is the number of items on the list));</p>\n<p><em><strong>Note</strong>: To award marks for such an answer it should be evident that the list is already sorted OR the term 'the best-case' should appear because the worst-case /average-case complexity/efficiency is same in both algorithms (O(N<sup>2</sup>))</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>In this question both parts, (a) and (b), were well answered by the majority of candidates. Many candidates scored full or nearly full marks for this question.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>In this question both parts, (a) and (b), were well answered by the majority of candidates. A few candidates confused Bubble Sort with Selection Sort. Many candidates scored full or nearly full marks for this question.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.3",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct a trace table for the following algorithm.</p>\n<pre>K = 1<br/>N = 1<br/>M = 2<br/>loop while K < 5<br/> output(N,M)<br/> K = K + 1<br/> N = N + 2<br/> M = M * 2<br/>end loop</pre>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[5 max]</strong> as follows</em>:<br/><em>Award <strong>[1]</strong> for a trace table with at least three columns (headings K, N, M, K<5 and output)</em>;<br/><em>Award <strong>[1]</strong> for each correct output up to <strong>[4 max]</strong></em></p>\n<p><em><strong><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></strong></em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>This question was well answered with the vast majority of candidates gaining some marks, many of whom<br/>achieved full or nearly full marks.</p>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.7",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p><strong>Copy</strong> and complete the following truth table.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1]</strong> for all correct input values, <strong>[1]</strong> for a correct A NOR B column and <strong>[1]</strong> for a correct (A NOR B) OR A column</em>.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.5",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An organization is implementing a new computer system.</p>\n</div><div class=\"specification\">\n<p>The management considered phased conversion and direct changeover as methods of implementation.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> organizational issues related to the implementation of the new system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate these <strong>two</strong> methods of implementation.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>one</strong> type of testing that involves users.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> consequences of inadequate testing.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Discuss the social and ethical issues associated with the introduction of a new computer system.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>User roles / the organization restructure their workflow;<br/>Technology issues / issues of software compatibility / hardware compatibility;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em><br/><em><strong>Direct changeover</strong></em>:<br/>is the cheapest and quickest/the old system is completely switched for the new one;<br/>this is straight forward but also the most risky / nothing to fall back on;<br/>no need to keep data duplicates;<br/>it allows the organization to change the system when most convenient;<br/>the employees have very little time in order get use to the new system as the change is instantaneous;<br/>there is a period of time when neither systems are operational;</p>\n<p><em><strong>Phased conversion</strong></em>:<br/>method where the old system is still in use but parts of the new system or modules are introduced, involves bringing in the new system one step at a time;<br/>less risky than direct changeover; less risky that the whole system will go wrong/if something happens, it will only affect the specific part;<br/>takes a lot of time;<br/>employees have enough time for training/to get use to the new system / are introduced to the changes in small stages;<br/>Employees/users could ask for changes which then hold up the installation of the next phase which helps improving the system;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>User acceptance test;<br/>Beta testing;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em><br/>Can lead to software which is not appropriate for the purpose it was intended/can lead to the system not meeting user requirements;<br/>Can lead to (undiscovered) bugs in software/errors in the system;<br/>Can lead to end user dissatisfaction;<br/>Can lead to reduced (employee) productivity;<br/>Can lead to decreased reliability of the organization;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em><br/>Personal/professional development of all employees must be considered;<br/>Physical safety (of all users);<br/>Ergonomic standards (human-computer components);<br/>Human dignity of all users;<br/>The new system might be designed to replace some staff;<br/>Code of ethics (system resources should not be used without approval);</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were usually able to identify at least one organizational issue related to user roles or technology, when implementing a new system. In many cases, candidates got both.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates were able to correctly evaluate the two given methods of implementation, direct changeover and phased conversion, with very comprehensive contextual responses seen. In some cases, it wasn't quite clear whether the candidate was describing phased conversion or pilot implementation. However, these cases were rare.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates correctly stated beta testing, as a type of testing that involves users.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally demonstrated their understanding of the consequences of inadequate testing with many full or nearly full mark responses seen. Some candidates unfortunately gave good descriptions of the consequences that concentrated on the same marking point, for example, they described the software not meeting user requirements or being fit for the intended purpose in multiple ways, therefore limiting their mark.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates recognised the more obvious social and ethical issues associated with the introduction of a new computer system, such as the need to replace some staff, or issues related to the implementation of a code of ethics. However, many candidates concentrated too much on matters related to poor data protection issues. In addition, the issues related to ergonomics, physical safety at work or professional development were rarely seen.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.8",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations",
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Assume X = 5, Y = 3 and A = TRUE.</p>\n<p>Determine the value of the following expression:</p>\n<p><math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mo>(</mo><mo>(</mo><mi mathvariant=\"normal\">X</mi><mo> </mo><mo>></mo><mo> </mo><mn>5</mn><mo>)</mo><mo> </mo><mi>XOR</mi><mo> </mo><mi mathvariant=\"normal\">A</mi><mo>)</mo><mo> </mo><mi>AND</mi><mo> </mo><mo>(</mo><mi mathvariant=\"normal\">Y</mi><mo> </mo><mo>+</mo><mo> </mo><mn>2</mn><mo> </mo><mo>></mo><mo> </mo><mn>4</mn><mo>)</mo></math></p>\n<p>Show all your working.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max] </strong></em><br/><em>Award <strong>[1]</strong> for showing the working out</em><br/><em>Award <strong>[1]</strong> for the correct result (TRUE)</em></p>\n<p>((5>5) <strong>XOR</strong> TRUE) <strong>AND</strong> (3+2>4) = (FALSE <strong>XOR</strong> TRUE) AND TRUE=<br/>=TRUE <strong>AND</strong> TRUE;<br/>=TRUE; </p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Many candidates correctly determined the value of the expression and gained full marks.</p>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.4",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A company has expanded its office space into nearby rooms and has decided to set up a local area network (LAN) to support its operations.</p>\n<p>The LAN will connect the room where the server is installed to new computers in the additional office space. The network engineer produced the following Gantt chart for this task.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>concurrent processing</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> tasks that will be carried out concurrently.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> tasks that will be carried out sequentially.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>After 5 years the company decided to replace the LAN with a wireless local area network (WLAN).</p>\n<p>Outline <strong>two</strong> advantages, to this company, of installing a WLAN.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A WLAN will introduce additional security issues for the company.</p>\n<p>Discuss any <strong>two</strong> of these issues and the ways in which the company might resolve them.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The company is considering expanding their network to allow employees to connect from anywhere in the world. The expanded network would need to provide security and allow the employees full functionality of the internal network.</p>\n<p>Explain how setting up a virtual private network (VPN) would provide a suitable solution.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Processes/task are carried out simultaneously/at the same time;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Install connectors on wall of server room AND Install connector on wall of new office space;</p>\n<p><em><strong>OR</strong></em></p>\n<p>Test the cabling AND Connect the new computers with the cabling;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Any pair of tasks that are NOT a correct answer to part (b)</em>;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for stating an advantage, <strong>[1]</strong> for expansion/example in context.</em><br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em></p>\n<p>Answers may include:<br/>Use on the move;<br/>More versatile staff encouraged to collaborate etc.;</p>\n<p>Allows BYOD:<br/>Which could lead to greater productivity (as familiarity with device);</p>\n<p>No extra equipment is needed for expansion after initial set-up;<br/>Which will save the company time and money;</p>\n<p>Reduces wiring;<br/>Therefore improved safety for employees;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>The data can be intercepted as it goes through “the air”;<br/>Can be resolved by strong encryption/protocols;<br/>WPA-2 / a description of WPA-2;<br/>Use of trusted MAC addresses;<br/>Regular changes of <span style=\"text-decoration:underline;\">router</span> password; <strong>[2 max]</strong></p>\n<p>BYOD issues leading to insecure devices;<br/>Clear company policy regarding use;<br/>Use of sand-box;<br/>Only approved devices allowed;<br/>MAC addresses – only adding clean and tested devices brought in by staff;<br/>Installation of MDM services;<br/>Authentication (user ID + password on all devices including BYOD);<br/>Security features added by company; <strong>[2 max]</strong></p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A VPN/tunneling allows the employee’s device to appear to be part of / a node of the internal company network;<br/>Thus affording him/her full access to the network resources;</p>\n<p>Data that passes through a VPN can be encrypted;<br/>So any unauthorized access will not be able to understand the data;</p>\n<p>Tunnelling allows the company’s own protocols to be used/IPsec/TSL ensure security;<br/>Even though the data is passing over an outside network;</p>\n<p>Multiple exit nodes / hidden IP addresses/encrypted connections;<br/>Make it hard to distinguish where the data was generated;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.11",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming",
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"4-1-general-principles",
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct a logic diagram for the Boolean expression</p>\n<p style=\"text-align:center;\">NOT A OR B AND C.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1]</strong> for each correctly placed gate, up to <strong>[3 max]</strong></em>.</p>\n<p><img src=\"\"/></p>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.6",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> difference between a binary tree and a non-binary tree.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Given the following binary search tree (BST), draw the resulting BST after the deletion of the root node.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><br/>Binary tree (is a tree) in which every node has (no, one or) at most two children whilst<br/>a non binary tree can have nodes with more than 2 children (non binary trees do not have an upper limit on number of children nodes);</p>\n<p>Each node in a binary tree can have at most two subtrees (left and right subtree), a node in a non binary tree can have any number of subtrees;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em></p>\n<p><em>Award <strong>[1]</strong> for the root (1)</em><br/><em>Award <strong>[1]</strong> for the correct right subtree</em></p>\n<p><em><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></em></p>\n<p>Alternative answer<em><br/></em></p>\n<p><em>Award <strong>[1]</strong> for the root (4)<br/>Award <strong>[1]</strong> for the correct right subtree</em></p>\n<p style=\"text-align:center;\"><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>In this question both parts, (a) and (b) were well answered by the majority of candidates.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>In this question both parts, (a) and (b) were well answered by the majority of candidates. Part(b) Only a few candidates did not draw the resulting binary tree after deleting the root node.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.5",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following algorithm, where <code>N</code> is a positive integer. </p>\n<pre>loop for K from 1 to N<br/> loop for J from 1 to N<br/> if K = J then<br/> output K<br/> end if<br/> end loop<br/>end loop</pre>\n</div><div class=\"question\">\n<p>Construct the algorithm which performs the same task using a single <code>while</code> loop, instead of nested <code>for</code> loops.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award marks as follows up to <strong>[4 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for correct initialization.</em><br/><em>Award <strong>[1]</strong> for correct condition.</em><br/><em>Award <strong>[1]</strong> for correct output.</em><br/><em>Award <strong>[1]</strong> for changing the value of controlling variable.</em></p>\n<p><em><strong>Note</strong>: The question explicitly requires one <code>while</code> loop</em>.<br/><em>Do no not accept a <code>for</code> loop. Do not accept two <code>while</code> loops</em>.</p>\n<p><em><strong>Example answer</strong></em></p>\n<pre>K = 1<br/>loop while K <= N<br/> output K<br/> K = K + 1<br/>end loop</pre>\n<p><em><strong>Example answer (including J variable)</strong></em></p>\n<pre>K = 1<br/>J = 1<br/>loop while K = J AND K <= N<br/> output K<br/> K = K + 1<br/> J = J + 1<br/>end loop</pre>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.7",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A group of programmers are involved in creating a new software product. They create many new sub-programs but also use existing sub-programs within the product.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p style=\"text-align:left;\">Outline why a sub-program is considered an example of abstraction.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the use of designing and developing different parts of software products concurrently.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> way in which users can be informed of software updates.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em></p>\n<p>A sub-program is a named section of code that performs a specific task (in a program) / can be called by name / referred by the identifier when needed;<br/>without knowing the details (of code and data structures) as these are wrapped / hidden within the sub-program;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em></p>\n<p>different stages (of programming) (<em>Accept examples!</em>) run simultaneously (rather than consecutively);<br/>this decreases product development time / decreases the time to market;<br/>leading to improved productivity/reduces costs;<br/>however, it requires more resources/more software developers;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong></em></p>\n<p>A message can be sent to the user (When the software is installed and registered, the user provides an email address / phone number);<br/>With a link to the update;</p>\n<p>notifications/alerts are sent to the computer (a cookie is placed on the user's computer which communicates with the software developer);<br/>about automatic updates;</p>\n<p>(when the program is run) it queries a URL the program developer has built in to check whether the current version matches the latest version;<br/>if not, notifications/alerts are sent;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates provided vague or too general answers.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates correctly answered this part.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.7",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming",
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"4-1-general-principles",
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>One-to-7</em> is an international organization that works with teachers and other educators. One department within this organization provides an online forum for teachers to discuss ideas for lessons and to share resources.</p>\n<p>In order to access this forum teachers are required to submit the following information, which will be stored in a table in the database.</p>\n<p style=\"text-align: center;\"><strong>Figure 1: Online form to register personal details to the <em>One-to-7</em> forum</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"specification\">\n<p>Once the submit button on the online form has been selected, the personal data is input into the database.</p>\n</div><div class=\"specification\">\n<p>Once the teacher is registered they can post comments on the forum.</p>\n</div><div class=\"specification\">\n<p>The <em>One-to-7</em> database in managed by the database administrator (DBA).</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> reason why the teacher’s name has been split into two fields.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> reason why there may be concerns about the amount of personal information that is requested.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why the transaction needs to be atomic in the context of this scenario.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how transactions are managed to ensure isolation when registered teachers add comments to a discussion thread on the forum.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> tasks that are carried out by the database administrator (DBA).</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The DBA is considering using the email address as the primary key, but is concerned that many of the 250 000 educators who are registering for this online forum may have more than one email address. Users may create duplicate accounts, deliberately or accidently, by using different email addresses as usernames.</p>\n<p>Explain the factors that would need to be considered in using a composite primary key instead of only using the email address.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>atomicity;<br/>sorting;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Not all of this information may be necessary for the purposes it is being collected for / asks for too much information;<br/>Teachers may be concerned about issues of privacy;<br/>If the information is shared with third parties it could be used / aggregated to identify the teacher / identity theft;<br/>Teachers may be put off either by the excessive time required to complete the form;<br/>This may lead to some teachers refusing to complete the application form / not as many teachers will sign up;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Atomicity in transactions ensure that the indivisible series of database operations either all occur, or nothing occurs;<br/>This prevents updates to the database occurring only partially / this maintains data integrity / consistency;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Isolation specifies the sequence that changes is processed / specifies that any parallel processing must produce the same result as if the processes were carried out sequentially;<br/>Each post to the thread takes place independently of others;<br/>One post will be completed before another starts / a post will not become visible until completed;<br/>Data and the transaction (row for the thread) is locked for that moment when the transaction is carried out;<br/>The addition of one post to the thread must not displace another’s, regardless of the order in which they finally appear;<br/>A transaction log is created prior to the transaction to allow rollback;<br/>This means that should an error occur part of the way through the transaction it will be rolled back and the database will return to its original state;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Data configuring / applying patches or upgrades;<br/>Setting permissions / passwords / access rights / ensuring security;<br/>Back up / recovery / archiving;<br/>Data cleansing / consistency checks on data / remove data errors;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>The large number of educators is critical to the number of fields included in any composite key;<br/>The composite key must be unique;<br/>Composite key could be made up of several fields;<br/>Allow suitable example (e.g. combinations of first name, last name, email, phone number etc.);<br/>Allow example that would <span style=\"text-decoration:underline;\">not</span> be suitable;<br/>Part of the primary key could include a random element in case of duplicated name and dates of birth;<br/>This would require an understanding of the nature of the educators, for example, are they of a particular age which would reduce the possible number of dates of birth, are they from one particular country so certain names would be more likely to occur;<br/>This would influence the number of fields that would be required to reduce the possibility of a duplicate entry occurring;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was poorly answered. Few candidates connected the question and scenario to atomicity or sorting purposes, while the majority claimed the reason for splitting the name into two fields was to avoid any confusion.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Generally, well done, but many partial marks were achieved on this question due to incomplete answers.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Was not well answered; Candidates were not able to outline the need for atomicity in transactions and many tended to confuse the question with networking environments, and failures in data transmission.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Was not well answered with many candidates giving generic answers for isolation in the scenario, but not knowing what happens when a transaction takes place with respect to this property.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was poorly answered. Responses were either vague or gave incorrect tasks of a DBA.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates were unable to clearly explain this question as they did not show understanding of the concept of a <em>composite primary key</em>. Some candidates, however, used correct examples to demonstrate its use and implications in the proposed scenario.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.1",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model",
|
||
"a-3-further-aspects-of-database-management",
|
||
"a-1-basic-concepts"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The machine instruction cycle is the process by which a program instruction is fetched, decoded, executed and the results are stored.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State where all instructions and data are stored.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the role of the data bus and address bus in this process.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Primary memory / RAM</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/><em><strong>Note</strong>: there must be explicit reference to both address and data bus</em></p>\n<p><em><strong>Example 1</strong></em><br/>Buses are used as physical connections to carry information to the CPU;<br/>The data bus transports data from/to CPU, whereas the address bus the memory address where the data is supposed to go/be.</p>\n<p><em><strong>Example 2</strong></em><br/>Data bus is a physical connection to transport data from-to CPU to be processed;<br/>Address bus is a physical connection to transport an address of memory storage where data (transported in the data bus) should be read/written;</p>\n<p><em><strong>Note</strong>: Award <strong>[1]</strong> mark, for responses that show some understanding of use of buses in CPU, for address location and data transport without using specialist terminology</em></p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.8",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> advantages of a school using a computer network.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the purpose of the following hardware component of a network: Router</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the purpose of the following hardware component of a network: Network interface card (NIC)</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why protocols are necessary.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>data encryption</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the use of trusted media access control (MAC) addresses as <strong>one</strong> method of network security.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em><br/>File sharing/resource sharing;<br/>instead of using a disk or USB key to carry files from one computer to another files can be shared directly using a network/all computers in the network can share resources such as printers, scanners;</p>\n<p>Communication;<br/>students/teachers can communicate with people around the world via the network;</p>\n<p>Interactive teamwork;<br/>software (like Microsoft Office) enables many users to contribute to a document concurrently;</p>\n<p>Flexible access;<br/>network allows students to access files from different computers (throughout the network) (one can begin work on a project on one computer and finish up on another);</p>\n<p>Software cost;<br/>software products are available for networks at a substantial savings in comparison to buying individually licensed software;</p>\n<p>Software management;<br/>load software on the server saves time compared to installing and tracking files on independent computers/upgrades are also easier because changes only have to be done once on the file server instead of on individual computers;</p>\n<p>Improved network security;<br/>if the school has its own network, it can monitor network traffic / can create a security culture (everyone who has a username and password is responsible for keeping data secure);</p>\n<p><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>A network router is a hardware device that is connected to multiple channels for different networks;<br/>through an interface that is situated on each network;</p>\n<p>Router acts as a processing unit for information packets;<br/>it duplicates information packets for use during transmission from one network to another;</p>\n<p>The router uses a protocol or set of rules;<br/>to determine which information packets are to be routed to certain interfaces within the network;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Network interface cards are used to connect each computer to the network;<br/>so they can communicate with the network router to receive information packets;</p>\n<p>Interface cards determine the infrastructure of a local area network (LAN);<br/>and allow all of the computers to connect to the network;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Protocols define the rules that govern network communication (for example, packet format, type and size, what happens when an error occurs, and which part of the network is supposed to handle the error and how);</p>\n<p>Computer networks consists of various types of equipment (such as routers, switches, hubs and network interface cards) and the equipment comes from different vendors, but they must all work together or the network does not operate correctly;</p>\n<p>Protocols work in layers (the highest being what the user sees, and the lowest being the wire that the information is transferred along) and these layers communicate with each other according to the rules (allowing communication to occur accurately and efficiently);</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>Data encryption refers to calculations/algorithms that transform plain text into a form that is non-readable to unauthorized parties (authorized recipient of an encrypted text uses a key and the algorithm to decrypt the data/ to transform it to the original plain text version);</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em><br/>Each (wireless network) adapter has a unique label called a MAC address;</p>\n<p>Routers uses these addresses to identify/authenticate computers (routers include an option to whitelist or blacklist certain devices based on MAC addresses, so access could be restricted to any device which is not in the whitelist);</p>\n<p>One disadvantage is that the whitelist should be amended any time a new device is purchased / when access to guests should be granted;</p>\n<p>Also this method is useless against hackers who use programs which intercept data passing through network and report the MAC address of any device communicating on the network;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were mostly able to outline at least one advantage of a school using a computer network. Answers were usually based around file or resource sharing. However, in many cases, the second advantage outlined was also related to file or resource sharing. Very few of the other possible answers were seen.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally found this question to be difficult and very few correct answers were seen, concerning the purpose of a router.</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates who achieved a mark for this question generally recognised that a network interface card was used to connect a computer to the network. Unfortunately, candidates who scored, generally only achieved a single mark, as they did not expand on their answers.</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally recognised that protocols define rules that govern network communication, but generally did not expand beyond that point, so rarely achieved two marks.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A mixed set of responses was seen for this question, in which candidates were required to define the term encryption. Candidates recognised that it was a security method but were often unable to provide sufficient detail to define clearly what it is.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally demonstrated a good understanding of what MAC addresses are and how they can be used in network security. Most candidates scored some marks. However, responses often lacked sufficient distinct points to allow all of the marks to be awarded.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.9",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Define the term <em>bit</em>.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>Binary digit;<br/>(Minimal) unit of storage that can be set to 0 or 1;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.9",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Explain how an operating system manages peripherals.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max] </strong></em></p>\n<p>OS keeps tracks of all peripheral devices (the I/O controller) / decides which process gets the device when and for how much time / allocates and de-allocates devices;<br/>OS works with device drivers and the basic input/output system (BIOS) to perform hardware tasks<br/>/ the necessary drivers (for every peripheral) are built into the OS and/or when a new peripheral is added software / device driver provided by a hardware maker is installed into the operating system (to tell the computer's OS how to work with the peripheral/hardware) (because without a device driver the OS would not be able to communicate with this peripheral device);<br/>A device driver translates the OS's instructions into a language (analogue signals) that the device can understand;<br/>There are various types of device drivers for peripherals (such as keyboards, mice, disk drives, controllers, printers, graphics cards, ports, etc.);<br/>Device drivers run in the OS kernel space (in the part of the OS that directly interacts with the physical structure of the system) (and implement functions such as open, close, read, write);<br/>The running application/user's program can make a call to device driver functions which provide an interface between user space and kernel space;</p>\n<p><span style=\"text-decoration:underline;\">Example answer</span>:<br/>An OS manages peripherals via their respective drivers;<br/>For example, sound card drivers;<br/>are necessary so the OS knows exactly how to translate the 1s and 0s (that comprise the MP3 file) into audio signals;<br/>that the sound card can output to headphones / speakers;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>A well answered question. Many comprehensive answers were seen.</p>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.8",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A transport authority is investigating how many people use a certain direct train route, which is used every day of the week.</p>\n<p>At the end of each day, the total number of passengers who travelled on this route is stored in a collection, <code>PASSENGERS</code>.</p>\n<p>The first item was written to the collection on Monday 1st January 2018.</p>\n<p><img src=\"\"/></p>\n<p>The next items, collected on Tuesday and Wednesday, were added like this:</p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p style=\"text-align:left;\">The collection <code>DATA</code> contains the following data:</p>\n<p style=\"text-align:center;\">2, 4, 1, −2, −4, 1, 0</p>\n<p style=\"text-align:left;\">Consider the following pseudocode:</p>\n<pre style=\"text-align:left;\">COUNTER = 0<br/>SUM = 0<br/>DATA.resetNext()<br/>loop for X from 0 to 6<br/> if DATA.getNext() > 0<br/> ARRAY[X] = DATA.getNext()<br/> COUNTER = COUNTER + 1<br/> SUM = SUM + ARRAY[X]<br/> end if<br/>end loop<br/>output SUM/COUNTER</pre>\n<p style=\"text-align:left;\">Trace the pseudocode using the table below:</p>\n<p style=\"text-align:left;\"><img src=\"\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Assuming that the first item read from the collection is from Monday 1st January 2018, construct pseudocode that will read <code>PASSENGERS</code> into an array, <code>P_ARRAY</code>.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using <code>P_ARRAY</code>, construct pseudocode to output the day of the week with the highest average number of passengers. Use the sub procedure <code>convert()</code> which converts the numbers 0 to 6 into days of the week, for example <code>convert(1)</code> will return “Tuesday”.</p>\n<p><strong>Note</strong>: you should <span style=\"text-decoration:underline;\">not</span> assume that data for an exact number of weeks is stored.</p>\n<div class=\"marks\">[7]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><img src=\"\"/></p>\n<p><em>Award <strong>[1]</strong> for each correct column (excepting the first). If the first row is not completed, mark as follows:</em><br/><em>All 4 correct except for first row: <strong>[3]</strong></em><br/><em>3 correct except for first row: <strong>[2]</strong></em><br/><em>2 correct except for first row: <strong>[1]</strong></em><br/><em>1 correct except for first row: <strong>[0]</strong></em>.</p>\n<p><em>Follow through for an output that is correct from their incorrect <code>COUNTER</code></em> <em>or <code>SUM</code></em> <em>columns.</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<pre>P_ARRAY // array declaration<br/>X = 0<br/>(PASSENGERS.resetNext())<br/>while PASSENGERS.hasNext()<br/> P_ARRAY[X] = PASSENGERS.getNext()<br/> X = X + 1<br/>end while</pre>\n<p><em>Award <strong>[1]</strong> for evidence of the idea of a loop (for or while etc.).</em><br/><em>Award <strong>[1]</strong> for correct while/until loop with correct condition.</em><br/><em>Award <strong>[1]</strong> for correct reading of collection into array.</em><br/><em>Award <strong>[1]</strong> for declaring and incrementing X</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The following are two alternative approaches. Most solutions should fit one or the other markscheme. Do not penalise those who introduce separate variables instead of arrays.</p>\n<p><span style=\"text-decoration:underline;\"><em>Example 1:</em></span></p>\n<pre>MAXAV = 0<br/> X = (P_ARRAY.length) − 1<br/> MAXDAY<br/> loop for DAY from 0 to 6<br/> SUM = 0<br/> COUNTER = 0<br/> loop for C from DAY to X //loop while C < X<br/> SUM = SUM + P_ARRAY[C]<br/> COUNTER = COUNTER + 1 <br/> C = C + 6 // C = C + 7 or allow step 7 in the loop<br/> end loop<br/> if SUM/COUNTER > MAXAV<br/> MAXAV = SUM/COUNTER<br/> MAXDAY = DAY<br/> end if<br/> end loop<br/>output convert(MAXDAY)</pre>\n<p><em>Award <strong>[1]</strong> for correct initialization of numerical variables (e.g. <code>MAXAV</code></em>, <em><code>COUNTER</code></em>, <em><code>SUM</code>)</em>.<br/><em>Award <strong>[1]</strong> for correct loop through each day</em>.<br/><em>Award <strong>[1]</strong> for correct for loop through array</em>.<br/><em>Award <strong>[1]</strong> for incrementing array position by 7 each time</em>.<br/><em>Award <strong>[1]</strong> for calculation of average (<code>SUM/COUNTER</code>)</em>.<br/><em>Award <strong>[1]</strong> for comparing this with <code>MAXAV</code></em>.<br/><em>Award <strong>[1]</strong> for adjusting <code>MAXAV</code> and <code>MAXDAY</code> if necessary</em>.<br/><em>Award <strong>[1]</strong> for correct use of <code>CONVERT</code> sub-procedure</em>.</p>\n<p> </p>\n<p><span style=\"text-decoration:underline;\"><em>Example 2:</em></span></p>\n<pre>MAXDAY = 0<br/>DAYSUM ARRAY<br/>WEEKS ARRAY<br/>COUNT = 0<br/><br/>while COUNT < P_ARRAY.length //loop through p.array<br/> DAY = COUNT MOD 7<br/> WEEKS[DAY] = WEEKS[DAY] + 1 //add number of weeks for this day<br/> DAYSUM[DAY] = DAYSUM[day] + P_ARRAY[COUNT]<br/> COUNT = COUNT + 1<br/>end while<br/>COUNT = 0 //reinitialize<br/>while COUNT < DAYSUM.length //loop through dayArray can also be<br/> //a for loop as there are 7 days.<br/> if DAYSUM[COUNT] / WEEKS[COUNT] > MAXDAY //find maxDay<br/> MAXDAY = COUNT<br/> end if<br/> COUNT = COUNT + 1<br/>end while<br/>output convert(MAXDAY)</pre>\n<p><em>Award </em><strong><em>[1] </em></strong><em>for correct initialisation of variables/arrays. <br/></em><em>Award </em><strong><em>[1] </em></strong><em>for correct loop through array. <br/></em><em>Award </em><strong><em>[1] </em></strong><em>mark for incrementing day. <br/></em><em>Award </em><strong><em>[1] </em></strong><em>mark for incrementing sum for each day. <br/></em><em>Award </em><strong><em>[1] </em></strong><em>mark for incrementing number of weeks for each day. <br/></em><em>Award </em><strong><em>[1] </em></strong><em>mark for correct calculation of average for each day. <br/></em><em>Award </em><strong><em>[1] </em></strong><em>mark for finding MAXDAY. <br/></em><em>Award </em><strong><em>[1] </em></strong><em>mark for correct use of CONVERT procedure.</em></p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "18M.1.SL.TZ0.12",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline what is meant by beta testing.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Involves sending sample software to the intended audience;<br/>(Selected audience do not pay for this software);<br/>To try/use the software product;<br/>And give the feedback to the authors (which help in correcting bugs);</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.10",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An application package used in an office includes a word processor. A secretary uses the word processor to create a text file.</p>\n</div><div class=\"specification\">\n<p>The text file is automatically saved at regular periods while being edited.</p>\n</div><div class=\"specification\">\n<p>All files created in this office contain information important to the business.</p>\n</div><div class=\"specification\">\n<p>The office manager decides to buy and install new software and hardware.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how a spellchecker checks whether a word in a text file is correctly spelt or not.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>one</strong> advantage of this feature.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> additional features of a word processing package that could be useful for this office.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the purpose of <strong>one</strong> application software package other than a word processing package that could be used in this office.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the security measures that should be taken to prevent data loss.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> problem that may arise from the installation of new hardware and software in the office.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The changeover to the new system can be achieved by either direct changeover or phased conversion.</p>\n<p>Compare direct changeover and phased conversion.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Each word in the text file is compared with words in a <span style=\"text-decoration:underline;\">dictionary</span> (held in memory/online);<br/>If the word is found in the dictionary it is correctly spelt / if the word is not found in the dictionary, spellchecker will recognize that it is incorrectly spelt;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>If power goes off, only the text typed after last (automatic) save is lost;</p>\n<p><em><strong>NOTE</strong>: accept responses that express evidence of just a partial loss of the file</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Apply styles, effects;<br/>Insert (tables/pictures/graphs/formulas/...);<br/>Mail merge;<br/>Macros;<br/>Print;<br/>etc.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for stating an application software package and <strong>[1]</strong> for stating its use in the office, up to <strong>[2 max]</strong></em>.</p>\n<p>Example answers<br/>Spreadsheet;<br/>For graphically presenting various data;</p>\n<p>Database software;<br/>For holding employees/customers data;</p>\n<p>Web page creators/editors;<br/>To create/manage the office’s web pages;<br/>etc.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Off site data storage;<br/>Make backups regularly/periodically/frequently;</p>\n<p>Prevent physical damage to the computers / Keep equipment in safe and dust-free places / Protect equipment from static electricity that can erase data or damage components / Protection during lightning and electrical storms;</p>\n<p><em><strong>Note</strong>: Accept any reasonable examples, but there should be more than one. The focus of the question is on data loss, and not in relation to security/hacking</em>.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for stating a problem and <strong>[1]</strong> for an elaboration, up to <strong>[2 max]</strong></em>.<br/>Users/employees might be afraid of these changes (for various reasons);<br/>And not willing to help in this change;</p>\n<p>Data migration problems;<br/>For example, different file formats so conversion must be performed;</p>\n<p>Employee efficiency may drop;<br/>As they learn to use the new system;</p>\n<p>Issue of compatibility with legacy software/hardware;<br/>So features of new software/hardware may not work correctly;</p>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for outlining what is meant by direct changeover, <strong>[1]</strong> for outlining what is meant by phased conversion, and then <strong>[1]</strong> for an advantage or disadvantage <strong>of each</strong>, up to <strong>[2]</strong></em>.</p>\n<p><strong>Example answer</strong>:<br/>Direct changeover, the old software and hardware is completely replaced, in one move, by the new software and hardware;<br/>Phased conversion involves selecting one section in the office for the direct changeover and other sections will be switched when the first section selected is running satisfactorily. Eventually the whole office has been changed;<br/>A phased conversion is less risky than a direct changeover as any problems that might arise will be isolated in only one section in the office;<br/>Direct changeover means everyone in the organization has same software/hardware and so there are no compatibility issues;</p>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.11",
|
||
"topics": [
|
||
"topic-2-computer-organization",
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization",
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A rail transport company uses a global positioning system (GPS) to determine a train’s position.</p>\n</div><div class=\"specification\">\n<p>The GPS data is used to provide real-time arrival data on video displays in train stations.</p>\n</div><div class=\"specification\">\n<p>The GPS data is made publicly available so that software developers can use it to build apps.</p>\n<p>The mobile application <em>ATrainAway</em> uses the real-time train GPS data as well as the GPS data from the user’s smartphone.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how GPS works.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>one</strong> data item concerning the arrival of a train that may be provided on the video display.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how sensors can be used in combination with GPS to provide more accurate arrival data.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> pieces of information that the <em>ATrainAway</em> application could provide to the user.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Discuss the advantages <strong>and</strong> disadvantages of using GPS in transportation systems.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] </strong></em><br/>The GPS receiver in a train takes the information from the satellite/ picks up the signals from (at least) 3 satellites;<br/>The signals transmitted are: time of transmission, coordinates of the satellite;<br/>The difference between the (atomic) time of transmission and (atomic) time of receiving the signal is used to calculate the distance;<br/>The method of trilateration is used to determine position from the distance to satellites/ is used to determine the train’s exact position/ is used to calculate position of the train through equation resolution on a sphere;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>Train number/ route / direction;<br/>Status (on time / delayed / cancelled);<br/>Time train / <strong>next</strong> train are due;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Motion sensors/vibration sensors (can be placed on track rail);<br/>(<em>Accept any sensors which detect trains that pass them!</em>)</p>\n<p>(Sensing devices are placed) at a distance from each side of a train station/junction<br/>OR<br/>at some fixed points where obstacles (like tunnels) prevent GPS from working properly;</p>\n<p>Data from each sensor can be logged continuously and used in calculations/determinations (of expected arrival times/ delays / rerouting during disruption, etc.);</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>Real-time information (train number/ route / direction and status (on time / delayed / cancelled);<br/>relating to the arrival / departure of a particular train;</p>\n<p>The time next train is due (the next 2/3 times a train will arrive at the station);<br/>helps passenger to spend less time waiting on trains;</p>\n<p>Should save user's (passenger) most frequented stops and routes;<br/>for quick access to get the next rail trip;</p>\n<p>Alerts (set);<br/>to let you know when a train is nearing the station;</p>\n<p>Trip planning (conducted);<br/>through Google trip planner within the app;</p>\n<p>Information on the nearest station, distance to station/ next train arrival/ next train departure;<br/>to help passenger to spend less time travelling/ save time;</p>\n<p><em>Mark as 2 and 2</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>Safer transit;<br/>Trains are tracked and in case of emergency the location can be reached at the earliest and emergency services provided;</p>\n<p>More favourable view of transit/helps passenger to get punctuality status of the train/;<br/>GPS can provide worldwide three-dimensional positions (24 hours a day) (in any type of weather);</p>\n<p>Sometimes it is too difficult to ensure reliable positioning;<br/>Objects, such as buildings, overpasses, and other obstructions (that shield the antenna from a satellite) can potentially weaken a satellite's signal;</p>\n<p>Privacy issues;<br/>Knowing the absolute position of anything, anytime, anywhere;</p>\n<p><em>Mark as 2 and 2</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates knew that a GPS works by communication with satellites. Some candidates failed to achieve full marks as result of incomplete and vague descriptions. A few candidates, for some unknown reasons, wrote that the satellite calculates the train's position. </p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Generally, well answered, with many full or near full marks awarded.</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Generally, well answered, with many full or near full marks awarded.</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question was well answered with the vast majority of candidates gaining some marks, some of whom achieved full or nearly full marks.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were usually able to identify the advantages and disadvantages of using GPS in transportation systems. Some marks were lost because of vague discussions.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.11",
|
||
"topics": [
|
||
"topic-7-control"
|
||
],
|
||
"subtopics": [
|
||
"topic-7-1-control"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Define the term <em>recursion</em>.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p>Process/method/ procedure/ subroutine/ function/ algorithm that calls itself;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.HL.TZ0.7",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Taxonomy is the part of science that focuses on naming and classifying or grouping organisms. Swedish naturalist, Carl Linnaeus, developed the current hierarchical classification system of taxonomic classification in the 1700s. This classification is hierarchical so one class has many orders, and one order has many families.</p>\n<p>Birds can be classified under the Linnaean hierarchical taxonomy as “Aves”. In one system of classification, Aves has 23 orders, one of which is the order Ciconiiformes, which holds six families within it.</p>\n</div><div class=\"specification\">\n<p>Spoonbills constitute one of the families within the order Ciconiiformes. Data can be collected about spoonbills, such as length of the bill or beak, and is included in the database.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an entity-relationship-diagram that shows the relationships between the class, order and family.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline, using an example, how data validation can ensure that data is entered into the birds database correctly.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline, using an example, how data verification can ensure that data is entered into the birds database correctly.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between data and information when entering the length of a spoonbill’s beak in the database.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> characteristics of a conceptual schema.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the use of data modelling is critical to the success of a database, such as the one used in this scenario.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain, using the example described in the scenario, why referential integrity is important in databases.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each correct relationship with labels</em>.<br/><em>Award <strong>[1]</strong> for a top-down diagram showing the relationships</em>.</p>\n<p>One CLASS contains many ORDER;<br/>One ORDER contains many FAMILY;</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em><span style=\"text-decoration:underline;\">Note: original MS did not make any sense</span></em><br/>Length check;<br/>Could ensure only a value within an acceptable range is entered (allow example);<br/>Type/format check on bill;<br/>Only numerical (int/float etc.);</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Double entry;<br/>Will only allow data entry if both match;<br/>Proof reading;<br/>Will give a visual check that the data is correct;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>When the length of the bill / beak of the spoonbill is measured it is simply a decontextualized figure such as 10 cm;<br/>When it is included in the database and interrogated it will have a meaning, so it then becomes information;</p>\n<p>The database will contain only the figure “10”;<br/>the “cm” will not be included and is part of the meaning of the attribute/field.</p>\n<p><span style=\"text-decoration:underline;\">Note: the “information” mark must reference the database in some way</span></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>A high-level / overall / general view of the database;<br/>Shows the main concepts;<br/>Shows the main relationships,<br/>Can be described by a Data Structure Diagram;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Data modelling gives a visual representation of the proposed system;<br/>So that all stakeholders have the same understanding of the system;<br/>Shows basic relationships / establishes naming conventions etc.;<br/>Some that developers are able to develop the actual database;<br/>Avoiding issues such as redundancy/lack of integrity/lack of consistency;</p>\n<p>The data model will take the information from the conceptual schema and logical schema to informs the physical model for the development of the database;<br/>A lack of modelling may result in a structurally deficient implementation with poor data integrity / redundant data;<br/>This may mean developing prototypes of the database to test whether the proposed structure of the database will function as intended;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/><span style=\"text-decoration:underline;\">Note: only award full marks if there is a valid reference to the scenario</span>.<br/>Referential integrity requires that a value used as a foreign key corresponds to a value of a primary key / validates the database through relationships;<br/>Therefore if the Ciconiiformes/order of the Spoonbill is not in the database, you will not be able to add it because of referential integrity;<br/>Referential integrity constraints;<br/>Ensure that if a record is updated or deleted, these changes will made in related cells and the possibility of update anomalies is reduced / eliminated;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most of the candidates clearly identified the main entities but failed to establish and correctly label the relationships.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates showed a good understanding of <em>data validation</em> and <em>data verification</em> with appropriate use of examples related to the scenario. However, many candidates provided answers that were generic, which showed confusion with both concepts.</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates showed a good understanding of <em>data validation</em> and <em>data verification</em> with appropriate use of examples related to the scenario. However, many candidates provided answers that were generic, which showed confusion with both concepts.</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates had no problem identifying what <em>data</em> was, but were not able to clearly distinguish the concept of information within the scenario.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A few candidates were able to correctly identify the characteristics of a conceptual schema.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was not well answered. Many candidates provided vague responses and just a few referred to <em>data modeling</em> as being critical process for avoiding issues such as redundancy, lack of integrity or lack of consistency.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most of candidates could not explain <em>referential integrity</em> with respect to the scenario.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.2",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model",
|
||
"a-1-basic-concepts"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Describe the characteristics of a queue.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award</em> <strong><em>[2]</em></strong>.<br/>FIFO data structure;<br/>Items can be added only to one end (rear/tail) and removed from the other end (front/head);</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.HL.TZ0.8",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline the function of an interrupt.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>An interrupt is a signal to the CPU sent by hardware or software;<br/>The function of an interrupt is to alert the CPU to suspend execution of the current program;<br/>And to transfer the control to the interrupt handler (which saves the state of the current program to the interrupt stack, services the interrupt and resumes the normal CPU activity);</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18M.1.HL.TZ0.10",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><code>NUMBERS</code> is a collection that holds only positive integers.</p>\n<p>A three-digit number has three digits: a hundreds digit, a tens digit and a units digit. <br/>For example, for 406, its hundreds digit is 4, its tens digit is 0 and its units digit is 6.</p>\n<p>An algorithm is needed to copy each three-digit number from the collection <code>NUMBERS</code>, where the hundreds digit is smaller than its tens digit and its tens digit is smaller than its units digit, into a one-dimensinal array named <code>THREE</code>. If there are no such numbers in the collection then an appropriate message should be displayed.</p>\n<p>For example:</p>\n<p>If <code>NUMBERS </code>= <code>{9, 3456, 12, 237, 45679, 368, 296}</code></p>\n<p>then the contents of the array, <code>THREE</code>, is:</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">If <code>NUMBERS</code> = <code>{1234, 56, 90, 324, 876}</code></p>\n<p style=\"text-align: left;\">then the array <code>THREE</code> is empty and a message such as “No such numbers”, should be outputted.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Consider the following algorithm.</p>\n<pre>N = 372<br/>X = N DIV 100<br/>Y = X + 10 * (N MOD 100 DIV 10)<br/>Z = Y + (N MOD 10) * 100<br/><br/>Determine the values of variables X, Y, and <code>Z</code> after execution of this algorithm. Show your working.</pre>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct this algorithm. You may assume that the array <code>THREE</code> is initialized with a sufficient number of elements.</p>\n<div class=\"marks\">[8]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how a selection sort algorithm could be used to sort the array <code>THREE</code> in ascending order.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em><br/>X = 372 div 100 = 3;</p>\n<p>Y = 3 + 10 * (372 mod 100 div 10) = 3 + 10 * ((372 mod 100) div 10) = 3 + 10 * (72 div 10) = 3 + 10 * 7 = 73;<br/>Z = 73 + (372 mod 10) * 100 = 73 + 2 * 100 = 273;</p>\n<p><em>Award FT marks if working is shown</em>.<br/><em>Award 1 mark only for each correct value if no working shown, up to 3</em>.</p>\n<p>X = 3;</p>\n<p>Y = 73;</p>\n<p>Z = 273;</p>\n<p><em>Allow FT marks</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[8 max]</strong></em><br/><em>Award <strong>[1]</strong> for reset/starting from the first item in the collection and for initialization and correct increasing of the array index (K)</em><br/><em>Award <strong>[1]</strong> for the while loop through the collection</em><br/><em>Award <strong>[1]</strong> for retrieving a number from the collection</em><br/><em>Award <strong>[1]</strong> for if statement- checking whether the number retrieved is a three-digit number</em><br/><em>Award <strong>[1]</strong> for correctly calculated digits in retreived number,</em><br/><em>Award <strong>[1]</strong> for each</em><br/><em>Award <strong>[1]</strong> for if statement which compares the three digits of the retrieved number</em><br/><em>Award <strong>[1]</strong> for correctly placing ITEM into the array THREE</em><br/><em>Award <strong>[1]</strong> for the correct output message</em></p>\n<p><em>Example answer</em>:</p>\n<pre>K=-1<br/>NUMBERS.resetNext()<br/>loop while NUMBERS.hasNext()<br/> ITEM=NUMBERS.getNext()<br/> if ITEM>99 and ITEM<1000 then<br/> F=ITEM DIV 100<br/> S=ITEM MOD 100 DIV 10 //or S= ITEM DIV 10 MOD 10<br/> T=ITEM MOD 10<br/> if F<S and S<T then<br/> K=K+1<br/> THREE[K]=ITEM<br/> end if<br/> end if<br/>end loop<br/>if K==-1 then<br/> output('No such numbers')<br/>endif</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em><br/>The selection sort algorithm starts by finding the <strong>minimum/smallest</strong> value in the array THREE (containing K elements);<br/>and moving it to the beginning of the array THREE (element at the first position is THREE[0]) / exchanges it with the element in the first position;<br/>the correct entry is in the first place in the array and the process is repeated on the remaining entries / this step is then repeated for the second lowest value, then the third, and so on;<br/>once this has been repeated K-1 times;<br/>the K-1 smallest entries are in the first K-1 places which leaves the largest element in the last place (the array is sorted in ascending order);</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally found this question difficult. They were required to determine the values of a number of variables using the formulae given. These formulae included program code for integer division and the remainder of integer division. Unfortunately, candidates often ignored this and simply gave answers as though regular division was used, therefore the answers given were incorrect. However, some candidates achieved full marks, and others achieved marks for partially correct responses.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A wide range of marks were awarded for this question, in which an algorithm was written. The algorithm involved copying data from a collection, processing it and then copying some of the data that meets a test into an array. Candidates achieved credit for the correct elements of their algorithms. Some common errors included candidates using an array for the initial data retrieval, rather than a collection, and not correctly using a loop, to ensure all the data elements had been read from the collection.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates achieved high marks for this question, as they were able to correctly describe how a selection sort could be used to sort the resulting array from part b in ascending order. A few candidates lost marks because they used the wrong type of sorting algorithm, for example, a bubble sort or an insertion sort. Another error seen involved candidates sorting the data into descending order.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19N.1.SL.TZ0.10",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The names of students attending a science fair were recorded in a stack data structure as each one arrived.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">The first item stored in the stack was “<code>Sophie</code>”.</p>\n<p style=\"text-align: left;\">Note that “<code>Troy</code>” is currently in position 0 in the stack.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the pseudocode that will search the stack for a specific name, and output its position in the stack. You may assume that all names in the stack are unique.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the benefits of using a binary search tree, compared to a stack, when searching for a specific item.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>If the tree is populated with the data from the stack, the first item popped off will become the root. For each subsequent item popped from the stack, a recursive procedure is followed until the item is correctly placed in the tree.</p>\n<p>Without writing code, describe this recursive procedure.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>By considering only the data visible in the stack shown above, sketch the binary search tree that has been created from the items removed from the stack.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong> as follows:</em></p>\n<p><span style=\"text-decoration:underline;\"><em>Example answer 1</em>:</span></p>\n<pre>searchName(NAME, STACK)<br/> DEPTH = 0<br/> NAMEDEPTH = -1<br/> while not STACK.isEmpty() do<br/> X = STACK.pop()<br/> if X == NAME<br/> then NAMEDEPTH=DEPTH<br/> DEPTH = DEPTH + 1<br/> end while<br/> if NAMEDEPTH == -1<br/> then output(NAME + ’not found’)<br/> else output(NAMEDEPTH)<br/> endif<br/>end searchName</pre>\n<p><em>Award <strong>[1]</strong> for initialization.</em><br/><em>Award <strong>[1]</strong> for a correct while/until loop.</em><br/><em>Award <strong>[1]</strong> for correct comparison and assignment.</em><br/><em>Award <strong>[1]</strong> for updating and outputting correct position of <code>NAME</code> on the stack(<code>NAMEDEPTH</code>)</em><br/><em>Award <strong>[1]</strong> for use of stack methods (<code>pop()</code> and <code>isEmpty()</code>)</em></p>\n<p><span style=\"text-decoration:underline;\"><em>Example answer 2:</em></span></p>\n<pre>NAME=input()<br/>CSTK = STACK.copy() // must make a real copy,<br/>//any attempt to make a copy of stack is acceptable<br/>DEPTH = 0<br/>SEARCHING = true<br/>while SEARCHING and not CSTK.isEmpty() do<br/> if NAME == CSTK.pop()<br/> then<br/> SEARCHING = false<br/> else<br/> DEPTH = DEPTH + 1<br/> end if<br/>endwhile<br/>if not SEARCHING<br/> then output(DEPTH)<br/> else output NAME + \" not found\"<br/>end if</pre>\n<p><em>Award <strong>[1]</strong> for initialization.<br/>Award <strong>[1]</strong> for a correct while/until loop (even if flag is missing).<br/>Award <strong>[1]</strong> for correct comparison and assignment.<br/>Award <strong>[1]</strong> for incrementing and outputting correct position of <code>NAME (DEPTH)</code>.<br/>Award <strong>[1]</strong> for use of stack methods <code>pop()</code> and <code>isEmpty()</code>).</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong>.</em></p>\n<p><em><span style=\"text-decoration:underline;\">Example answer 1 (time efficiency)</span></em>:<br/>The data in the binary search tree(BST) is ordered;<br/>Such that as each node is checked for the item, half of the remaining nodes are ignored;<br/>But each element in the stack has to be checked;<br/>Which, for large data sets, may be inefficient compared to the BST;</p>\n<p><span style=\"text-decoration:underline;\"><em>Example answer 2 (memory efficiency)</em></span>:<br/>Each element on the stack has to be popped off/removed from the stack to be checked for the searched item;<br/>When the item is found the stack will be empty/stack contents will be changed;<br/>When an element in the BST is checked for the item it is not removed from the BST;<br/>So there is no need to create an additional copy of the BST (but a real copy of the stack must be created which for large data sets may be inefficient);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p><span style=\"text-decoration:underline;\"><em>Example answer</em></span>:<br/>The (next) stack item is (placed into a new node and) compared (alphabetically) to the root;<br/>If the root is empty it would be placed here (and this recursive procedure terminates);<br/>Else, depending upon the comparison, it would look to the node to the left or right and the (recursive) procedure calls itself again (with the new root);<br/>If it is lower than the root, then the left child of the root becomes the new root;<br/>If it is higher than the root, then the right child of the root becomes the new root;</p>\n<p><em><strong>Note</strong>: Marks should also be awarded for an algorithm constructed in pseudocode.</em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3]</strong></em>.</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n<p><em>Award marks as follows</em>:<br/>Clearly a binary tree;<br/>Correct root;<br/>All values correct;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18M.1.HL.TZ0.13",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following circular linked list:</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">where <em>head</em> is an external pointer that points to the first node in the circular linked list.</p>\n<p style=\"text-align: left;\">Three operations are performed on this circular linked list in the following order:<br/><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>Arrays and linked lists are used to store linear data.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Sketch a diagram showing the resulting circular linked list.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how the last node of the circular linked list is identified.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the steps required to calculate the sum of all numbers held in this circular linked list.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare the use of arrays and linked lists.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A linked list can be used to implement a data structure queue.</p>\n<p>Identify <strong>two</strong> applications of a queue data structure.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for the node containing number 20 is pointed to by the pointer 'head';</em><br/><em>Award <strong>[1]</strong> for the diagram showing only two nodes and all the correct links;</em><br/><em>Award <strong>[1]</strong> for the last node containing number 5;</em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.</p>\n<p>The last node is identified by its next/link pointer;<br/>which contains the address of the node at the beginning of the list / is equal to the pointer “head “;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p>Initialize (a temporary pointer with the head and) a variable sum with 0 (zero);<br/>Loop from the beginning to the end of the circular linked list / until all the nodes get traversed);<br/>Add the value (of the data field) (of the current node) to the sum;<br/>Change the temporary pointer so it points the next node of circular linked list;</p>\n<p><em><strong>Note</strong>: Answers written in pseudocode are acceptable</em>.<br/><span style=\"text-decoration:underline;\"><em>For example</em></span>,</p>\n<pre>sum = 0<br/>curr = head<br/>loop<br/> sum = sum + curr.data<br/> curr = curr.next<br/>until curr == head</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p>In an array, memory is assigned during compile time(predetermined) whilst in a linked list it is allocated during execution/runtime;<br/>Arrays are of fixed size whilst linked lists are flexible and can expand and contract its size;<br/>Array requires less memory (due to actual data being stored within the index in the array) whilst there is a need for more memory in linked list (due to storage of additional next and previous pointers/references);<br/>Elements are stored consecutively in array whereas elements are stored randomly in linked lists;<br/>Memory utilization is inefficient in the array whilst memory utilization is efficient in the linked list;<br/>Accessing an element in an array is direct (fast) while accessing an element in linked list is sequential/linear (slower) /to get into the nth element only the array name with index within the square bracket should be written whilst a linked list (to get the nth element) should be traversed starting from the beginning of the list, and traversing through the list until found/ ;<br/>Operations like insertion and deletion in arrays consume a lot of time whilst the performance of these operations in linked lists is fast;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.</p>\n<p>Print queues (a number of print jobs on a queue instead of waiting for each one to finish before specifying the next one);<br/>Queue is used for synchronization when data is transferred asynchronously between two processes (for example IO Buffers, file IO);<br/>Queues are used in CPU scheduling algorithms;<br/>Handling of interrupts in real-time systems (the interrupts are handled in the same order as they arrive, first come first served);<br/>Computer modelling of physical queues (supermarket checkouts) (call centre phone systems use queues to hold people calling them in an order, until a service representative is free);</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to sketch a diagram showing the resulting circular linked list.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A mixed set of responses was seen for this question. Most candidates knew that the last node in a circular linked list contains a pointer to the first node of the list. A few candidates incorrectly wrote that the next of the last node point to the null.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were required to write the main steps involved in an algorithm to calculate the sum of all numbers held in the circular linked list. Many candidates were well prepared, some candidates even wrote their answers in algorithmic form and they generally achieved better results than those who simply described the steps. The full range of marks, from zero to four were achieved for this question.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Was reasonably well answered with many gaining at least two of the marking points. Some candidates described two data structures individually without performing any comparison and thus losing marks.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Was well answered.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.12",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Sketch a double linked list that holds the following sequence of names: Anne, Lana, Mary.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em><br/><em>Award <strong>[1]</strong> for showing that every node in a double linked list contains three fields (data and 2 pointers);</em><br/><em>Award <strong>[1]</strong> for showing every node has link to its previous node and next node/can be traversed forward by using next field and can be traversed backward by using previous field;</em><br/><em>Award <strong>[1]</strong> for showing that the first node must be always pointed by an external pointer (for example head) (and the last node could be pointed to by an external pointer (for example rear));</em><br/><em>Award <strong>[1]</strong> for showing that the previous field of the first node must be NULL and the next field of the last node must be NULL</em>.</p>\n<p><img src=\"\" style=\"display:block;margin-left:auto;margin-right:auto;\"/></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates sketched a doubly linked list and answered this question reasonably well.</p>\n<p>Only a few candidates did not attempt this question.</p>\n</div>",
|
||
"question_id": "19N.1.HL.TZ0.5",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A number of devices in and around the home can be operated by control systems.</p>\n<p>A home owner wishes to install automatic lights to illuminate a water fountain in her garden. These lights will automatically turn on at sunset and turn off at sunrise.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> hardware components that would be an essential part of this control system.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the concept of feedback, with respect to computer control systems in general.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The home owner has also installed a control system that waters the flowerbeds in the garden. This system aims to maintain the water content of the flowerbeds between a minimum and a maximum value. However, the system is only activated when the light intensity is below a certain level.</p>\n<p>Outline the algorithm involved in controlling the watering system described above.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying the hardware component and <strong>[1]</strong> for describing its purpose within the control system.</em><br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>Sensor;<br/>To detect the presence/absence of the light;</p>\n<p>Microprocessor;<br/>To carry out any processing;</p>\n<p>Output transducer / Actuator / Activator;<br/>To turn the lights on or off;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The output value is (continuously) compared to the desired value; <br/>To produce an error value/difference between observed and measured; <br/>The controller uses the error value/difference between observed and measured;<br/>To determine the new input to the system;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong> for the following</em>:<br/><em><strong>[1] </strong>the system is turned on (when the light intensity is below a given value);</em><br/><em><strong>[1] </strong>for light loop/while input light intensity is below the given value the system continues being on;</em><br/><em><strong>[1] </strong>for comparison and activating watering / checking the water content of the flower beds and turning on water if the water content is not in a given range;</em><br/><em><strong>[1] </strong>for water loop / watering until maximum value;</em><br/><em><strong>[1] </strong>for turning off water when the water content of the flower beds is filled to maximum;</em><br/><em><strong>[1] </strong>for turning off system when the light intensity increases the given value;</em></p>\n<p><em><strong>Note</strong>: Candidates are not requested to construct an algorithm in pseudocode</em>.</p>\n<p><span style=\"text-decoration:underline;\"><em>Example answer</em></span>:</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "18M.1.HL.TZ0.14",
|
||
"topics": [
|
||
"topic-7-control"
|
||
],
|
||
"subtopics": [
|
||
"topic-7-1-control"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A wireless local area network (WLAN) is used to extend access to a school’s wired local area network.</p>\n</div><div class=\"specification\">\n<p>The advantages of this WLAN are user-mobility and economical access points.</p>\n</div><div class=\"specification\">\n<p>The concept of packet data transmission is used within this network.<br/><strong>Figure 1</strong> shows the simplified structure of a data packet.</p>\n<p style=\"text-align: center;\"><strong>Figure 1: The structure of a data packet</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> hardware component of the WLAN, other than computers.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> disadvantages of this WLAN.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> ways in which the network administrator can reduce the risk of unauthorized access to confidential data.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>protocol</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to <strong>Figure 1</strong>, explain how data is transferred by packet switching.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[1 max]</strong></em>.<br/>Wireless router/modem;<br/>Access points;<br/>Switch;<br/>Wireless repeater/extender/booster;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying a disadvantage and <strong>[1]</strong> for an expansion, for <strong>two</strong> disadvantages up to <strong>[4 max]</strong></em>.</p>\n<p>Data transfer will decrease (compared with a wired LAN);<br/>Because the number of computers using the network increases;<br/>(and because) WLAN has lower bandwidth than a wired LAN;</p>\n<p>Less data security;<br/>As devices from outside the school can access the network/intercept transmissions;</p>\n<p>More easily open to misuse;<br/>As teacher/administrator cannot directly monitor a specific student/teacher/ machine;</p>\n<p>Intermittent connectivity due to physical barriers (walls);<br/>Results in low transfer/speed and may hinder operations.</p>\n<p><em><strong>Note</strong>: Accept any reasonable points, provided they are appropriately elaborated</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>Give each user appropriate login details/passwords;<br/>Different access rights for students, teachers, school administrators (file-level and share-level security);<br/>All passwords and files should be encrypted;<br/>Use the latest WiFi protocol/WPA2;<br/>Require MAC address authentication;<br/>Password protect the documents;</p>\n<p><em><strong>Note</strong>: the focus of the question is on confidential data (firewalls not accepted)</em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Set of rules for data transmission;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6]</strong> as follows</em>:</p>\n<p><em>Award up to <strong>[3 max]</strong> for a general description of how data is transferred by packet switching. ([1 max] if this general description is very simplistic and refers to just the Header/Data/Trailer already shown in the question paper)</em>.</p>\n<p><em>Award up to <strong>[3 max]</strong> for added detail that references the contents of the given data packet in the answer</em>.</p>\n<p><em><strong>Example of general description</strong></em></p>\n<p>Data is organized in specially formatted units (data packets) which are routed from source to destination using network switches and routers;</p>\n<p>Network switches and routers determine how best to transfer the packet between a number of intermediate devices (routers and switches) on the path to its destination (rather than flowing directly over a single wire on the path to its destination);</p>\n<p>Data packets are reassembled at the destination;</p>\n<p><strong>Example of referencing content</strong></p>\n<p><em><strong>Addresses</strong></em> have to be in a standard format so that each switch/routing station recognizes the address;<br/><em><strong>Address of sender</strong></em> identifies the sending computer, so that any packets not received can be re-requested;<br/><em><strong>Address of receiver</strong></em> identifies intended recipient so it can be forwarded on correctly;<br/>The <em><strong>protocol</strong></em> used must be identified so that the correct rules are followed;<br/><em><strong>Size of packet / size of fields in packet</strong></em> – All packets/fields must have the same size so that the data can be reassembled;<br/><em><strong>Sequence number</strong></em> so that packets can be reassembled in correct order;<br/><em><strong>Transmission codes</strong></em> to show whether the data packet is transmitted or re-transmitted;<br/><em><strong>Control bits</strong></em>, to maintain the integrity of the data by ensuring that the data received is the same as the data sent;<br/><em><strong>Error checking code</strong></em> – when an error is detected, an algorithm either corrects the error or requests that the packet is resent;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "17N.1.SL.TZ0.12",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline what is meant by <em>virtual memory</em>. </p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Virtual memory is a memory management capability of an OS;<br/>that (uses hardware and software to) allow a computer to compensate for physical memory shortages by temporarily transferring data from random access memory (RAM) to disk storage;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates provided the generally correct answers. Only a few were not able to outline the meaning of \"virtual memory\".</p>\n</div>",
|
||
"question_id": "19N.1.HL.TZ0.7",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A washing machine manufacturer has created its website to be viewed on standard desktop computers as well as mobile devices. The mobile browsing experience differs from desktop browsing.</p>\n</div><div class=\"specification\">\n<p>Different devices such as desktop computers and mobile devices have different operating systems.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>screen resolution</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> issues resulting from the website being viewed on various devices, such as desktops and smartphones.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the role of the operating system (OS) in terms of managing the hardware resources.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A washing machine uses a control system.</p>\n<p>The microprocessor controls the washing machine and its actions. To complete the wash and rinse process the user selects the program, loads the washing machine and pushes the start button.</p>\n<p>Describe the interaction between the sensors, microprocessors and output transducers in this situation.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>Screen resolution is the number of pixels a screen can display (horizontally and vertically). (For example, the screen can show 1024 pixels horizontally and 768 vertically);</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em><br/>Screens that are different sizes (for example, 3–6 diagonal inches for a phone, and 9–12 diagonal inches for a tablet, size of 13–17 inches for a notebook screen, and a desktop screen size of 20–30 inches);<br/>can still have the same screen resolution (for example, a laptop could have a 13-inch screen with a resolution of 1280 x 800 and a desktop computer could have a 17 inch monitor with the same 1280 x 800 resolution);<br/>but physically smaller screen will not show less of the website;<br/>the screen with the higher resolution will be able to show you more of the website because that screen has more pixels and the image will be sharper;<br/>but elements on the screen (icons and text) will look smaller;</p>\n<p>Most mobile displays currently have screens with fewer pixels than desktop displays and are physically smaller;<br/>typing on small on-screen keyboards is difficult;<br/>less precision (clicking a 12-pixel-high text link with a mouse is no problem but tapping the same link with fingers could be difficult);<br/>there is no mouse pointer so there is no concept of \"hovering\" over a page element/ remaining in an uncertain state;<br/>most modern touch screens allow zooming;<br/>allow the user to perform gestures using one or more fingers, such as swiping/pinching;</p>\n<p><em><strong>Note</strong>: Award marks not only for issues for a viewer but also for issues for a creator of the interface</em>.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em><br/>OS controls all the activities of computer system and acts as an interface between user and hardware;</p>\n<p><em>Thus the role of OS is</em><br/>to keep track of who is using which resource;<br/>to grant resource requests;<br/>to mediate conflicting requests from different users/programs;<br/>to allocate time to different programs or different users/ each one gets their turn to use that resource (for example printer);<br/>to allocate space for different users, each one gets a part of the resource (for example sharing main memory/ hard disk);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em><br/><em>Award <strong>[2 max]</strong> for evidence that</em>:<br/>Sensors (input devices) detect/measure the water level;<br/>sensors detect/measure the temperature (of the water);<br/>sensors detect/measure the dampness/moisture level of the clothes;<br/>sensors also detect movement of the machine's drum and other associated actions;</p>\n<p>Sensors continuously take readings/measurements (in the context of above) and send these readings to the processor;</p>\n<p><em>Award <strong>[2 max]</strong> for evidence that</em>:<br/>processor controls sensors, valves and actuators responsible for controlling the parts that clean clothes;<br/>processor determines what actions the machine should take next;<br/>the washing machine has been programmed/ it goes through a process of running its internal programs;</p>\n<p>processor compares readings with pre-set values (in the context of the various sensors);<br/>if the readings fall outside of the specified range, the processor sends a message to the output transducer to switch on/off ... (in the context of part of the washing machine);</p>\n<p><em>Award <strong>[2 max]</strong> for evidence that</em>:<br/>output transducers are used for turning on and off devices that control the rest of the machine;<br/>such as the motors that spin the tub;<br/>or the water pump;</p>\n<p>Example:<br/>once the start button is pushed the washing machine begins to dump water into the drum, a sensor will detect that the water level has been reached;<br/>based on the setting, the processor will allow the water to flow only to a predetermined level;<br/>it will send the signal to output transducers to shut off the water;<br/>and begin the agitation process;<br/>once the timer tells that it is time, processor sends signal to output transducer to stop agitating;<br/>it then begins the spin process/ removing the dirty water from the machine at the end of the spin cycle, the washing machine's processor sends signal to turn on the water pump and sucking it out of the machine;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Mostly a well answered question.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Mostly a well answered question.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates mostly gave good responses for this question.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A wide variety of answers and quality of answers was seen for this question covering the full mark range. Candidates who were able to fully describe the interaction between the sensors, microprocessors and output transducers and the steps involved generally scored quite highly.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19N.1.HL.TZ0.11",
|
||
"topics": [
|
||
"topic-6-resource-management",
|
||
"topic-7-control"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management",
|
||
"topic-7-1-control"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Trucking On</em>, a logistics and haulage company based in Marseille, France, keeps track of its lorries and operations in a database.</p>\n<p>Lorries are made up of the truck and a trailer. Trucks are usually coupled with the same trailer but sometimes trailers are moved to a different truck for part of the year.</p>\n<p>Each driver only uses one truck.</p>\n</div><div class=\"specification\">\n<p>The following LORRY table shows information about the lorries.</p>\n<p><img src=\"\"/></p>\n<p>Trailer space is measured in cubic metres.</p>\n<p>The table can also be represented as:</p>\n<pre>LORRY (TruckID, Truckmake, Energysource, Driver, Tel, TrailerID,<br/>Trailerspace, Coupled_from, Coupled_to)</pre>\n</div><div class=\"specification\">\n<p>The table has been split into two tables following the rules of normalization. The resulting two tables are shown with the primary key underlined:</p>\n<pre>LORRY (<span style=\"text-decoration: underline;\">TruckID</span>, Truckmake, Energysource, Driver, Tel)<br/><br/>TRAILER (<span style=\"text-decoration: underline;\">TrailerID</span>, Trailerspace, Coupled_from, Coupled_to, TruckID)</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> characteristics that make a database unnormalized.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why data redundancy may be a problem in the LORRY table.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the steps to create a query to find the names and telephone numbers of the drivers who drive lorries that have more than 60 cubic metres of trailer space.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Normalize the database to 3NF. Use the same format as shown, ensuring that primary keys are clearly indicated by underlining them.</p>\n<div class=\"marks\">[7]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Note: Allow answers that refer to any stage of normalisation</em>.<br/>Each data item hasn’t be broken down any further / contains repeating data;<br/>Each row is not unique / does not contain a primary key;<br/>Each field/column does not have a unique name / does not have atomic values;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>This would mean that data is duplicated within a table / allow an example of duplicated data in this table;<br/>However, when it is updated, it may not be updated in all cases;<br/>Which could lead to anomalies within the data and the incorrect information being used;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for all relevant tables selected (Lorry and Trailer);</em><br/><em>Award <strong>[1]</strong> for all relevant fields selected (Driver and Tel);</em><br/><em>Award <strong>[1]</strong> for correct condition;</em><br/><em>Award <strong>[1]</strong> for correct link between tables;</em></p>\n<p>SELECT Driver, Tel<br/>FROM Lorry INNER JOIN Trailer<br/>ON Trailer.TrailerID = Lorry.TrailerID<br/>WHERE TRAILERSPACE > 60;</p>\n<p><em>Accept logically equivalent answers written in English or a Data Manipulation Language</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[7 max]</strong></em>. <br/><em>Award marks as follows</em>:<br/>Separate, correct DRIVER table;<br/>FK links Driver to TRUCK table (driver always drives same truck);<br/>New “journey” table created — called JOURNEY in examples below;<br/>JOURNEY PK either a new JourneyID field, or a composite key as shown below;<br/>Correct FK links to TRUCK and TRAILER tables in JOURNEY table;<br/>Coupled.to and Coupled_from in correct table;<br/>TRAILER table + PK correct;</p>\n<p>DRIVER (<span style=\"text-decoration:underline;\">Driver</span>, Tel)<br/>TRUCK (<span style=\"text-decoration:underline;\">TruckID</span>, Truckmake, Energysource, Driver)<br/>JOURNEY (<span style=\"text-decoration:underline;\">TruckID, TrailerID, Coupled_from</span>, Coupled_to)<br/>TRAILER (<span style=\"text-decoration:underline;\">TrailerID</span>, Trailerspace)</p>\n<p>DRIVER (<span style=\"text-decoration:underline;\">Driver</span>, Tel)<br/>TRUCK (<span style=\"text-decoration:underline;\">TruckID</span>, Truckmake, Energysource, Driver)<br/>JOURNEY Journey <span style=\"text-decoration:underline;\">ID</span>, TruckID, TrailerID, Coupled_from, Coupled_to)<br/>TRAILER (<span style=\"text-decoration:underline;\">TrailerID</span>, Trailerspace)</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a memory recall question, where many candidates were able to identify at least one characteristic of unnormalized databases. However, many others were not prepared for this question.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was connected to a given scenario. Successful candidates were able to provide examples of redundant data affecting the given table, but just few candidates were able to outline consequences.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to get the basic structure of the query though some of them could not set the two tables and their relationship properly while writing the query. Also, many candidates provided generic answers failing to provide the necessary details (fields, tables, conditions) to answer the query.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates seemed unprepared for this question, most of them were not able to correctly split the table, identify the relationships and in many cases did not identify primary keys (this being explicitly required in the wording of the question).</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.3",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A bus company provides services within a city. Passengers can look up the distance between any two bus stations on any of its routes.</p>\n<p>For each route, a one-dimensional string array is used to store the names of all bus stations on the route and a two-dimensional array is used to store the distances between the bus stations (in kilometres). Only the lower triangle of the two-dimensional array is used to store the distances.</p>\n<p><strong>Figure 1</strong> shows data about Route X, a bus route between Oppox and Dovely.</p>\n<p style=\"text-align: center;\"><strong>Figure 1: One-dimensional string array, <code>ROUTE_X_NAMES</code>, and</strong><br/><strong>two-dimensional array, <code>ROUTE_X_DISTANCES</code>, for Route X</strong></p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p>For example, the distance between Kingsley and Kronos (2.0 kilometres) can be found in <code>ROUTE_X_DISTANCES [7][5]</code>.</p>\n</div><div class=\"specification\">\n<p>The two-dimensional array <code>ROUTE_X_DISTANCES</code> is valid if all the entries on and above the main diagonal are zero and all the entries below the main diagonal are greater than zero.</p>\n<p><strong>Figure 2</strong> shows an invalid form of <code>ROUTE_X_DISTANCES</code>.</p>\n<p style=\"text-align: center;\"><strong>Figure 2: Invalid form of two-dimensional array <code>ROUTE_X_DISTANCES</code></strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the distance between Kiko and Longlines.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm in pseudocode that checks the elements of the array <code>ROUTE_X_DISTANCES</code> and outputs whether the array is valid or not.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm in pseudocode that inputs the names of two bus stations and outputs the distance between them. If any of the inputted names are not found, the method should output an appropriate message.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The array <code>ROUTE_X_TIMES</code> (<strong>Figure 3</strong>) stores the approximate number of minutes it takes for a bus to travel to a bus station from the previous one. For example, <code>ROUTE_X_TIMES [6]</code> stores the number of minutes it takes for a bus to travel from Kingsley to Allapay: 7 minutes.</p>\n<p style=\"text-align:center;\"><strong>Figure 3: The array <code>ROUTE_X_TIMES</code></strong></p>\n<p style=\"text-align:center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align:left;\">Explain how this data could be used to determine the number of minutes it takes for a bus to travel between any two bus stations.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>5.9;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for correct outer/row loop</em><br/><em>Award <strong>[1]</strong> for correct inner/column loop</em><br/><em>Award <strong>[1]</strong> for use of a flag</em><br/><em>Award <strong>[1]</strong> for checking whether all elements on and above the main diagonal are zero</em><br/><em>Award <strong>[1]</strong> for checking all elements below the main diagonal (they all should be positive numbers)</em><br/><em>Award <strong>[1]</strong> for outputting the appropriate message</em></p>\n<p><span style=\"text-decoration:underline;\">Example 1</span>:</p>\n<pre>VALID=True<br/>loop R from 0 to 9<br/> loop C from 0 to 9<br/> if R>C and ROUTE_X_DISTANCES[R][C]<=0<br/> then VALID=False<br/> end if<br/> if R<=C and ROUTE_X_DISTANCES[R][C]!=0<br/> then VALID=False<br/> end if<br/> end loop<br/>end loop<br/>if VALID<br/> then output('VALID')<br/> else output('INVALID')<br/>end if</pre>\n<p><span style=\"text-decoration:underline;\">Example 2</span>:</p>\n<p><code>FLAG=1</code><br/><code>loop R from 1 to 9</code><br/><code> loop C from 0 to R-1</code><br/><code> if ROUTE_X_DISTANCES[R][C]<=0</code><br/><code> then FLAG=0</code><br/><code> end if</code><br/><code> end loop</code><br/><code>end loop</code><br/><code></code></p>\n<p><code>loop R from 0 to 9</code><br/><code> loop C= from R to 9</code><br/><code> if ROUTE_X_DISTANCES[R][C]!=0</code><br/><code> then FLAG=0</code><br/><code> end if</code><br/><code> end loop</code><br/><code>end loop</code><br/><code>if FLAG ==1</code><br/><code> then output('IT IS VALID')</code><br/><code> else output('IT IS NOT VALID')</code><br/><code>end if</code></p>\n<p><span style=\"text-decoration:underline;\">Example 3</span>:</p>\n<p><em><strong>Note</strong>: Marks should also be awarded if a candidate wrote the algorithm in Java/Python/Javascript.</em></p>\n<p><em>Award [1] for correct outer/row loop</em><br/><em>Award [1] for correct inner/column loop</em><br/><em>Award <strong>[1]</strong> for stopping as soon as an incorrect value is found</em><br/><em>Award <strong>[1]</strong> for checking whether elements on and above the main diagonal are zero</em><br/><em>Award <strong>[1]</strong> for checking elements below the main diagonal (they all should be positive numbers)</em><br/><em>Award<strong> [1]</strong> for outputting the appropriate message</em></p>\n<pre>function check()<br/><br/>{ for (var i=0; i<10; i++)<br/> { for (var j=0; j<10; j++)<br/> { if (i>j)<br/> { if (ROUTE_X_DISTANCES[i][j] <= 0.0) return \"invalid\";<br/> }<br/> else if (ROUTE_X_DISTANCES[i][j] != 0.0 ) return \"invalid\";<br/> }<br/> }<br/> return \"valid\";<br/>}<br/><br/>output(\"ROUTE_X_DISTANCES is \"+check());</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for all variables correctly declared and initialized;</em><br/><em>Award <strong>[1]</strong> for looping through the array ROUTE_X_NAMES;</em><br/><em>Award <strong>[1]</strong> for determining positions of the first name in the array;</em><br/><em>Award <strong>[1]</strong> for determining positions of the second name in the array;</em><br/><em>Award <strong>[1]</strong> for outputting a message if one or other not present;</em><br/><em>Award <strong>[1]</strong> for a comparison of positions to find largest;</em><br/><em>Award <strong>[1]</strong> for the correct output of distance from ROUTE_X_DISTANCES;</em></p>\n<p><span style=\"text-decoration:underline;\">Example 1</span>:</p>\n<pre>NAME1=input()<br/>NAME2=input()<br/>POS1=-1<br/>POS2=-1<br/>K=0<br/>loop while K<=9 and (POS1==-1 or POS2==-1)<br/> if ROUTE_X_NAMES [K].equals(NAME1) //accept '==' instead of equals()<br/> then POS1=K<br/> end if<br/> if ROUTE_X_NAMES [K].equals(NAME2)<br/> then POS2=K<br/> end if<br/> K=K+1<br/>end while<br/>if POS1==-1 OR POS2==-1<br/> then output('stations are not found')<br/> else<br/> if POS1 > POS2<br/> then output(ROUTE_X_DISTANCES [POS1][POS2])<br/> else output(ROUTE_X_DISTANCES [POS2][POS1])<br/> end if<br/>end if</pre>\n<p><span style=\"text-decoration:underline;\">Example 2</span>:</p>\n<pre>ST1=input()<br/>ST2=input()<br/>PS1=-1<br/>PS2=-1<br/>loop K from 0 to 9<br/> if ROUTE_X_NAMES [K]==ST1<br/> then PS1=K<br/> end if<br/> if ROUTE_X_NAMES [K]==ST2<br/> then PS2=K<br/> end if<br/>end loop<br/>if PS1!=-1 AND PS2!=-1<br/> then if PS1 < PS2<br/> then T=PS1<br/> PS1=PS2<br/> PS2=T<br/> end if<br/> output(ROUTE_X_DISTANCES [PS1][PS2])<br/> else<br/> output('stations not found')<br/>end if</pre>\n<p><span style=\"text-decoration:underline;\">Example 3</span>:</p>\n<p><em><strong>Note</strong>: Award marks if algorithm is presented in a Java/Python/Javascript/any other program rather than IB pseudocode.</em><br/><em>For example, please see the following Javascript program</em></p>\n<pre>function findStation(station)<br/>{ var found = false;<br/> var i = 0;<br/> do<br/> { found = (ROUTE_X_NAMES[i] == station);<br/> if (!found) i = i + 1;<br/> } while (!found && i < 10);<br/> if (found) return i;<br/> else<br/> { output(\"No such bus station as \"+station);<br/> return -1;<br/> }<br/>}<br/><br/><br/><br/><br/>var station1 = input();<br/>var station2 = input();<br/>output(\"Finding the distance between \"+station1+\" and \"+station2);<br/>var station1index = findStation(station1);<br/>var station2index = findStation(station2);<br/>if (station1index >=0 && station2index >= 0)<br/> { if (station1index >= station2index)<br/> output(\"Distance \"+ROUTE_X_DISTANCES[station1index][station2index]);<br/> else<br/> output (\"Distance = \"+ROUTE_X_DISTANCES[station2index][station1index]);<br/>}</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Determine positions/indexes/subscripts of both bus stations in array ROUTE_X_NAMES;</p>\n<p>Calculate the sum of the elements of array ROUTE_X_TIMES (calculate the number of minutes as the sum of the array elements);</p>\n<p>Between (lower +1) index and higher index;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The majority of students attempted it, and many got it right.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Algorithms were required based on the question scenario. Some candidates did not attempt these questions. Some candidates achieved high marks by demonstrating good programming skills. Many candidates scored several marks for the construction of a partial solution or a solution that was partially correct.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Algorithms were required based on the question scenario. Some candidates did not attempt these questions. Some candidates achieved high marks by demonstrating good programming skills Many candidates scored several marks for the construction of a partial solution or a solution that was partially correct.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Varied from poor to excellent.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "21N.1.HL.TZ0.13",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A transport authority is investigating how many people use a certain direct train route.</p>\n<p>At the end of each day, the total number of passengers who travelled on this route is stored in a collection, <code>PASSENGERS</code>.</p>\n<p>The first item was written to the collection on Monday 1st May 2017.</p>\n<p><img src=\"\"/></p>\n<p>The next items, collected on Tuesday and Wednesday, were added like this:</p>\n<p><img src=\"\"/></p>\n<p>Data for 30 complete weeks was added to the collection.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct pseudocode that will read <code>PASSENGERS</code> into the two-dimensional array, <code>2D_ARRAY</code>.</p>\n<p><img src=\"\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the pseudocode for the procedure <code>total</code>, that takes as input a column number of this two-dimensional array and returns the sum of the elements in that column.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The transport authority wishes to know how many passengers, on average, travel on each day of the week.</p>\n<p>Using the procedure <code>total</code> construct the pseudocode to output the day of the week with the highest average number of passengers, and the value of this average.</p>\n<p>You should make use of the sub procedure <code>convert()</code> which converts the numbers 0 to 6 into days of the week, for example <code>convert(1)</code> will return “Tuesday”.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The transport authority stores details about the ticket prices in a one-dimensional array, <code>FEES</code>, where <code>FEES[0]</code> contains the price of a ticket for Monday to Friday, while <code>FEES[1]</code> contains the price of a ticket for Saturday and Sunday.</p>\n<p>The procedure <code>salesCalculate()</code> takes as input the column and row indices that define two specific days during the 30 weeks, and outputs the total amount of money generated from ticket sales between those two days (inclusive).</p>\n<p>Construct, in pseudocode, the procedure <code>salesCalculate()</code>.</p>\n<div class=\"marks\">[7]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4]</strong> as follows</em>.</p>\n<p><span style=\"text-decoration:underline;\"><em>Example answer 1</em></span>:<br/>Assumes that an array of sufficient size is declared (<code>2D_ARRAY[][]</code>) and <code>PASSENGERS</code> contains valid data for all 7 days in each of 30 weeks.</p>\n<pre>PASSENGERS.resetNext()<br/>N = 0<br/>loop while PASSENGERS.hasNext()<br/> //accept not PASSENGERS.isEMPTY()<br/> //accept N<PASSENGERS.length()<br/> WEEK = N div 7<br/> DAY = N mod 7<br/> 2D_ARRAY[WEEK][DAY] = PASSENGERS.getData() // PASSENGERS.getNext()<br/> N=N+1<br/>end loop</pre>\n<p><em>Award <strong>[1]</strong> for while loop.</em><br/><em>Award <strong>[1]</strong> for correct calculation of row index(WEEK).</em><br/><em>Award <strong>[1]</strong> for correct calculation of column index(DAY).</em><br/><em>Award <strong>[1]</strong> for correct array subscripts.</em><br/><em>Award <strong>[1]</strong> for correct use of collection methods.</em></p>\n<p><em><span style=\"text-decoration:underline;\">Example answer 2</span>:<br/></em>Assumes that an array of a sufficient size is declared (<code>2D_ARRAY[][]</code>) and <code>PASSENGERS</code> contain valid data for all 7 days in each of 30 weeks.</p>\n<pre>PASSENGERS.resetNext()<br/>loop for WEEK from 0 to 29<br/> loop for DAY from 0 to 6<br/> 2D_ARRAY[WEEK][DAY] = PASSENGERS.getNext()//PASSENGERS.getData()<br/> end loop<br/>end loop</pre>\n<p><em>Award <strong>[1]</strong> for nested loops.</em><br/><em>Award <strong>[1]</strong> for loops that generate the right output (correctly read <code>PASSENGERS</code> into <code>2D_ARRAY</code>).</em><br/><em>Award <strong>[1]</strong> for assignment into correct array location.</em><br/><em>Award <strong>[1]</strong> for correct use of collection methods</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<pre>total (N)<br/>// if N (column number) is not passed as an input parameter then<br/>// assignment must appear in pseudocode, for example, N = input()<br/> SUM = 0<br/> loop for WEEK from 0 to 29<br/> SUM = SUM + 2D_ARRAY[WEEK][N]<br/> end loop<br/> return SUM<br/>end total</pre>\n<p><em>Award <strong>[1]</strong> for assigning the input to a variable / passing the value of <code>N</code>.</em><br/><em>Award <strong>[1]</strong> for initializing and returning/outputting <code>SUM</code>.</em><br/><em>Award <strong>[1]</strong> for correct loop.</em><br/><em>Award <strong>[1]</strong> for correct addition of each term to <code>SUM</code>. (<strong>Note</strong>: The array position must be completely correct with the input column and the varied row.)</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<pre>MAXAV = 0<br/>MAXDAY = \"\"<br/>loop for DAY from 0 to 6<br/> if total(DAY)/30 > MAXAV<br/> MAXAV = total(DAY)/30<br/> MAXDAY = convert(DAY)<br/> end if<br/> end loop<br/>output MAXAV,MAXDAY</pre>\n<p><em>Award <strong>[1]</strong> for correct loop.</em><br/><em>Award <strong>[1]</strong> for use of method total() when calculating the average number of passengers.</em><br/><em>Award <strong>[1]</strong> for initializing, updating and outputting/returning <code>MAXAV</code> and <code>MAXDAY</code></em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<pre>salesCalculate(2D_ARRAY, A, B, X, Y)<br/>// A,B are row & column of first day,<br/>// X,Y are row & column of last day.<br/><br/>TOTAL = 0<br/><br/>loop for COL= B to 6<br/> if COL < 5 then<br/> TOTAL = TOTAL + 2D_ARRAY[A][COL] * FEES[0]<br/> else<br/> TOTAL = TOTAL + 2D_ARRAY[A][COL] * FEES[1]<br/> end if<br/>end loop<br/> //calculates total for week A,<br/> //days are in the range from B to 6<br/> //weekdays are days 0-4, and weekend 5,6<br/><br/>loop for ROW = A + 1 to X - 1<br/> loop for COL= 0 to 6<br/> if COL < 5 then<br/> TOTAL = TOTAL + 2D_ARRAY[ROW][COL]*FEES[0]<br/> else<br/> TOTAL = TOTAL + 2D_ARRAY[ROW][COL]*FEES[1]<br/> end if<br/> end loop<br/>end loop<br/> //calculates total for all weeks from A+1 to X-1,<br/> //days are in the range from 0 to 6<br/><br/>loop for COL= 0 to Y<br/> if COL < 5 then<br/> TOTAL = TOTAL + 2D_ARRAY[X][COL]*FEES[0]<br/> else<br/> TOTAL = TOTAL + 2D_ARRAY[X][COL]*FEES[1]<br/> end if<br/>end loop<br/> //calculates total for week X,<br/> //days are in the range from 0 to Y<br/><br/>output TOTAL<br/>end salesCalculate</pre>\n<p><em>Award <strong>[7 max]</strong>.</em><br/><em>Award <strong>[1]</strong> for initializing, updating and outputting TOTAL.</em><br/><em>Award <strong>[1]</strong> for nested loops.</em><br/><em>Award <strong>[1]</strong> for correct calculation of <code>TOTAL</code> in row/week A (column subscripts/days/ in <code>2D_ARRAY</code> must be in range B to 6).</em><br/><em>Award <strong>[1]</strong> for correct calculation of <code>TOTAL</code> in row/week X (column subscripts/days/ in <code>2D_ARRAY</code> must be in range 0 to Y).</em><br/><em>Award <strong>[1]</strong> for correct calculation of <code>TOTAL</code> in rows/weeks from A + 1 to X – 1 (column subscripts/days/ in <code>2D_ARRAY</code> must be in range 0 to 6).</em><br/><em>Award <strong>[1]</strong> if evident that the number of days to be included in calculating total amount is different for weeks A + 1 to X – 1, week A and X (three different cases).</em><br/><em>Award <strong>[2]</strong>, <strong>[1]</strong> for checking for weekdays / weekend and <strong>[1]</strong> for using correct subscript in FEE (0 for weekdays, 1 for weekend).</em></p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18M.1.HL.TZ0.15",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following recursive method, where <code>N</code> is a positive integer</p>\n<pre>mystery(N)<br/> if (N > 0) AND (N mod 2 = 0) then<br/> mystery(N−2)<br/> end if<br/> output N<br/>end mystery</pre>\n</div><div class=\"question\">\n<p>Determine the output produced by the method call <code>mystery(4)</code>.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award up to <strong>[3]</strong> as follows</em>:<br/><em><strong>[3]</strong> for fully correct response (sequence of output) “0;2;4”</em>;<br/><em><strong>[2]</strong> for response (sequence) “4;2;0” (all elements are correct, but they are in inverse order)</em>;<br/><em><strong>[1]</strong> for response ”0” (only base case is correct)</em>;<br/><em><strong>OR</strong></em><br/><em>“0;2” (incomplete output, but initially correct, and with correct order)</em>;<br/><em><strong>OR</strong></em><br/><em>“–2;0;2;4”,“0;2;4;6” (correct sequence immersed in some unnecessary and incorrect context)</em>;</p>\n<p><em><strong>[0]</strong> in all other cases (e.g. responses “2”, “4”, “2;0”, “2;4”, “4;2”)</em>;</p>\n<p>0<br/>2<br/>4</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "17N.1.HL.TZ0.6",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An application package used in an office includes a word processor.</p>\n</div><div class=\"specification\">\n<p>The office manager decides to buy and install new software and hardware.</p>\n</div><div class=\"specification\">\n<p>The changeover to the new system can be achieved by either direct changeover or phased conversion.</p>\n</div><div class=\"specification\">\n<p>The new software allows basic text summaries and analysis to help check text files, including functions such as calculating word frequency.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how a spellchecker checks whether a word in a text file is correctly spelt or not.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> problem that may arise from the installation of new hardware and software in the office.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare direct changeover and phased conversion.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> way of testing this software.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Each word in the text file is compared with words in a <span style=\"text-decoration:underline;\">dictionary</span> (held in memory/online);<br/>If the word is found in the dictionary it is correctly spelt / if the word is not found in the dictionary, spellchecker will recognize that it is incorrectly spelt;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for stating a problem and <strong>[1]</strong> for an elaboration, up to <strong>[2 max]</strong></em>.<br/>Users/employees might be afraid of these changes (for various reasons);<br/>And not willing to help in this change;</p>\n<p>Data migration problems;<br/>For example, different file formats so conversion must be performed;</p>\n<p>Employee efficiency may drop;<br/>As they learn to use the new system;</p>\n<p>Issue of compatibility with legacy software/hardware;<br/>So features of new software/hardware may not work correctly;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for outlining what is meant by direct changeover, <strong>[1]</strong> for outlining what is meant by phased conversion, and then <strong>[1]</strong> for an advantage or disadvantage<strong> of each</strong>, up to <strong>[4 max]</strong></em>.</p>\n<p><em><strong>Example answer</strong></em><br/>In direct changeover, the old software and hardware is completely replaced, in one move, by the new software and hardware;<br/>Phased conversion involves selecting one section in the office for the direct changeover and other sections will be switched when the first section selected is running satisfactorily. Eventually the whole office has been changed;<br/>A phased conversion is less risky than a direct changeover as any problems that might arise will be isolated in only one section in the office;<br/>Direct changeover means everyone in the organization has same software/hardware and so there are no compatibility issues;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>Debugging (<em><strong>Accept</strong></em>: white-box testing – i.e. structural testing/flow testing;<br/>black-box testing / requirement testing);<br/>User acceptance testing (alpha-testing) / Beta-testing;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "17N.1.HL.TZ0.10",
|
||
"topics": [
|
||
"topic-2-computer-organization",
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization",
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Investment planning is something that many people need to be aware of. Planning for your future requires research because bad choices can be very costly.</p>\n<p>Interest paid on money invested is usually in the form of compound interest. The formula to calculate compound interest is:</p>\n<p><math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>T</mi><mo>=</mo><mi>P</mi><mo> </mo><mo>*</mo><mo> </mo><mo>(</mo><mn>1</mn><mo> </mo><mo>+</mo><mo> </mo><mi>r</mi><msup><mo>)</mo><mi>n</mi></msup></math></p>\n<p><strong>T</strong> is the total value of the investment,<br/><strong>P</strong> is the principal sum invested,<br/><strong>r</strong> is the interest rate per time period converted to a decimal (for example, 5 % is 0.05),<br/><strong>n</strong> is the number of time periods.</p>\n</div><div class=\"specification\">\n<p>An additional $1000 is added to a principal amount of $30 000 at the end of each month.<br/>The monthly interest rate is 0.5 % and this rate is compounded at the end of each month.</p>\n</div><div class=\"specification\">\n<p>Each month, tax is calculated on the monthly profit at a rate of 25 % when the investment total (T) is $40 000, or below. However, when the investment total (T) is above $40 000, the tax rate is 40 %.</p>\n<p>The tax is calculated at the end of each month after interest has been added. A running total of the tax is kept and only deducted from the investment total (T) at the end of the year.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Calculate the total value of the investment after two years if the principal sum of $30 000 is invested. The yearly interest rate is 10 % and this rate is compounded at the end of each year.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline, using a diagram or otherwise, a method of calculating the total value of the investment after 12 months.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm to calculate the fund value at the end of each month. This algorithm should also calculate the total value of the investment after the tax has been deducted after 12 months.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Many investment companies offer alternative investment schemes and use modelling to set the rates of interest.</p>\n<p>Explain why the investment company would use modelling when setting the rates of interest.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>36300;<br/>if interest only award<strong> [1 mark max]</strong>, $6300;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/><em>Award <strong>[1]</strong> Initial investment 30000 for month 0;</em><br/><em>Award <strong>[1]</strong> Investment 1000 each month;</em><br/><em>Award <strong>[1]</strong> Interest rate of 0.005 * Principal</em><br/><em>Award <strong>[1]</strong> Calculate compound interest for 12 months;</em><br/><em>Award <strong>[1]</strong> Add interest to the investment;</em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><strong><em>An array does not need to be used to obtain full marks</em></strong>.</p>\n<p><em>Award <strong>[1]</strong> Create array or variables / initialise array or variables / P[0] = 30 000;</em><br/><em>Award <strong>[1]</strong> Create interest rate and assign it to 1.005;</em><br/><em>Award <strong>[1]</strong> Calculate interest;</em><br/><em>Award <strong>[1]</strong> Add interest and 1000 to each month;</em><br/><em>Award <strong>[1]</strong> If statement to determine the correct tax rate;</em><br/><em>Award <strong>[1]</strong> Output investment - tax;</em></p>\n<p><img src=\"\"/></p>\n<p><em>Alternative solution without an array</em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>A what if scenario can be employed;<br/>A mathematical model will allow you to adjust variables to see what impact that will have on the investment;<br/>You can see exactly what is happening to the money each month; <br/>If the client decides to pay in less or more money for a given month you can see what affect this will have on the profits;<br/>If the interest rate changes, you will be able to see what changes this has on profit;<br/>If the tax rate changes you can see how this affects the investment profits.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.4",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>State <strong>two</strong> compatibility issues that may arise when international businesses merge.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Language differences / lexical differences present across datasets to be merged;<br/>Data representation differences / different data structures (e.g., date format, incompatible file formats);<br/>Incompatible hardware;<br/>Incompatible operating systems / different software versions;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were generally able to state at least one compatibility issue related to the merging of international business systems. Some candidates lost out by naming two issues that were too similar, so therefore covering the same marking point.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.1",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline <strong>one</strong> reason why accurate user documentation is necessary for a system.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>User efficiency;<br/>To ensure that users know how to use the system correctly;</p>\n<p>Support/Troubleshoot;<br/>To provide users help when they encounter errors;</p>\n<p>Accuracy;<br/>To ensure the correct methods are used to enable reliable output;</p>\n<p>Improved user experience;<br/>the user is aware of all available features, so they can make the most out of the system;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were able to identify a reason why accurate user documentation is necessary for a system. A few candidates mixed this up with system documentation. Some candidates also named two reasons rather than expanding on the one reason, as required by the question.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.2",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following binary tree.</p>\n<p>An inorder traversal of this binary tree will produce a list of names sorted in ascending order.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>two</strong> applications of stacks.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the use of a one-dimensional array as a static stack. Your answer should include brief outlines of the push and pop operations and the tests for empty and full stacks. </p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the result of postorder traversal.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Draw the binary tree after deleting the root node.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare the use of static and dynamic data structures.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Holding all data of a function/method call; simulation of recursion;<br/>Conversion of expressions (infix to postfix, infix to prefix, etc.)<br/>Evaluating expression;<br/>Parsing;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em><br/><em>Award <strong>[3 max]</strong> for the following</em>:<br/>An array A of N elements should be initialized (fixed, predetermined size);</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<p style=\"text-align:left;\">keep track of the top of the stack since not all of the array holds stack elements (in an integer variable, for example, named TOP);</p>\n<p style=\"text-align:left;\">the main property of a stack is that stack values/objects go on and come off of the one end of the stack (LIFO data structure);</p>\n<p style=\"text-align:left;\"><em>Award <strong>[1]</strong> for each stack method outlined</em>.</p>\n<p style=\"text-align:left;\"><em>Push</em><br/>Places a value (object) on the top of the stack;<br/>Increase TOP by one and set A[TOP]= value;</p>\n<p style=\"text-align:left;\"><em>Pop</em><br/>Returns a value from the top of the stack and removes that value from the top of the stack;<br/>Returns A[TOP] and decreases TOP by 1;</p>\n<p style=\"text-align:left;\"><em>IsEmpty</em><br/>Reports whether the stack is empty or not / returns True if the stack is empty, False otherwise;<br/>Returns True if TOP is less than 0, False otherwise;</p>\n<p style=\"text-align:left;\"><em>IsFull</em><br/>Reports whether the stack is full or not/ returns True is stack is full, False otherwise;<br/>Returns True if TOP is greater than N-1 (where N is size of the array), False otherwise;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max] </strong></em><em><strong><br/>The names must be in the following order:<br/></strong></em>Elm, Elder, Holly, Rowan, Larch, Hazel;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] </strong></em><em><strong><br/></strong>Award <strong>[1]</strong> for the correct root.<br/>Award <strong>[1]</strong> for the correct left subtree.<br/>Award <strong>[1]</strong> for the correct right subtree.<strong><br/></strong></em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em><br/>Static data structures are fixed sized (for example, arrays) whilst dynamic data structure (for example, trees, linked lists) have flexible size;</p>\n<p>The size of static data structures is predetermined; the amount of memory once allocated to them at compile time cannot change on run time whereas dynamic data structures they can grow or shrink as needed to contain the data to be stored;</p>\n<p>Slower access to elements of dynamic data structure (sequential access) when compared with (direct) access to elements of static data structures;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Mostly well answered questions.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not all candidates answered this question, but most of those who did outlined the push and pop operations and the tests for empty and full stacks. The use of a one-dimensional array as a static stack was weakly explained.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Mostly well answered.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Mostly well answered.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Mostly well answered.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19N.1.HL.TZ0.12",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Galaxy Bank</em> is a US based bank with many banks (branches) across the country. <em>Galaxy Bank</em> uses a relational database to support its operations.</p>\n<p>Each <strong>branch</strong> has many <strong>customers</strong> and each <strong>customer</strong> may take out a number of <strong>loans</strong>.</p>\n</div><div class=\"specification\">\n<p>Some of the data in the <strong>LOANS</strong> table is shown below.</p>\n<p>The underlined attribute indicates the primary key.</p>\n<p style=\"text-align: center;\"><strong>LOANS</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"specification\">\n<p>Two other tables in the database are identified below:</p>\n<ul>\n<li>The <strong>ACCOUNTS</strong> table contains the account details of the customers.</li>\n<li>The <strong>CUSTOMERS</strong> table contains the contact details of each customer.</li>\n</ul>\n<p>The underlined attribute indicates the primary key in each table.</p>\n<p style=\"text-align: center;\"><strong>ACCOUNTS</strong></p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: center;\"><strong>CUSTOMERS</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"specification\">\n<p>Security is the top priority for <em>Galaxy Bank</em>.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the entity relationship diagram (ERD) that shows the relationship between the bank branch, the customers and their loans.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the table <strong>LOANS</strong>, state the output of the following query:</p>\n<pre>SELECT LOANS.Loan_ID, LOANS.Customer_ID, LOANS.Amount, LOANS.Type<br/>FROM LOANS<br/>WHERE (LOANS.Amount > 600000) AND ((LOANS.Type = \"Home\") OR<br/>(LOANS.Type = \"Venture\"));</pre>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify the steps to create a query to find the names of customers whose account balance is greater than $300 000.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how controlling access rights contributes to the security of the <em>Galaxy Bank</em> database.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how row locking ensures the consistency of the data in the <em>Galaxy Bank</em> database.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><img src=\"\"/></p>\n<p>Bank, Customers and Loan correctly positioned;<br/>for EACH 1 to n relationship / for “has customers” and “has loans” (accept words to this effect);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><img src=\"\"/></p>\n<p><em>Award <strong>[1]</strong> for any two correct rows, <strong>[2]</strong> for all three rows correct</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[4 max]</strong></em>.</p>\n<p><em>Answers may include</em>:</p>\n<p>Step 1: From the table CUSTOMERS,ACCOUNTS;<br/>Step 2: Choose Family_name attribute;<br/>Step 3: For a condition of the Customer_ID matching in both the CUSTOMERS and ACCOUNTS table;<br/>Step 4: And also satisfying the condition of the Balance > 300 000;</p>\n<p>SELECT CUSTOMERS.Family_name, ACCOUNTS_Balance<br/>FROM CUSTOMERS INNER JOIN ACCOUNTS<br/>ON CUSTOMERS.Customer_ID = ACCOUNTS,Customer_ID<br/>WHERE ACCOUNTS.Balance > 300 000</p>\n<p><em>Award <strong>[1]</strong> for identifying the FamilyName.</em><br/><em>Award <strong>[1]</strong> for checking that Customer_ID matches.</em><br/><em>Award <strong>[1]</strong> for identifying the use of both CUSTOMERS and ACCOUNTS.</em><br/><em>Award <strong>[1]</strong> for balance check of greater than 300 000.</em></p>\n<p><em><strong>Note:</strong> SQL is not required.</em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.</p>\n<p><strong>Access control</strong>;<br/>This means that different users will have different levels of access to the <em>Galaxy Bank</em> database;<br/>Therefore customers will only be able to access the information that they require to carry out their transactions;<br/>Whereas other users such as the DBA will have access to more of the database;<br/>Ensuring that the sensitive information within the <em>Galaxy Bank</em> database is secure from unauthorized access, editing etc.;</p>\n<p><em><strong>Note:</strong> Do not accept responses pertaining to how access rights are granted</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.</p>\n<p>Row locking prevents two or more database users from updating the same data at the same time;<br/>When a row is locked it means that another database session cannot update that data until the lock is released (which unlocks the data and allows other database users to update that data;<br/>If the database as a whole is locked, then only one database session can apply any updates; Locks are done using statements;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.1",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Identify <strong>two</strong> differences between a wide area network (WAN) and a local area network (LAN).</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>WAN covers a much larger area (national/international), LANs usually cover a smaller area (such as a single site);<br/>Nodes connected to WANs often make use of connections through public networks (such as the telephone system), nodes connected to LANs are usually connected through private infrastructure;<br/>LANs are more secure than WANs (due to how WANs transmit the data /how far the data would need to travel);<br/>A higher bandwidth is available for transmission in a LAN than a WAN/ LANs can have a higher data transfer rate than a WAN;<br/>LAN is typically cheaper than WAN to implement/ maintain (as the equipment required for LAN is less expensive);<br/>WAN includes a large number of devices connected together, LAN includes less;<br/>WANs are typically slower than LANs due to the distance data must travel;<br/>WAN requires hardware to connect different networks, such as a router, LAN can be simple and does not need to connect to other networks;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were aware of the differences between wide area networks and local area networks, but often spent a long time writing a description that only covered one difference, rather than the two required by the question.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.3",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline the reason for compression when transmitting data.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>The reason for compression when transmitting data is to save on transfer times;<br/>As it reduces the number of bits needed to represent data (when compared with the original data);</p>\n<p>Compressing data involves modifying/restructuring files, so that they take up less space;<br/>And this results in cost savings in cloud storage;</p>\n<p>To take up less bandwidth;<br/>Because data compression reduces the size of files to be transmitted over a network;</p>\n<p><em>Note to examiners: Award <strong>[1]</strong> for a reason (for example, to save data usage for sending files over the internet, to save storage capacity, to speed up file transfer, to decrease costs for network bandwidth, etc.), and award <strong>[1]</strong> for an expansion.</em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were aware of a reason for the use of compression when transmitting data. Some candidates, however, directed their responses to generic reasons for compression, rather than the scenario of data transmission, as stated in the question.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.4",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following doubly linked list which holds the names of flowers in alphabetical order.</p>\n<p><img src=\"\" style=\"display: block; margin-left: auto; margin-right: auto;\"/></p>\n</div><div class=\"specification\">\n<p>Consider the two stacks: <code>FLOWERS</code> and <code>FRUITS.</code></p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the features of a dynamic data structure.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how <code>“Primrose”</code> could be inserted into this doubly linked list. You should draw a labelled diagram in your answer.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Show the output produced by the following algorithm.</p>\n<pre><code>loop while (NOT FRUITS.isEmpty()) AND (NOT FLOWERS.isEmpty())</code><br/><code> X = FRUITS.pop()</code><br/><code> Y = FLOWERS.pop()</code><br/><code> if X < Y then</code><br/><code> output </code><code>X</code><br/><code> else</code><br/><code> output Y</code><br/><code> end </code><code>if</code><br/><code>end </code><code>loop</code></pre>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A third stack, <code>FLOFRU</code>, is needed. It should contain all the data from <code>FLOWERS</code> and <code>FRUITS</code> and will store it as shown below</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<p style=\"text-align:center;\"> </p>\n<p>Describe how the <code>FLOFRU</code> stack could be created.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Each node contains data and also a link to other nodes;<br/>Links between nodes are implemented by pointers (a pointer references a location in memory or holds a memory address);<br/>List size is not fixed / predetermined;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[6 max]</strong> as follows. (There are 7 marking points)</em><br/><em><strong>[1]</strong> create new node;</em><br/><em><strong>[1]</strong> instantiation of values and pointers in new node;</em><br/><em><strong>[1]</strong> state where the search starts from;</em><br/><em><strong>[1]</strong> how to detect position for insertion;</em><br/><em><strong>[1]</strong> update pointers in new node;</em><br/><em><strong>[1]</strong> update pointers from the node at the insertion point, to the new node;</em><br/><em><strong>[1]</strong> update external pointers;</em><br/><em><strong>Remark</strong>: Some answers may just use illustrations alone, or very minimal explanations: see </em><em>note below;</em></p>\n<p>Create a new node (with pointer <code>NEWNODE</code>) with data field Primrose and two pointer fields (next and previous), to be inserted;</p>\n<p>Perform a linear search, either from the beginning or end of the list (using pointers <code>FIRST</code> and <code>LAST</code>, on the alphabetically order list;</p>\n<p>The location/position of insertion, is found by comparing nodes (Primrose to be inserted after Lavender, <code>LOCATION</code> points to Lavender) <em>(<strong>Accept</strong> any description to that effect)</em>;</p>\n<p>(<em>At the end of this phase, the situation looks as in <strong>Figure 1</strong></em>)</p>\n<p><em><strong>Figure 1</strong></em><em><strong><img src=\"\"/></strong></em></p>\n<p>Then, continue by setting the “next” field/pointer in the newly created node to <code>NULL</code>;</p>\n<p>Set the “previous” pointer in the newly created node to the current <code>LAST</code> / to point to Lavender/ to point to the node detected by <code>LOCATION</code>;</p>\n<p>Change/Set/Update the Lavender’s “next” pointer to point to the new node / to link with the <code>NEWNODE</code> pointer (delete <code>NULL</code> in the field and link to the existing <code>NEWNODE</code> pointer);</p>\n<p>Update the <code>LAST</code> pointer to point to the newly created node;</p>\n<p>Eventually the final doubly linked list looks like this (<strong>Figure 2</strong>);</p>\n<p><strong>Figure 2</strong></p>\n<p><strong><img src=\"\"/></strong></p>\n<p><em><strong>Note</strong>: Award<strong> [4 max] </strong>for responses that return one or more drawings without any explanation at all, for evidence of these features</em>:<strong><br/><em>[1] </em></strong><em>Evidence of creation of an initial new node for Primrose out of the list;<strong><br/>[1] </strong>The order of nodes Aster/Camellia/Lavender/Primrose is eventually correct;<strong><br/>[1] </strong>The two unidirectional links between Lavender and Primrose are (eventually) correctly displayed, from-to the appropriate fields;<strong><br/>[1] </strong>LAST points correctly to the appropriate field in the new node Primrose, <strong>and</strong> NULL fills the last field of the new node;</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each one in the correct order</em>.<br/>Apple;<br/>Broom;<br/>Camellia;<br/>Day Lily;</p>\n<p><strong>Note</strong>: Solution for the Spanish version (in this order):<br/>Aster; Camelia; Lavanda; Lirio;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award marks as follows up to <strong>[3 max]</strong></em>.</p>\n<p><em><strong>Example answer 1</strong></em><br/>Create an empty stack <code>(FLOFRU)</code>;<br/><strong>pop</strong> all elements from <code>FRUITS</code> and <strong>push</strong> them onto <code>FLOFRU</code>;<br/>Then <strong>pop</strong> all elements from <code>FLOWERS</code> and <strong>push</strong> them onto <code>FLOFRU</code>;</p>\n<p><em><strong>Example answer 2</strong></em><br/>Create an empty stack (<code>FLOFRU</code>);<br/>While <code>FRUITS</code> is not empty<br/><strong> pop</strong> an element from <code>FRUITS</code> and <strong>push</strong> it onto <code>FLOFRU</code>;<br/>While <code>FLOWERS</code> is not empty<br/><strong> pop</strong> an element from <code>FLOWERS</code> and <strong>push</strong> it onto <code>FLOFRU</code>;</p>\n<p><em><strong>Note</strong>: Award <strong>[2 max]</strong> for generic descriptions that do not use appropriate terminology on data structures and their operations</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "17N.1.HL.TZ0.13",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A supermarket chain has identified four potential locations to build a distribution centre. The distribution centre will store goods and distribute them to a large number of supermarkets in the region.</p>\n<p>A computer simulation will be run to determine the best location to build the distribution centre.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> reasons for using a computer simulation in this scenario.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> data inputs for this computer simulation model.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> criteria that may be used to determine the best location to build the distribution centre.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Discuss how the simulation model will use the data inputs in (b)(i) and the criteria identified in (b)(ii) to generate recommendations.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why the use of a computer simulation may not be beneficial.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 mark]</strong> for reason and <strong>[1 mark]</strong> for expansion <strong>[4 marks max]</strong></em>.<br/>Cost;<br/>Building a distribution centre is expensive so it is impractical to build four centres to see which one is the best location / build the centre in a poor site location;</p>\n<p>Time;<br/>The time to build and run the simulation is much less than building a distribution centre;</p>\n<p>Amendments to input data / extra variables added;<br/>The simulation could be adjusted to factor in unforeseen variables / run worst case scenario e.g. roadworks, changes in traffic congestion, new housing being built in the area;</p>\n<p><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Road networks to and from the distribution sites;<br/>Location of the supermarkets / distance to the supermarkets;<br/>Location of the port / airport / station that delivers the products to the distribution centre;<br/>Cost of the land for each of the sites;<br/>Average labour costs in the area;<br/>Time taken to drive from the site to each supermarket at different times of the day;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Overall costs to build the distribution centre for each site;<br/>Running costs to receive shipments / distribute goods;<br/>Time taken to build the distribution centre at each of the sites;<br/>Time taken to distribute goods / shipments to arrive;</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.</p>\n<p><strong>Overall costs to build the distribution centre for each site</strong>;<br/>Inputs of labour rate, time taken to build, cost of land are inputted;<br/>Simulation is run with a variety of scenarios (e.g. number of workers, rate of pay for labour; cost of materials);</p>\n<p><strong>Running costs to receive shipments / distribute goods</strong>;<br/>Inputs of fuel cost, distance to each supermarket / sites, fuel economy, number of trips, etc.<br/>Simulation is run with a variety of scenarios (eg fuel price increases, congestion reduces fuel economy, more trips needed to ship goods)</p>\n<p><strong>Time taken to build the distribution centre at each of the sites</strong>;<br/>Inputs for number of diggers, number of workers, building materials delivery schedule;<br/>Simulation is run with scenarios (delay in window deliveries, change in the number of builders, etc.)</p>\n<p><strong>Time taken to distribute goods / shipments to arrive</strong>;<br/>Inputs for time taken to travel to destination, number of vehicles; length of time to load / unload goods, etc.;<br/>Simulation is run with scenarios (e.g. Increased traffic congestion, number of vehicles shipping goods, etc.)</p>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>The cost outweighs the benefit;<br/>It may be impossible to simulate a simulation / too many variables / too many confounding factors;<br/>No positive reasons such as time/danger/modification;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.5",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations",
|
||
"b-1-the-basic-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline the need for a translation process from high level language to machine code.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>(The program written in HLL must be translated into machine code) so that the computer can <span style=\"text-decoration:underline;\">execute</span> the program;<br/>as the computer only understands machine language / as code written in HLL can only be understood by humans and cannot be interpreted by the computers (which work in binary);</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were mostly able to offer good responses as to why a translation process is required from high level language to machine code.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.5",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Draw the truth table for the following logic circuit.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>1 mark for every two correct rows</em>;</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>The majority of candidates achieved high marks for drawing and completing an appropriate truth table for the given logic circuit. Some marks were lost by candidates not including all possible combinations of inputs in their responses, or missing out some of the interim stages, therefore giving inaccurate outputs.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.6",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The following matrix has non-zero elements on the diagonal, on the super-diagonal (the first diagonal above the main diagonal) and on the sub-diagonal (the first diagonal below the main diagonal). All the rest of the elements are zeros.</p>\n<p>The following two-dimensional array named <code>MAT</code> of dimensions 6 × 6 is an example of such a matrix.</p>\n<p style=\"text-align: center;\"><math style=\"font-family: 'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>MAT</mi></math></p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>Method <code>isValidMatrix(N,A)</code> accepts an integer <code>N</code> and a two-dimensional array <code>A</code> of dimensions <code>NxN</code>. It returns <code>True</code> if all elements below the subdiagonal and all elements above the superdiagonal are zeros and all elements on three diagonals are non-zeroes; otherwise it returns <code>False</code>.</p>\n<p>For example, <code>isValidMatrix(6,MAT)</code> returns <code>True</code> for the matrix <code>MAT</code> given above.</p>\n</div><div class=\"specification\">\n<p>Given the following recursive method <code>mystery()</code> with two formal parameters:<br/><code>A</code> (a two-dimensional array) and <code>R</code> (an integer).</p>\n<pre>mystery(A,R)<br/> if R > 0 then<br/> return A[R][R-1] + mystery(A,R-1)<br/> else<br/> return 0<br/> end if<br/>end mystery</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the value of <code>MAT</code>[3][4].</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an efficient algorithm for the method <code>isValidMatrix()</code>.</p>\n<div class=\"marks\">[8]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Determine the value of variable <code>X</code> after execution of the following method call:</p>\n<p><code>X = mystery(MAT,5)</code></p>\n<p>where <code>MAT</code> is the two-dimensional array given. You must show your working.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Deduce the purpose of the method <code>mystery(A,R)</code>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>4;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[8 max]</strong></em><br/><em>Award <strong>[1]</strong> for initialization, correct changing and returning of a flag.</em><br/><em>Award <strong>[1]</strong> for the nested loops.</em><br/><em>Award <strong>[1]</strong> for correct initial and for correct terminal value and changing the value of the control variable in <strong>outer</strong> loop.</em><br/><em>Award <strong>[1]</strong> for correct initial and for correct terminal value and changing the value of the control variable in <strong>inner</strong> loop.</em><br/><em>Award <strong>[1]</strong> for<strong> efficiency</strong> (terminating execution when a zero or non-zero element is not at the correct position).</em><br/><em>Award <strong>[1]</strong> for correct condition in if statement.</em><br/><em>Award <strong>[1]</strong> for checking elements in the lower/upper triangle.</em><br/><em>Award <strong>[1]</strong> for checking elements on the three diagonals.</em><br/><em>Award <strong>[1]</strong> for the correct logical expression.</em></p>\n<p><em><strong>Example 1</strong></em>:</p>\n<pre>INVALID=False<br/>R=0<br/>loop while R<N and not INVALID<br/> C=0<br/> loop while C<N and not INVALID<br/> if abs(R-C)>=2 and A[R][C]!=0 or abs(R-C)<2 and <br/>A[R][C]==0 then<br/> INVALID=True<br/> endif<br/> C=C+1<br/> endwhile<br/> R=R+1<br/>endwhile<br/>return not INVALID</pre>\n<p><em>Please note that instead the logical expression given in the Example answer 1 several if statements could be used and award 1 mark for each correct if statement (1 mark for checking elements in the lower triangle, 1 mark for checking upper triangle, 1 mark for checking three diagonals)</em>.</p>\n<pre>if R>C and R-C>1 then //lower triangle<br/> if A[R][C]!=0 then<br/> INVALID=True<br/> endif<br/>endif<br/>if R<C and C-R>1 then //upper triangle<br/> if A[R][C]!=0 then<br/> INVALID=True<br/> endif<br/>endif<br/>if R<C and C-R=1 or R>C and R-C==1 or R==C then //three <br/>diagonals<br/> if A[R][C]==0 then<br/> INVALID=True<br/> endif<br/>endif</pre>\n<p><em><strong>Example 2</strong></em>:<br/><em>Award <strong>[7 max]</strong> (no ‘efficiency’ mark).</em><br/><em>Award <strong>[1]</strong> for initialization, correct changing and returning of a flag</em><br/><em>Award <strong>[1]</strong> for the nested loops.</em><br/><em>Award <strong>[1]</strong> for correct initial and for correct terminal value of the control variable in <strong>outer</strong> loop.</em><br/><em>Award <strong>[1]</strong> for correct initial and for correct terminal value of the control variable in <strong>inner</strong> loop.</em><br/><em>Award <strong>[1]</strong> for correct condition in if statement.</em><br/><em>Award <strong>[1]</strong> for checking elements in lower/upper triangle.</em><br/><em>Award <strong>[1]</strong> for checking elements on the three diagonals.</em><br/><em>Award <strong>[1]</strong> for the use of correct logical expressions.</em></p>\n<pre>INVALID=False<br/>loop R=0 to N-1 do<br/> loop C=0 to N-1 do<br/> if abs(R-C)>=2 and A[R][C]!=0 or abs(R-C)<2 and <br/> A[R][C]==0 then<br/> INVALID=True<br/> endif<br/> endloop<br/>endloop<br/>return not INVALID</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<pre><em>Award <strong>[4 max]</strong></em><br/>X = mystery( MAT, 5)= 5+ mystery( MAT, 4);<br/>5 + 7 + mystery( MAT, 3);<br/>5 + 7 −5 + mystery( MAT, 2);<br/>5 + 7 −5 + 9 + mystery( MAT, 1);<br/>5+7-5+9+1+mystery(MAT, 0)= 5+7-5+9+1+0 = 17;</pre>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Calculates the sum of R elements;<br/>Starting from A[R][R-1] to A[1][0];<br/>on the sub-diagonal (of the two-dimensional array A);</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Parts (a) and (b) have been attempted with some repetition. The reasonable general knowledge of when and how data can be lost and backup strategies. However, many responses were vague enough not to describe the situation with reference to the basic technical terminology of the devices/systems. </p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was reasonably well answered with many gaining at least 2 or 3 of the marking points.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Quite a few candidates did not attempt the recursion question. However, those who did generally answered well.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Quite a few candidates did not attempt the recursion question. However, those who did generally answered well.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19N.1.HL.TZ0.13",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p style=\"text-align:left;\">Calculate, showing your working in each case: the binary (base 2) value of the denary (base 10) number: 105.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p style=\"text-align:left;\">Calculate, showing your working in each case: the hexadecimal (base 16) value of the denary (base 10) number: 200.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for showing workings</em>.</p>\n<p>(0)1101001;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for showing workings</em>.</p>\n<p>C8;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates were able to correctly convert a binary number to its denary equivalent.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to correctly convert a hexadecimal number to its denary equivalent.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.7",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>ShowTime</em> is a local theatre that allows online booking for its various shows.<br/>All customers are able to access the database to book a movie of their choice.</p>\n<p>However, some of the customers have received incorrect information when their booking has been made. This has been caused by update anomalies.</p>\n</div><div class=\"specification\">\n<p><em>ShowTime</em> have introduced a database recovery system in case the database becomes corrupted.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> types of update anomaly.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> methods of database recovery that can be used to restore the system.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> tasks that are carried out by the database administrator (DBA).</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Customers can choose a credit card as their method of payment. However, some customers are concerned that their personal information could get shared with unauthorized third parties.</p>\n<p>Explain <strong>one</strong> way that the DBA at <em>ShowTime</em> can ensure the anonymity of the customers is maintained.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Insertion;<br/>Deletion;<br/>Modification;<br/>Lost update;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each method of recovery followed by <strong>[1]</strong> for brief explanation up to a maximum of <strong>[2]</strong>.</em><br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong>.</em></p>\n<p><em>Do not accept generic back up responses. It must be DBMS related</em>.</p>\n<p><strong>System log</strong>;<br/>In the event of a disk crash (any catastrophic failure);<br/>The recovery method recovers a past copy of the database;<br/>Backed up to archival storage and reconstructs a more current state by redoing the operations of committed transactions, up to the time of failure.</p>\n<p><strong>Deferred Update</strong>;<br/>To support ABORT and machine failure scenarios;<br/>While a transaction runs, no changes made by that transaction are recorded in the Database;<br/>On a commit, new data is recorded in a log file and flushed to the disk;<br/>New data is then recorded in the database itself;<br/>On abort, do not do anything (the database has not been changed);<br/>On a system restart after a system failure, REDO the log;<br/>Data on disk is not updated until after a transaction commits fully;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>Authorizing/managing access to the database;<br/>Coordinating and monitoring its use;<br/>Capacity planning;<br/>Routine backups to safeguard from data loss during crash;<br/>Tried and tested strategies to recover the database after any crash; <br/>reinstallation/overwrite of data; // Do not accept installation of new software alone<br/>Manage security;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[3 max]</strong></em>.<br/>Important sensitive information like personal details such as names, social security;<br/>Number and addresses should be separated;<br/>A unique identifier should be assigned to each customer;<br/>This identifier is then used to access the booking details in the <em>ShowTime</em>;</p>\n<p><em><strong>Note</strong>: No generic access rights issues like authorisation should be accepted.</em><br/><em>Do not accept Encryption as it is a general point and not specific to DBMS</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18M.2.SL.TZ0.2",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-1-basic-concepts",
|
||
"a-3-further-aspects-of-database-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A biotechnology company owns a resource centre which collects and classifies organisms for use in research.</p>\n<p>Only authorized employees are allowed access to some laboratories in the resource centre.</p>\n<p>These laboratories are protected by locked doors. Each door is controlled by a separate microprocessor. A digital camera is used to scan the iris of an employee who wishes to enter the lab. If the employee is authorized the doors are unlocked.</p>\n</div><div class=\"specification\">\n<p>The company is planning to use a centralized computer system to secure the resource centre’s building.</p>\n</div><div class=\"specification\">\n<p>The operating system has an important role in this system.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> benefits of using a digital camera as an input device in this control system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the use of a microprocessor in this control system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the function of an output transducer.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare a centrally controlled system with the system described above.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> functions of the operating system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Polling and interrupt are two operating system management techniques.</p>\n<p>Suggest with reasons which of these two techniques is the most appropriate for this centrally controlled system.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/><em>(<strong>[1]</strong> for each of the <strong>two</strong> benefits)</em>.</p>\n<p>Digital cameras are relatively cheap;<br/>Robust;<br/>No need for AD conversion;<br/>Generally very high quality pictures (useful to prevent malpractice);<br/>Generally quick;</p>\n<p><em><strong>Example answer 1</strong></em><br/>No need for conversion because image is in digital format;<br/>Thousands/millions of photos of eyes could be taken before needing replacement;</p>\n<p><em><strong>Example answer 2</strong></em><br/>It is directly connected to a microprocessor for image comparison;<br/>It could be fitted (purchased), with a macro lens so that a close up scan of the Iris is possible;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award up to <strong>[2 max]</strong></em>.<br/>Processor compares the inputted image/pattern with the images stored in memory;</p>\n<p>If a match is found, it sends a signal to unlock doors /<br/>(if match is not found, it sends error message/the doors remain locked);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Output transducer is a device (an actuator) which converts;<br/>an electrical signal into physical quantity (a physical action);</p>\n<p>Output transducer is a device which converts energy from one physical form to another;<br/>e.g. electrical energy (signal) into electro-mechanical or kinetic energy / to produce action (lock/unlock door);</p>\n<p><em><strong>Note</strong>: Award one mark only for an answer that just says that the output transducer can be used to lock/unlock doors</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for the meaning of centrally controlled system;</em><br/><em><strong>[1]</strong> for the meaning of a distributed system, and;</em><br/><em><strong>[up to 2 max]</strong> for an expansion/comparison addressing both kind of systems <strong>[up to 4 max]</strong>;</em></p>\n<p><em><strong>Example answer</strong></em><br/>A centrally controlled system involves a central computer which controls all labs/doors;<br/>A distributed system can have only a dedicated microprocessor with memory to control one of the labs/doors;</p>\n<p>A centrally controlled system is more versatile;<br/>Could be used in solving other business tasks (accept specific examples);<br/>Can unlock all doors easily during an emergency;<br/>Access rights can be updated easily;<br/>Data is stored centrally and therefore easier to update;<br/>A failure in a central system would affect all doors;</p>\n<p>A distributed system can be programmed with ad hoc OS depending on the technologies used;<br/>It may be practical choice when dealing with legacy systems/ specific devices/ old infrastructure/while updating the facilities;<br/>It contributes a higher sense of partition of the physical space (territory) to groups / individuals;<br/>Data are stored locally, so there is local consistency (and smaller size mean easier to manage);<br/>Changes to data may be done locally, and if some data are common in two or more different systems, global inconsistencies across different systems may be introduced;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Memory management;<br/>Resource allocation / Resource and Hardware management (printer, disk drives, etc.);<br/>Booting / bootstrapping;<br/>Loading and execute / provide service for applications software;<br/>Disk/File system management;<br/>Data security;<br/>Provides a user interface to other levels of the machine;<br/>etc.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for choosing “interrupt”, <strong>[1]</strong> for explaining “interrupts” and <strong>[1]</strong> for justifying the choice in this context, up to <strong>[3 max]</strong></em>.</p>\n<p><em><strong>Example answer</strong></em>:<br/>Interrupt;<br/>A signal sent from an input device to a computer causes the processor, and the main program that operates the computer (the operating system), to stop and figure out what to do next;<br/>Interrupt is better in this situation because it does not waste central computer’s time (other tasks could be performed);<br/>(<em>example of emergency – it must give quick response</em>);</p>\n<p><em><strong>Note</strong>: Award <strong>[1 max]</strong> for an answer of “polling”, but only if reasonably justified</em>.</p>\n<p>Polling – the continuous checking of all input devices by processor to see what state they are in/to see whether they are still connected/want to communicate;<br/>So a faulty device that is polled will not reply;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "17N.1.HL.TZ0.12",
|
||
"topics": [
|
||
"topic-7-control",
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"topic-7-1-control",
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p style=\"text-align:left;\">Identify <strong>one</strong> function of a single-user operating system.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>memory management;</p>\n<p><em>Note to examiners: allow any other correct function of a single-user operating system</em>.</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Many correct alternative functions of a single-user operating system were identified by candidates.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.8",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The QT Railway and QT Highway have recently been built to connect Qinghai with Tibet. This has made the mountainous region of Tibet accessible to the rest of China.</p>\n<p>The endangered Tibetan antelope migrates over 300 km each year to give birth to a single calf. The QT Railway and QT Highway cross this migration route, see <strong>Figure 2</strong>.</p>\n<p style=\"text-align: center;\"><strong>Figure 2: Map of the study site and habitat of Tibetan antelope</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align: center;\">[Source: adapted (simplified redraw of the nature reserve data map) from Karina Manayeva, Buho Hoshino, Hiromasa Igota, Takashi Nakazawa and Ganzorig Sumiya, 2017. Seasonal migration and home ranges of Tibetan antelopes (Pantholops hodgsonii) based on satellite tracking. <em>Int. J. Zool. Res</em>., <strong>13</strong>: 26–37. © 2017 Karina Manayeva et al.]</p>\n<p style=\"text-align: left;\">The building of the QT Railway and QT Highway presents potential dangers to both the antelopes and the public travelling through this nature reserve.</p>\n<p style=\"text-align: left;\">To understand more about the antelopes’ migration patterns, some antelopes have tracking devices attached. Using the information from these tracking devices, a 2D visualization model can be developed and updated in real time.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>four</strong> items of data that would be included to create the 2D visualization model.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why a 2D visualization model would be used rather than a 3D visualization model in this scenario.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the development of a visualization model was necessary in this scenario.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Continuously collected data (from satellite, electronic trackers, observation);<br/>Data on current speed of antelopes / length of time for the entire herd to pass a certain point;<br/>Previous migration paths stored and used to provide additional data;<br/>Predicted path calculated to determine when the antelopes will hit the railway line / highway;<br/>Model may show the expected time of highway / railway inception updated in real time;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>2D visualization gives a rapid way of seeing what is happening relative topositions on the map and updates quickly;<br/>A 3D model may have delays updating providing information too late;</p>\n<p>The antelope is always on the ground / in a 2D space<br/>So there is no need to map in 3D space</p>\n<p>2D visualization will update rapidly because it is less complex;<br/>A 3D model that requires more powerful graphics cards (GPU);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award<strong> [2 max]</strong> for technical difficulties of collecting data;</em><br/><em>Award <strong>[2 max]</strong> for a reasonable solution to the problem</em></p>\n<p>Difficult to put people on the ground to keep pace with the antelope;<br/>Because the area is inhospitable / mountainous;<br/>The antelope may cross the road at any point over a vast distance so the number of people required is prohibitive;<br/>Poor visibility may affect visuals of antelopes / too dark for cameras;<br/>Transmission may get disrupted in a remote place like Tibet;<br/>So satellite transmissions as a back up system;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.6",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-3-visualization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p style=\"text-align:left;\">Define the term <em>usability</em>. </p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>The extent to which a device can be used by specific/its users;<br/>To achieve specific goals effectively/efficiently/satisfactorily;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were mostly able to define the term usability, but some candidates found it difficult to do so without including the word usable, or similar, in their response.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.9",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Marble Reading Book Stores</em> (<em>MRBS</em>) is a chain of bookstores based in London. The stores want to keep information about the books they sell, the authors of the books and the publishers they work with. The assumptions made when the database was created were:</p>\n<ul>\n<li>a publisher can publish books from one or more authors</li>\n<li>an author can write one or more books.</li>\n</ul>\n</div><div class=\"specification\">\n<p>Three of the tables in the <em>MRBS</em> database are shown below:</p>\n<p style=\"text-align: center;\"><strong>PUBLISHER</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align: center;\"><strong>AUTHOR</strong></p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: center;\"><strong>BOOK</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"specification\">\n<p>The <em>MRBS</em> database undergoes many transactions.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the entity-relationship diagram (ERD) for this scenario.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why data validation is difficult for the Book_Title attribute.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the result from the following query:</p>\n<pre>SELECT Book_Title<br/>FROM BOOK<br/>WHERE Genre = \"Non-fiction\"<br/>AND ISBN = '0-98124-612-2'</pre>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a query to find the titles of the books published by “Orlando Crux”.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why atomicity is important within a database.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how data consistency can be maintained in transactions in this database system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Some data in the <em>MRBS</em> database is redundant.</p>\n<p>Outline <strong>one</strong> problem caused by redundant data.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><img src=\"\"/></p>\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for correct relationship “publishes books from”</em>.<br/><em>Award <strong>[1]</strong> for correct relationship “writes”</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>As Book_Title attribute is String/Varchar;<br/>It does not allow many validation checks (like range check etc.);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Seeking the truth;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for selection of both Publisher_Name and Book_Title from the two respective tables.</em><br/><em>Award <strong>[1]</strong> for making INNER JOIN of the Publisher_Name from both tables-Publisher and Author.</em><br/><em>Award <strong>[1]</strong> for the correct test ON Author_Num from both tables-Author and Book.</em><br/><em>Award <strong>[1]</strong> for the correct test of equity of Publisher_Name.</em></p>\n<pre>SELECT Publisher.Publisher_Name, Book.Book_Title FROM Author<br/>INNER JOIN Book ON PUBLISHER. Publisher_Name = <br/>Author.Publisher_Name, ON Author.Author_Num = Book.Author_Num <br/>WHERE Publisher.Publisher_Name = \"Orlando Crux\";</pre>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Helps the searching of a family name for example rather than a “like” name search;<br/>So, making data into the smallest possible unit helps quicker searches;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Each user sees a fixed view of the data;<br/>This may include visible changes made by the user / the user's own transactions and transactions of other users;</p>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>When a field value changes multiple occurrences must be updated;<br/>For example, if a publisher moves, we’ll need to change the values for City and Country in multiple records;<br/>Problem occurs if we forget to change the values in any of the records;<br/>The database would then have data inconsistency;</p>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students knew how to sketch an ER diagram though some of them don’t seem to know the various relationships in it and how to apply. Some of them can draw the entities but setting the relationship was not done correctly.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most of the students understood the validations in String attributes and its challenges.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The query was well understood.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students were able to get the basic structure of the query well though some of them could not set the two tables and their relationship properly while writing the query. Also many students searched for the publisher or author code not the publisher name.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students were able to explain atomicity though only very few students were able to refer to rollback as well.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>‘Data consistency’ was understood though they could not relate to the given scenario of the bookstore database.</p>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students gave generic answers and most of them incorrectly referred to the space redundancy that is not appropriate to this question clearly.</p>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.1",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model",
|
||
"a-1-basic-concepts"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p style=\"text-align:left;\">Outline <strong>one</strong> reason for the use of standards in the construction of networks.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Standards ensure compatibility between nodes on the network;<br/>Through the use of common techniques/protocols/language;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Most candidates recognised that the use of standards in the construction of networks was related to the need for compatibility, with many answers based on that concept seen.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.10",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p style=\"text-align:left;\">Explain how cache memory affects system performance.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Cache is high-speed memory;<br/>Located between CPU and RAM;<br/>Frequently used data/instructions are (temporarily) stored in cache memory;<br/>To reduce the access time needed/Speed up retrieval time/To improve the speed of processing;<br/>CPU searches as instruction’s address first in the cache, and if not found, in RAM;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates were able to explain the positive impact of cache memory on system performance, with many high scoring responses.</p>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.11",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>OrderYourFoods</em> is an online company that allows customers to order food and get it delivered to their location. It operates in a number of cities in India.</p>\n<p>On the home page of the company’s website www.orderyourfoods.com, the customer has to enter the city name and the address the food needs to be delivered to. Based on this information, the website displays a list of restaurants.</p>\n</div><div class=\"specification\">\n<p>The website has a pop-up advert that encourages customers to subscribe for discount offers, see <strong>Figure 3</strong>.</p>\n<p style=\"text-align: center;\"><strong>Figure 3: An example of a pop-up advert</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align: left;\">The following code is executed when the customer clicks on the subscribe button.</p>\n<pre style=\"text-align: left;\"><? php<br/>$to = 'info@orderyourfoods.com';<br/>$from = '$_POST['email']';<br/>$headers = \"From: \" . $from . \"\\r\\n\";<br/>$subject = \"New subscription at OrderYourFoods\";<br/>$body = \"New user subscription: \" . $_POST['email'];<br/>if( filter_var($_POST['email'], FILTER_VALIDATE_EMAIL) )<br/>{<br/> if (mail($to, $subject, $body, $headers, \"-f \" . $from))<br/> {<br/> echo 'Your e-mail (' . $_POST['email'] . ') has been added to our<br/> mailing list!';<br/> }<br/> else<br/> {<br/> echo 'There was a problem with your e-mail (' . $_POST['email'] . ')';<br/> }<br/>}<br/>?></pre>\n</div><div class=\"specification\">\n<p>The website uses the following method to communicate with the potential customers, see <strong>Figure 4</strong>.</p>\n<p style=\"text-align: center;\"><strong>Figure 4: Banner for OrderYourFoods.com</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align: left;\"><em>OrderYourFoods</em> currently displays an email address and a phone number to show customers how they can be contacted.</p>\n<p style=\"text-align: left;\"> </p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the protocol used in the company’s website.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the importance of protocols on the World Wide Web.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the type of scripting used in the php code.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>one</strong> inbuilt function along with parameters used in the php code.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the processing that occurs when the subscribe button is clicked.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> additional method of online interaction that can be incorporated in this website.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p><em>OrderYourFoods</em> is concerned that it never appears close to the top of the list of search results when the term “food delivery” is typed into a search engine.</p>\n<p><em>OrderYourFoods</em> has decided to use black hat search engine optimization techniques to be more visible in search engines.</p>\n<p>Evaluate this decision.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Hypertext transfer protocol secure/https;<br/><em>Do not accept http</em>.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>To allow successful communication to take place;<br/>Ensure data integrity such as error checking;<br/>Regulate flow control such as prevent a fast sender from overwhelming a slow receiver;<br/>Managing deadlock when two processes are each waiting for the other to complete before proceeding;<br/>Manage congestion;<br/>Manage error correction such as enabling reliable delivery of digital data over unreliable communication channels;<br/>Manage packet switching;<br/>Manage security / encryption / authentication ……;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Server-side scripting;</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>filter_var($_POST['email'], FILTER_VALIDATE_EMAIL);<br/>mail($to, $subject, $body, $headers, \"-f \" . $from);</p>\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>The script reads the email id;<br/>Checks if the email address entered is valid/executes the <strong>filter( ) function</strong>;<br/>If correct, then the <strong>mail( ) function</strong> of PHP adds the email address and displays that your email address has been added to our mailing list;<br/>Else, the error message will be displayed;<br/>There is no error message if the email address is invalid.</p>\n<p><em><strong>OR</strong></em></p>\n<ul>\n<li>The script gets an e-mail address via POST</li>\n<li>It checks whether it is valid via a filter function; if not, it does nothing</li>\n<li>If it is valid, it checks with the mail function, and displays either a success or an error message</li>\n</ul>\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Social Networking/Facebook/Social Media/Twitter;<br/>Forums;<br/>Online chat;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/><em><strong>Advantages</strong> <strong>[2 max]</strong></em><br/>The use of black hat SEO techniques may increase the visibility of the <em>OrderYourFoods</em> website;<br/>Which will bring a short term gain;</p>\n<p><em><strong>Disadvantages</strong> <strong>[2 max]</strong></em><br/>Black hat techniques are unethical;<br/>Use of these techniques may lead to blacklisting;</p>\n<p><em><strong>Evaluative comment</strong> <strong>[1 max]</strong></em><br/><em>OrderYourFoods</em> may decide that the need to increase their visibility, and increase their sales potential, so this may be a pragmatic (if unethical) compromise;<br/><em>OrderYourFoods</em> may decide that the potential long term risks that may arise from the use of an unethical technique may not be a risk that is worth taking may affect the company’s reputation;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not all candidates registered the fact that this site would need to be secure and therefore would use the HTTPS protocol.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>As this was a 4-mark question a brief definition type response would be unlikely to score highly. Most commented on the fact that protocols are needed to ensure that communication takes place, but few were able to provide the specific detail that an \"explain\" question demands.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Schools need to be aware that the candidates are expected to be practiced in the use of web software such as php, JavaScript and CSS. Answers did not show a high level of understanding even though some gained marks through answering quite generally in part (b).</p>\n<div class=\"question_part_label\">b.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A specific web element was expected here — many answered with on-line chat.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were more comfortable with this topic and provided some good discussions identifying both the short-term gains and long-term consequences of black hat SEO.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.7",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-2-searching-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A business’s computer system needs to be updated.</p>\n</div><div class=\"specification\">\n<p>The new system is now ready for implementation.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> stakeholder to be considered when planning the new system.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> consequence of not including all stakeholders in the design of the new system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> appropriate techniques to gather the information needed to find a suitable solution for the updated system.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> reason testing should take place at every stage of the development process.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate <strong>two</strong> methods the business could use to implement the new system. Include the benefits and drawbacks of each.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>End users/ employees/ customers/ community members/ media/ suppliers;<br/>Business owners/ managers/ shareholders/ investors;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>User dissatisfaction;<br/>because the system does not meet user requirements;</p>\n<p>Developers not being paid for the final product;<br/>as the business owner requests are not evident in the final product/ or outside of the project's scope;</p>\n<p>Unsuccessful final product;<br/>the developed system may either solve a different problem/ is not user friendly as compared to the existing system;</p>\n<p><em>Note to examiners: Reward other reasonable responses</em>.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Examining current systems (using interviews/ surveys/direct observation);<br/>To compare the existing system against possible requirements to identify missing features;</p>\n<p>Examining competing products;<br/>To compare own system with competitors to enable decisions on features to add;</p>\n<p>Review of organizational capabilities;<br/>To determine how well the organization manages resources to gain an advantage over competitors;</p>\n<p>Literature searches;<br/>To research current methods and to help inform development choices;</p>\n<p><em>Mark as 2 and 2</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Testing is important (at every stage) to make sure the system operates in line with user requirements/as intended;<br/>To prevent the end user being dissatisfied with the final system;</p>\n<p>Testing is important to enable early discovery of errors;<br/>to reduce time delay/ using more resources / avoid higher cost;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for method, award <strong>[1]</strong> for benefit and award <strong>[1]</strong> for drawback</em>.</p>\n<p>Parallel running;<br/>The old and new systems run together, so if a problem is found with the new system, it can be repaired/the old system can take over;<br/>This is expensive as duplicate systems and staff are needed;</p>\n<p>Pilot running;<br/>The new system is only implemented in one branch of the organization so disruption is kept to a minimum;<br/>It can take a long time for the new system to be fully implemented / two systems are still in operation within the organization, leading to duplication and possible errors;</p>\n<p>Direct changeover;<br/>The new system is implemented overnight so the changes happen very quickly;<br/>If the new system fails, the company has no working system to fall back on;</p>\n<p>Phased conversion;<br/>Only one area/department/part of the system is updated at a time, so the disruption is kept to a minimum;<br/>Multiple systems which may not be compatible with each other will be running at the same time;</p>\n<p><em>Note to examiners: Accept other suitable examples of benefits and drawbacks</em>.</p>\n<p><em>Mark as 3 and 3</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates identified a range of correct stakeholders who should be considered when planning a new business computer system. </p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>In general, they then correctly continued and outlined a consequence of not including all stakeholders in the design of the new system. If marks were lost, it was most likely due to not expanding on the consequence they had named, and then, had gone on to name one or more additional consequences.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates mostly misinterpreted this question as requiring methods of data collection, so talked about surveys, interviews or observations, when the question was asking about techniques to gather information, which meant, for example, examining current systems, examining competing products or literature searches. A small number of candidates did identify appropriate techniques.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Virtually all candidates were able to talk about the reasons for testing, but the question specifically asked about the reason for testing at every stage of the development process. Many good answers were seen, but there were also some answers that gave generic benefits of testing. In addition, candidates were asked to outline one reason, so candidates who gave simple answers covering more than one reason lost out on the expansion mark.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates who chose to evaluate the direct and parallel running methods of implementing a new system often scored high marks and generally scored higher marks than those who chose to write about other methods. Candidates often mixed up the meaning of pilot and phased implementation, so therefore didn’t get all the available marks if they chose either of these methods.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.12",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics",
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Consider the following two-dimensional array, <code>MAT</code>, with dimensions 6 × 6.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">The value <code>−1</code> is stored in <code>MAT</code> at position <code>[4][2]</code>. The position <code>[4][2]</code> means row 4 and column 2.</p>\n</div><div class=\"specification\">\n<p>A two-dimensional array in which most of the elements are zero is called a <strong>sparse matrix</strong>. A sparse matrix can be compressed by storing only non-zero elements using three one‑dimensional arrays.</p>\n<p><strong>The first array</strong>, <code>VALUES</code>, stores all non-zero elements taken from the sparse matrix in row‑major order (left-to-right then top-to-bottom order).</p>\n<p>The length of the array <code>VALUES</code> is equal to the number of non-zero elements in the sparse matrix. For the sparse matrix above, <code>MAT</code>, the array <code>VALUES</code> is:</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">The <strong>second array</strong> is <code>ROWC</code>. <code>ROWC[i]</code> stores the number of non-zero elements, from row <code>0</code> to row <code>i</code> of the sparse matrix, <strong>inclusive</strong>.</p>\n<p style=\"text-align: left;\">The length of <code>ROWC</code> is equal to the number of rows in the sparse matrix. For <code>MAT</code> the array <code>ROWC</code> is:</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n<p style=\"text-align: left;\">For example, <code>ROWC[2]</code> stores <code>3</code> because in <code>MAT</code> there are three non-zero elements from row <code>0</code> to row <code>2</code>, inclusive.</p>\n<p style=\"text-align: left;\">The <strong>third array</strong>, <code>COL</code>, stores the column index for each non-zero element in the sparse matrix. <code>COL[i]</code> stores the sparse matrix column index for the non-zero element stored in <code>VALUES[i]</code>. For <code>MAT</code> the array <code>COL</code> is:</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>Consider the following three arrays. They hold the compressed contents of a 7 × 7 sparse matrix, <math style=\"font-family: 'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>BIGMAT</mi></math>.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the total number of elements stored in <code>MAT</code>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the number of non-zero elements in <code>MAT</code>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State how many rows in <code>BIGMAT</code> contain only zeros.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the index in <code>VALUES</code> of the first non-zero element in row <code>5</code> of <code>BIGMAT</code>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">f.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the index in <math style=\"font-family:'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>VALUES</mi></math> of the first non-zero element in row <math style=\"font-family:'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mn>5</mn></math> of <math style=\"font-family:'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>BIGMAT</mi><mo>.</mo><mo> </mo></math></p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">f.i.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>36;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>7;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>1;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>5;</p>\n<div class=\"question_part_label\">f.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>5;</p>\n<div class=\"question_part_label\">f.i.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.i.</div>\n</div>",
|
||
"question_id": "17N.1.HL.TZ0.14",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A teacher would like a simple program to store the names, marks and grades of students in a set of three parallel one-dimensional arrays called <code>NAME[]</code>, <code>MARK[]</code> and <code>GRADE[]</code> .</p>\n<p>The grade boundaries for the individual grades are shown below:</p>\n<p><img src=\"\" style=\"display: block; margin-left: auto; margin-right: auto;\"/></p>\n<p>The class has 30 students.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> components in a conditional statement.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm using pseudocode to take the marks that have been stored in <code>MARK[]</code>, convert them into the appropriate grade and store the calculated grades in <code>GRADE[]</code>.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how the name, mark and grade in the three arrays correspond to the same student.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm using pseudocode to output the names and grades of all students who achieve a grade of Merit or Distinction.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how you would change your algorithm in <strong>part (d)</strong> to allow a user to choose a grade and output the names and marks of the students who have achieved this grade.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><code>if;</code><br/><code>then;</code><br/><code>else;</code></p>\n<p><em>Note to examiners: allow an alternative descriptive version such as</em>:<br/>test/condition;<br/>action/consequence;<br/>(optional) alternative action/consequence;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for an appropriate loop with correct loop parameters to cover 30 array elements/all students</em><br/><em>Award <strong>[1]</strong> for correct use of indexes in two arrays (<math style=\"font-family:'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>MARK</mi></math> <code>and</code> <math style=\"font-family:'Courier New';\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>GRADE</mi></math>)</em><br/><em>Award <strong>[1]</strong> for each if statement with correct condition and grade assignment up to <strong>[4]</strong>.</em></p>\n<p><em>Note to examiners: Award <strong>[4]</strong> if candidate has correctly used an alternative conditional statement such as switch/ case.</em></p>\n<p><strong><em>Example answer 1</em></strong>:</p>\n<pre>loop COUNTER from 0 to 29<br/> if MARK[COUNTER] >= 80<br/> then GRADE[COUNTER] = \"Distinction\"<br/> else<br/> if MARK[COUNTER]>˝= 60<br/> then GRADE[COUNTER] = \"Merit\"<br/> else<br/> if MARK[COUNTER} >= 40<br/> then GRADE[COUNTER] = \"Pass\"<br/> else<br/> GRADE[COUNTER] = \"Fail\"<br/> end if<br/> end if<br/> end if<br/>end loop</pre>\n<p><em><strong>Example answer 2</strong></em>:</p>\n<pre>COUNTER = 1<br/>loop while COUNTER <= 30<br/> if MARK[COUNTER-1] >= 80<br/> then GRADE[COUNTER-1] = \"Distinction\"<br/> end if<br/> if MARK[COUNTER-1] >= 60 and MARK[COUNTER-1] < 80<br/> then GRADE[COUNTER-1] = \"Merit\"<br/> end if<br/> if MARK[COUNTER-1} >= 40 and MARK[COUNTER-1] < 60<br/> then GRADE[COUNTER-1] = \"Pass\"<br/> end if<br/> if MARK[COUNTER-1} < 40<br/> GRADE[COUNTER-1] = \"Fail\"<br/> end if<br/> COUNTER = COUNTER + 1<br/>end loop</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Three arrays are parallel/ they have the same number of elements/ the same length;<br/>the same array index can be used to represent name, grade and mark of the same student/ the array index makes sure that data from the three arrays lines up;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for correct loop to check all students</em><br/><em>Award <strong>[1]</strong> for correct conditional statement checking correct array</em><br/><em>Award <strong>[1]</strong> for correct output</em></p>\n<p><strong><em>Example answer 1</em></strong>:</p>\n<pre>loop COUNTER from 0 to 29<br/> if MARK[COUNTER] >= 60 then<br/> output NAME[COUNTER], GRADE[COUNTER]<br/> end if<br/>end loop</pre>\n<p><strong><em>Example answer 2</em></strong>:</p>\n<pre>loop C from 0 to 29<br/> if GRADE[C].equals(“Merit”)OR GRADE[C].equals(“Distinction”)<br/> then<br/> output NAME[C], GRADE[C]<br/> end if<br/>end loop</pre>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for an input statement before the loop;</em><br/><em>Award <strong>[1]</strong> for changing the conditional statement so that it checks the </em><code>GRADE[]</code><em> array for the </em><code>GRADE</code><em> input (using the same variable)</em><br/><em>Award <strong>[1]</strong> for outputting the name and marks of the student who has achieved the inputted grade</em></p>\n<p><em>Note to examiners: Accept a written explanation or an amended algorithm that corresponds to candidate’s answer to part(d).</em></p>\n<p><em><strong>Example 1</strong></em>:</p>\n<pre>G=input()<br/>COUNTER = 0<br/>loop while COUNTER < 30<br/> if GRADE[COUNTER] = G<br/> then<br/> output(NAME[COUNTER], MARK[COUNTER])<br/> end if<br/> COUNTER = COUNTER + 1<br/>end loop</pre>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates who gave an example of a conditional statement did enough to get both marks for this question. Other candidates who described the make-up of a conditional statement, were also successful.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were able to demonstrate the construction of an algorithm to take marks that were stored, convert them into a grade and then store the calculated grades. However, fully correct pseudocode solutions were rare. Errors that were seen included incorrect loop constructs; loops not covering the whole data set; incorrect use of array indexing for both retrieval and storage; incorrect data types – the data to be stored was of the string data type, but this was not always shown; incorrect use of assignment.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates recognised that a particular student’s data used the same index in each of the three arrays, therefore indicating that the data in each array corresponded to the same student. Relatively few candidates identified the fact that this was because they were parallel arrays.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Another algorithm was required here with some of the same problems as seen in question 13b, however, most candidates did achieve marks here, mostly for the correct use of conditional statements.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates were asked to explain how they would change their algorithm in question 13d to achieve some additional functionality. Most candidates did achieve some marks here for adding an input, changing the conditional statement and/or changing the output.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.13",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-1-general-principles",
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A school maintains a database of students’ details and teaching resources on a central server. This data can be accessed by all teachers in the school.</p>\n<p>Teachers may need to edit resources when preparing their lessons.</p>\n</div><div class=\"specification\">\n<p>When storing student details, data security is an important consideration.</p>\n</div><div class=\"specification\">\n<p>The school has appointed a database administrator (DBA).</p>\n<p>A DBA is required to carry out tasks such as ensuring there is a strategy to recover the database if it becomes corrupted and that the data is shared ethically.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how concurrent use of the school database is possible in this situation.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> ways that data security in the school's database can be maintained.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>one</strong> strategy that could be used to ensure the data can be recovered if the database becomes corrupted.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Suggest how the privacy of student data can be ensured.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>The ability of a database to allow multiple teachers to affect multiple transactions;<br/>Allowing concurrent processing while ensuring transaction isolation;<br/>Thus, ensuring the update of one teacher does not affect the update of another teacher;<br/>While one transaction (by a teacher) is accessing a resource from a shared folder, it places a lock, an access restriction, on the resource, controlling the level of access allowed by another transaction by another teacher;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for identifying a way of maintaining data security and <strong>[1]</strong> for a development up to <strong>[2 max]</strong></em><br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em></p>\n<p>Minimizing permissions;<br/>Restrict users to have permission only to the means to do their job. Some can view, modify and insert some only view etc.;</p>\n<p>Auditing changes;<br/>Log changes made to teachers and permissions through auditing. This gives a trail to follow should you have problems. Without authorization no one gets grant of permissions;</p>\n<p>Minimizing table access;<br/>Isolate the teachers from the data tables they do not need / Create views and user defined functions to support user access requirements and not give access to the tables;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for identifying a way of maintaining data security and <strong>[1]</strong> for a development up to <strong>[2 max]</strong></em>.</p>\n<p>Deferred update;<br/>does not physically update the database on disk until a transaction has reached its commit point/if a transaction fails before reaching its commit point, it will not have changed the database in any way so UNDO is not required;</p>\n<p>Shadow paging;<br/>When a page is to be modified, a shadow page is allocated in which changes are made;<br/>When it is ready to become durable, all pages that refer to original are updated to refer new replacement page;</p>\n<p>Back-up;<br/>Back-up copies of the entire database is done to ensure the database is at the most updated version of the original;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for the method, award <strong>[1]</strong> for the explanation and <strong>[1]</strong> for the example up to <strong>[3 max]</strong></em>.</p>\n<p>Data masking or data obfuscation;<br/>is the process of hiding original data with random characters;<br/>e.g.: suppressing certain characters in the student address, student id etc.;</p>\n<p>Data encryption;<br/>Conversion of data into non-readable gibberish creates highly secure results such as scrambling the student_ID;<br/>The only way to gain access to the data is to unlock it with a key or password which only those authorized can access; </p>\n<div class=\"question_part_label\">c.ii.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many students gave generic answers for isolation in this section. Few of the students gave very precise explanations as well.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students were able to do this question.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A majority of candidates were able to identify at least one way of maintaining data consistency but did not relate to the recovery part of the answer.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Methods of anonymising data was a challenge for most students.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.2",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-1-basic-concepts",
|
||
"a-2-the-relational-database-model",
|
||
"a-3-further-aspects-of-database-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The IB Coordinator of AB World Academy introduces the Extended Essay to the Grade 11 students in January by researching the difference between primary and secondary data on the internet.</p>\n<p>Some of the students used the Google search engine (Google.com) and others used the Ask search engine (Ask.com). These search engines gave results.</p>\n</div><div class=\"specification\">\n<p>Google uses the PageRank algorithm and Ask uses the HITS algorithm.</p>\n</div><div class=\"specification\">\n<p>The IB coordinator uploaded the assignments onto a cloud-based Learning Management Platform.</p>\n</div><div class=\"specification\">\n<p>As part of their research, students downloaded images from the internet. Most of the downloaded JPG images were compressed using lossy compression.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>search engine</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between the principles of these two algorithms.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the difference between cloud computing and local client-server architecture.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the alternative type of compression to lossy.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the advantages and disadvantages for students of using compressed images in their IB Coursework.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>A PNG image uses open standards.</p>\n<p>Distinguish between interoperability and open standards.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Software that interrogates a database of web pages;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em><strong>PageRank algorithm</strong> <strong>[2 max]</strong></em><br/>PageRank works by counting the number and quality of in links of a page to determine a rough estimate of how important the website is;<br/>The assumption is that more important websites are likely to receive more links from other websites;<br/>Pages are given a score (rank) / counts links per pages;</p>\n<p><strong><em>HITS algorithm [2 max]</em></strong><br/>Based on authorities and hubs;<br/>Authorities: A page is called an authority, if it contains valuable information and if it is truly relevant for the search query. It is assumed that such a page has a high number of in-links;<br/>Hubs: These are pages that are relevant for finding authorities. They contain useful links towards them. It is therefore assumed that these pages have a high number of out-links;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/><em><strong>Local client-server architecture [1 max]</strong></em><br/>The server is the central communicator between clients (e.g. email/chat server)/allows different clients to access and manipulate data;</p>\n<p><em><strong>Cloud computing [1 max]</strong></em><br/>Cloud computing puts the focus on sharing computing resources over the internet;</p>\n<p><em><strong>Differences between the two [1 max]</strong></em><br/>Cloud computing is often offered as a service to individuals and companies whereas local client server architecture is based at an organizational level;<br/>Cloud computing can scale up or down depending on current demands more easily than local client server networks;<br/>Client / server networks are more secure than the cloud as the data transmission is carried out locally;<br/>Client / server networks have lower levels of latency than the cloud as the data transmission is carried out locally;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Lossless (Compression);</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><strong><em>Advantages of using compression [2 max]</em></strong><br/>Allows for more rapid upload/download as the compressed file is smaller than the original;<br/>Scrolling through the coursework may be quicker;</p>\n<p><em><strong>Disadvantages of using compression [2 max]</strong></em><br/>This may mean that the overall quality of the work is reduced;<br/>This may be an issue when printing the work / or the quality of the image is a key contributor to the overall quality of the work;</p>\n<p><em><strong>Overall comment [1 max]</strong></em><br/>The impact of using compression may be dependent on the context in which the work is compressed;</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Interoperability means a computer program can communicate and exchange information across a range of platforms;<br/>Open standards are publically and free standards that enable interoperability;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>All candidates are familiar with search engines but not all were able to put together a precise definition that including both the role of the user and processes involved.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a memory recall question and dependent on the schools' coverage of the course.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates did not answer this well being unable to clearly distinguish between the two types of architecture. They seemed particularly unaware of the difference in scale.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a familiar topic and was answered well. Full marks went to candidates who related their answers to the specific scenario.</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a familiar topic and was answered well. Full marks went to candidates who related their answers to the specific scenario.</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Another memory recall question at was answered quite well.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.8",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-2-searching-the-web",
|
||
"c-4-the-evolving-web",
|
||
"c-3-distributed-approaches-to-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Outline what is meant by the term computer network.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[1]</strong> for identifying the nature of a network and <strong>[1]</strong> for a development of the first point up to <strong>[2 max]</strong></em>.</p>\n<p>A group of computers and other computing hardware devices that are linked together through communication channels/cables/wirelessly;<br/>To enable communication (sharing files, sharing information) between systems/among a wide range of users;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.1",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline what is meant by a database management system.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage of using beta testing prior to the release of a new product.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying a feature of a database management system and <strong>[1]</strong> for an expansion up to <strong>[2 max]</strong></em>.</p>\n<p>Database management system is an application software;<br/>that allows users to define/create/maintain a database / provides (controlled) access to the data;<br/>Examples of database applications are computerized library, inventory, flight reservation, etc.;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> of using beta testing and <strong>[1]</strong> for an expansion up to <strong>[2 max]</strong></em>.</p>\n<p>Beta testing is done from the user/client perspective;<br/>So, requirement mismatches can be easily identified;<br/>The real users have an opportunity to test a new product before it is (publicly) released;<br/>So, user acceptance is assured;<br/>Any bugs identified could be (easily) fixed before the public release of the product;<br/>So, quality of the product is enhanced;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.2",
|
||
"topics": [
|
||
"topic-2-computer-organization",
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization",
|
||
"1-1-systems-in-organizations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The array <code>DATA_ARR[]</code> is a one-dimensional array of 12 integers.</p>\n<p><img src=\"\"/></p>\n<p><strong>Algorithm 1</strong> represents a method of searching the array <code>DATA_ARR[]</code> to see if it contains a specific value.</p>\n<p><strong>Algorithm 1</strong></p>\n<pre>input TO_FIND<br/>LIMIT = 11<br/>LOC = FALSE<br/>ITERATE = 0<br/>loop while not LOC and ITERATE <= LIMIT<br/> if DATA_ARR[ITERATE] = TO_FIND then<br/> LOC = TRUE<br/> end if<br/> ITERATE = ITERATE + 1<br/>end loop<br/>if LOC then<br/> output TO_FIND, \"is in the array\"<br/>else<br/> output TO_FIND, \"is NOT in the array\"<br/>end if</pre>\n</div><div class=\"specification\">\n<p><strong>Algorithm 2</strong> represents an alternative method of searching the array <code>DATA_ARR[]</code> to see if it contains a specific value.</p>\n<p><strong>Algorithm 2</strong></p>\n<pre>input TO_FIND<br/>LOC = FALSE<br/>LOW_LIM = 0<br/>UP_LIM = 11<br/>loop while LOW_LIM <= UP_LIM and LOC = FALSE<br/> MID_VAL = (LOW_LIM + UP_LIM) div 2<br/> if DATA_ARR[MID_VAL] = TO_FIND then<br/> LOC = TRUE<br/> else<br/> if TO_FIND < DATA_ARR[MID_VAL] then<br/> UP_LIM = MID_VAL - 1<br/> else<br/> LOW_LIM = MID_VAL + 1<br/> end if<br/> end if<br/>end loop<br/>if LOC = TRUE then<br/> output TO_FIND, \"is in the array\"<br/>else<br/> output TO_FIND, \"is NOT in the array\"<br/>end if</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the trace table for <strong>Algorithm 1</strong> using <code>TO_FIND = 39</code>.</p>\n<p>The first value of the first row has been done for you.</p>\n<p style=\"text-align:left;\"><img src=\"\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the constant used in <strong>Algorithm 1</strong>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the trace table for <strong>Algorithm 2</strong> using <code>TO_FIND = 50</code>.</p>\n<p>The first two values of the first row have been done for you.</p>\n<p><img src=\"\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why <code>MID_VAL</code> could not be a constant.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Evaluate the use of a sequential search and a binary search including the advantages and disadvantages of each.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for </em><code>TO_FIND</code><em> and </em><code>LOC</code><em> columns;</em><br/><em>Award <strong>[1]</strong> for </em><code>ITERATE</code><em> column;</em><br/><em>Award <strong>[1]</strong> for </em><code>DATA_ARR[ITERATE]</code><em> column; </em><em><br/>Award <strong>[1]</strong> for the correct output;</em></p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/><code>LIMIT</code></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for </em><code>LOW_LIM</code> column;<br/><em>Award <strong>[1]</strong> for </em><code>UP_LIM</code> column;<br/><em>Award <strong>[1]</strong> for </em><code>MID_VAL</code> and <code>DATA_ARR[MID_VAL]</code> columns;<br/><em>Award <strong>[1]</strong> for </em><code>TO_FIND</code><em>, </em><code>LOC</code> and Output columns;</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>The value (of <code>MID_VAL</code>) changes during the operation of the algorithm;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>.</p>\n<p><em>Award <strong>[3 max]</strong> for sequential search</em><br/>The algorithm searches through every element in the array starting at the beginning and working through one after the other;<br/>…until the required item is found;<br/>This method is potentially slow if the data set is large and the required element is towards the end of the list;<br/>The data does not need to be in any particular order;</p>\n<p><em>Award <strong>[3 max]</strong> for binary search</em><br/>The data must be sorted before it is stored;<br/>After comparing the data set with the target data, half of the data can be discounted using a simple condition;<br/>…enabling the target to be more quickly located;</p>\n<p><em>Note to examiners: Big O notation is not on the syllabus so answers with reference to this are not expected, however, if this type of answer is seen, please allow, for example</em>:</p>\n<p>Sequential: main disadvantage is O(N) so inefficient;<br/>advantage is that it works with an unsorted array;<br/>Binary search: main advantage is that it’s efficient as it’s O(log n);<br/>disadvantage is that the array must be sorted (and so must be sortable – not all data has a defined sort order);<br/>Binary search cannot be performed on a linked list but a sequential search can;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally constructed the correct trace table for this question; however, marks were often lost by not providing the correct quantity of iterations for the trace, or by making errors in how the output would actually appear if the program ran.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates correctly identified LIMIT as the constant in the algorithm.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally performed less well on the trace for the second algorithm (binary search), with similar errors to the trace carried out in part (a). Also, as this algorithm required more processing, additional errors included incorrect calculations of the variables, leading to incorrect values being displayed in the trace table.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates gave an appropriate reason why the variable MID_VAL could not be a constant in the given algorithm.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Virtually all candidates were able to evaluate the use of a sequential and a binary search, with many of these candidates achieving high or full marks. One point that was often missing form candidates’ responses, however, which is fundamental to the topic, was the need for the data to be sorted/ordered for a binary search to work.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "22M.1.SL.TZ0.14",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Armour Hardware Company</em> has the following data about salespersons and the quantities of items sold.</p>\n<p>Each salesperson can sell many different products.</p>\n<p style=\"text-align: center;\"><strong>SALES_PERSON</strong></p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> reasons why databases are normalized.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why the <strong>SALES_PERSON</strong> table is not in 1st Normal Form (1NF).</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the 3rd Normal Form (3NF) of the unnormalized relation shown above.</p>\n<div class=\"marks\">[8]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why it is necessary to ensure that referential integrity is maintained in databases.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why a primary key may consist of more than one attribute.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Applications interacting with the database are minimally affected;<br/>When a fully normalized database structure is extended, to accommodate new types of data, database structure can remain largely or entirely unchanged;<br/>So, the applications interacting with the database are minimally affected;</p>\n<p>Key dependent;<br/>Every non-key column in every table is directly dependent on the key, the whole key and nothing but the key;<br/>Thus making reduced redundancies, lesser anomalies and better efficiencies;<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>For First Normal Form, each attribute value should be atomic;<br/>In the given example product_Num, Pro_Name, Unit_Price and Qty is multivalued / All 4 tuples shown have multiple values in their first 4 attributes;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[8 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for each correct table up to <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for each correct primary key up to <strong>[4 max]</strong></em>.</p>\n<p><strong>3NF</strong><br/>Product_Number<br/>Product_Number, Unit_Price, Product_Name</p>\n<p>Sales_Person<br/>Sales_Person_Number, Sales_Person_Name, Manager_Number</p>\n<p>Manager<br/>Manager_Number, Manager_Name</p>\n<p>Purchases<br/>Purchase_ID, Date_And_Time, Product_Number, Sales_Person_Number</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>You can enter foreign keys that do not match the corresponding primary key in the related table;<br/>This could cause a lot of problems such as mismatched customer data and mismatched transaction records;</p>\n<p>Cascading update;<br/>If the primary key for a record in the Managers table changes, all corresponding records in the Employees table are modified;</p>\n<p>Cascading delete;<br/>If a record in the Managers table is deleted, all corresponding records in the Employees table are deleted;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>The combination of the two provides unique identifiers for the records of the table;<br/>And that there is no single attribute that is able to uniquely identify a record;<br/>In a manner that will not lead to potential duplication of records;<br/>It identifies exactly one record of the table, then that record shows the single value of each of the non-key attributes;<br/>That is associated with the unique combination of the key attributes;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students were clear about normalisation in removing redundancy but only a few could identify reasons of key dependencies and interaction of the applications with the database.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students were able to identify why the data was not in First Normal Form but some of the students could not use the terms ‘atomic’ or ‘multi-valued’.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students are able to correctly split the tables but only a few identified the foreign keys. The primary keys were in most cases identified.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many students could not explain the referential integrity.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most students understood the composite keys and the need for them.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.3",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Direct observation is a technique used by a system analyst to determine user requirements for updating a computer system.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> advantage of direct observation.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> disadvantage of direct observation. </p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for an advantage up to <strong>[1 max]</strong></em>.</p>\n<p>Direct observation is systematic/structured process;<br/>Direct observation allows that current computer system can be studied in its natural setting;<br/>Direct observation provides a better understanding of the way computer system is used;<br/>etc.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for a disadvantage up to <strong>[1 max]</strong></em>.</p>\n<p>Direct observation is susceptible to observer bias;<br/>Direct observation also can affect the behavior of users/process being observed;<br/>Direct observation is time consuming;<br/>etc.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.3",
|
||
"topics": [
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The growth of the Internet has led to increased levels of collaboration between different IB World Schools.</p>\n</div><div class=\"specification\">\n<p>The World World Web consisted of over 1350 million web pages in 2017. Each web page is accessed by typing its uniform resource locator (URL) into the address bar of the browser.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why a distributed network such as the World Wide Web may act as a catalyst to increase the collaboration between different IB World Schools.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> function of a web browser.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how a domain name server (DNS) functions.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the use of a distributed network, such as the World Wide Web, may lead to copyright and intellectual property issues.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>The Internet is growing exponentially meaning that more and more nodes (in this case IB World Schools) can be added;<br/>This has led to greater connectivity between the different nodes;<br/>However, the number of hops required to transmit information from one node to another is growing linearly;<br/>Therefore, each node can access the increased number of nodes with no discernible latency which makes increased levels of collaboration between these nodes possible and desirable;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Browser Retrieves a Web Page;<br/>The web browser retrieves (or fetches) code, usually written in HTML (HyperText Markup Language) and other computer languages, from a web server;<br/>Then, it interprets this code and displays it as a web page for you to view;</p>\n<p>Browser acts as a bridge between URL and DNS;<br/>The user inputs the URL / website domain name on web browser’s address bar;<br/>The web browser passes this website domain name to a domain name server;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>User type the domain name into the URL search area on the web browser and press “Enter” on the keyboard.</p>\n<p>The domain name is intercepted by a “Domain Name Server” or DNS.</p>\n<p>The main function of the DNS is to look up in its database the domain name you have typed and find the matching IP address.</p>\n<p>It then forwards the request onwards, using this address.</p>\n<p>If it cannot find the IP address in its own database, it then contacts other Domain Name Servers until it finds it, or if it can't find it anywhere, it displays a “web site not found” message to you.</p>\n<p>When the request reaches the destination, the pages are sent back.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/><em><strong>Copyright issues [3 max]</strong></em><br/>Copyright issues may occur because of the ease of access to materials on the World Wide Web;<br/>When material is accessed on the World Wide Web it may breach copyright rules in a number of ways (such as copying / publishing/ public display), often without the user realizing they have done so;<br/>It may also be a potential issue of the user is not aware of the complicated and extensive copyright laws;<br/>The continuing technical evolution of the web may mean that new practices emerge that may inadvertently breach existing copyright laws;</p>\n<p><em><strong>IP [3 max]</strong></em><br/>Potential IP issues may occur with web sites for a number of reasons such as being linked to copyright, trademarks, patents;<br/>When material is downloaded it may breach IP rights;<br/>When material is modified without author’s permission;<br/>These IP rights may vary between countries which leads to some acts being an IP issue on one country, but not in another;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>There were a lot of vague responses with few homing in on the fact that the \"distributed\" nature of the web was the key element.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Being an \"explain\" question the answers required knowledge of \"how\" or \"why\". Not that many explained the importance of the translation feature of a browser.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates identified some of the steps involved but omitted to say that the IP address would be returned to the original browser.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This wasn't particularly well-answered with few understanding the differences between intellectual property and copyright issues. Many alluded to the problems of identification but few included the idea that regulations differ from country to country.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.9",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-3-distributed-approaches-to-the-web",
|
||
"c-1-creating-the-web",
|
||
"c-4-the-evolving-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct a logic diagram for the following expression.</p>\n<p style=\"text-align:center;\">NOT A OR (A AND B) </p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for a logic diagram representing A OR B with 2 inputs, 1 output and 3 logic gates.</em><br/><em>Award <strong>[1]</strong> for the OR gate having 2 inputs, one of which is NOT A.</em><br/><em>Award <strong>[1]</strong> for another input to the OR gate, which is A AND B.</em></p>\n<p><em><img src=\"\"/></em></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.4",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An international company is in the process of moving its Head Office from Europe to Asia.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> possible compatibility issues as a part of data migration.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how a virtual private network (VPN) will allow employees who are in Europe to communicate with the Head Office in Asia.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> social issue associated with this process.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each possible compatibility issue identified up to <strong>[2 max]</strong></em>.</p>\n<p>Language differences/different character set;<br/>Different conventions of representing various data/currencies, dates, etc.;<br/>Incompatible software/incompatible hardware;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying how VPN will allow employees to communicate and <strong>[1]</strong>for a development up to <strong>[2 max]</strong></em>.</p>\n<p>VPN allows secure communication with the Head Office in Asia;<br/>A VPN is the company’s private network that uses a public network (in this situation the Internet) to connect remote sites/employees together;<br/>Privacy is protected using VPN tunneling;<br/>VPN uses encrypted connections routed through the Internet from the company's private network (Europe)to the remote site in Asia (or employee);<br/>Hiding IP addresses to prevent unwanted exposure and data leaks;<br/>Data security is ensured by encryption – anyone intercepting the encrypted data cannot read it;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying an issue and <strong>[1]</strong> for an expansion up to <strong>[2 max]</strong></em>.</p>\n<p>Employees who will not be willing to move to Asia;<br/>Lost jobs / finding new job / income decreased;</p>\n<p>Employees who will move to Asia;<br/>Personal or family issues during the period of moving or in a new environment / finances and cost of living / services such as schools, hospitals, transport / language problems;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.5",
|
||
"topics": [
|
||
"topic-1-system-fundamentals",
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"1-1-systems-in-organizations",
|
||
"3-1-networks",
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The rise in global temperatures has led to the melting of the sea ice in polar regions. Scientists have developed a number of computer models that can be used to make predictions about the rate of sea ice melting in these polar regions and its effect on coastal areas globally. In order to create a computer model a number of variables are identified.</p>\n<p>A computer model of the effects of the melting of the sea ice in the Arctic Ocean may include the following variables:</p>\n<ul>\n<li>average ocean surface temperature (°C)</li>\n<li>albedo of the ocean (the proportion of light reflected from the ocean surface)</li>\n<li>precipitation (mm)</li>\n<li>salinity of the ocean (grammes of salt in one kilogramme of water)</li>\n<li>area of sea ice (km<sup>2</sup>).</li>\n</ul>\n</div><div class=\"specification\">\n<p>In this model the following rules have been determined:</p>\n<ul>\n<li>for every 0.01 °C increase in ocean surface temperature, the area of sea ice decreases by 1 %</li>\n<li>for every 1 % decrease in the area of the sea ice, the sea level rises by 20 mm.</li>\n</ul>\n<p>The initial values are:</p>\n<ul>\n<li>area of sea ice = 1 000 000 km<sup>2</sup></li>\n<li>average surface temperature of the ocean is 0.00 °C.</li>\n</ul>\n</div><div class=\"specification\">\n<p>The scientists observed when running the model numerous times using historical data there were significant differences between observed and expected results.</p>\n<p>A second model was developed that included new variables and rules.</p>\n<p>The surface of the ocean reflects the heat from the sun. The ratio between the area covered by the sea ice and the area where there is no sea ice (open ocean) affects the value of the average albedo. The lower the albedo, the quicker the sea ice will melt.</p>\n<p>The average albedo is calculated using this formula:</p>\n<p>Average albedo =</p>\n<p><math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mfrac><mrow><mo>(</mo><mi>area</mi><mo> </mo><mi>of</mi><mo> </mo><mi>sea</mi><mo> </mo><mi>ice</mi><mo> </mo><mo>×</mo><mo> </mo><mi>albedo</mi><mo> </mo><mi>of</mi><mo> </mo><mi>sea</mi><mo> </mo><mi>ice</mi><mo>)</mo><mo> </mo><mo>+</mo><mo> </mo><mo>(</mo><mi>area</mi><mo> </mo><mi>of</mi><mo> </mo><mi>open</mi><mo> </mo><mi>ocean</mi><mo> </mo><mo>×</mo><mo> </mo><mi>albedo</mi><mo> </mo><mi>of</mi><mo> </mo><mi>open</mi><mo> </mo><mi>ocean</mi><mo>)</mo></mrow><mrow><mo>(</mo><mi>area</mi><mo> </mo><mi>of</mi><mo> </mo><mi>sea</mi><mo> </mo><mi>ice</mi><mo> </mo><mo>+</mo><mo> </mo><mi>area</mi><mo> </mo><mi>of</mi><mo> </mo><mi>open</mi><mo> </mo><mi>ocean</mi><mo>)</mo></mrow></mfrac></math></p>\n<p><strong>Note</strong>:</p>\n<ul>\n<li>area of sea ice = 1 000 000 km<sup>2</sup></li>\n<li>area of open ocean = 1 000 000 km<sup>2</sup></li>\n<li>albedo of sea ice = 0.6</li>\n<li>albedo of open ocean = 0.1.</li>\n</ul>\n<p>The average albedo will change with every iteration of the model. Each iteration is 2 years after the previous.</p>\n<p>The rules for the model are:</p>\n<ul>\n<li>the initial albedo is 0.35</li>\n<li>the rate of decrease in sea ice every 2 years is <math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mfrac><mrow><mn>0</mn><mo>.</mo><mn>3</mn></mrow><mrow><mi>average</mi><mo> </mo><msup><mi>albedo</mi><mn>2</mn></msup></mrow></mfrac></math></li>\n<li>the starting year is 2019</li>\n<li>the sample rate is every 2 years.</li>\n</ul>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the following table showing each variable’s data type and a suitable range of values that would represent the information shown above.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using the rules and initial values above, construct the pseudocode that would enable the area of the sea ice and the sea level rise to be calculated if there was an increase of 0.04 °C in the ocean surface temperature.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using the information above state the area of the sea ice.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using the information above state the change in sea level.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using the formula, rules and initial data given above, construct the pseudocode that would calculate the year that the area of sea ice will be less than 10 000 km<sup>2</sup>.</p>\n<div class=\"marks\">[7]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> ways that this model could be implemented.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the accuracy of the simulation in predicting the area of the sea ice is critical.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/><img src=\"\"/></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Initialization – Original area of sea ice;<br/>Initialization – Surface temperature change;<br/>New sea ice area calculation;<br/>Sea level change calculation;</p>\n<p><em>Example algorithm</em>:</p>\n<pre>OriginalSeaIceArea = 1000000<br/>SurfaceTempChange = 0.04<br/>NewSeaIceArea = OriginalSeaIceArea * (1 – SurfaceTempChange)<br/>SeaLevelChange = -(NewSeaIceArea - OriginalSeaIceArea) / OriginalSeaIceArea * 100 * 20</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>960 000 (km<sup>2</sup>);</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>80 (mm);</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[7 max]</strong></em>. <br/>Initialization – Initial areas of Ice and water, and starting year;<br/>Use of loop;<br/>Loop parameters (limits, condition, increment, end statement correct);<br/>Average albedo;<br/>Rate of decrease calculation;<br/>Area of ice update calculation;<br/>Area of open water update calculation;<br/>Output;</p>\n<p><em>Example algorithm</em>:</p>\n<pre>IceArea = 1000000<br/>OpenArea = 1000000<br/>Year = 2019<br/>Loop While IceArea > 10000<br/> TotalArea = IceArea + OpenArea<br/> AveAlbedo = ((IceArea * 0.6) + (OpenArea * 0.1)) / (IceArea + OpenArea)<br/> Decrease = 0.3 / (AveAlbedo * AveAlbedo)<br/> // allow Decrease = 0.3 / AveAlbedo ^ 2<br/> IceArea = IceArea * (1 − (0.01 * Decrease))<br/> OpenArea = TotalArea − IceArea<br/> Year = Year + 2<br/>End loop<br/>Output \"Date when there less than 10 000km2 of ice in the ocean <br/>is \" Year</pre>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/> Spreadsheets;<br/>IDEs using code;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>If the calculation of the rate of reduction of the sea ice is inaccurate the calculation of the amount of sea ice remaining;<br/>At a given time will turn out to be wrong;<br/>So, work to correct the problems may be too little/too great;<br/>The year in which the sea ice is predicted to be 10 000 km<sup>2</sup>;<br/>Will be wrong;<br/>So, ice coverage may be more/less than expected in the calculated year;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates recognized this as a straightforward question. However, some candidates were unable to demonstrate the concept of data types and range of values for given variables.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question was reasonably well answered and most candidates were able to produce some pseudocode. However, a few candidates struggled to apply all the required formulae and couldn’t produce all the required values.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was answered correctly by most of the candidates.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was answered correctly by most of the candidates.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of candidates could not produce the correct pseudocode to calculate all the required values.</p>\n<p>The skill to apply a loop in this question was poorly demonstrated by most of the candidates.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was not well understood by the majority of the candidates. Most of the responses were generic and off course.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates did not answer the question appropriately and focused more on generic points rather than being specific to the scenario.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.4",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-1-the-basic-model",
|
||
"b-2-simulations"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>State <strong>three</strong> operating system resource management techniques.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em><br/>scheduling;<br/>policies;<br/>multitasking;<br/>virtual memory;<br/>paging;<br/>interrupt;<br/>polling;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>A well answered question.</p>\n</div>",
|
||
"question_id": "22M.1.HL.TZ0.8",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>To improve customer satisfaction, a supermarket chain wants to create an object-oriented program (OOP) to simulate the lines of customers at the check-outs in their point of sale (POS) system.</p>\n<p>This point of sale (POS) system consists of several check-out counters. After filling their shopping carts with items, customers line up at one of the check-out counters. In most cases, they wait in line until it is their turn to pay.</p>\n<p>Three real-world objects are implemented using the following classes:</p>\n<p><img src=\"\"/></p>\n<p>The UML diagram for the class <code>POSline</code> is provided below.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the relationship between the <code>POSsystem</code> and <code>POSline</code> objects.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Draw a diagram to show the relationship between the objects <code>POSsystem</code>, <code>POSline</code> and <code>Cart</code>. You are not required to draw a complete UML diagram.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>identifier</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between a class and an instantiation. You must make reference to the UML provided.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the code fragment that instantiates an array <code>line</code> of 20 <code>Cart</code> objects.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method <code>public void joinLine(Cart newCart)</code> that adds a <code>newCart</code> to <code>line</code> in the next empty <code>array</code> location. You may assume that <code>line</code> is not full.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the method <code>public Cart leaveLine(int n)</code> that removes the cart at position <code>n</code> from <code>line</code> by shifting down all the array entries bigger than <code>n</code>, before returning the indicated <code>Cart</code> object. You may assume that a cart exists at position <code>n</code>.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>Aggregation;<br/>POSsystem has a (many) POSline(s);<br/><em>Allow 1 to many</em>;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for one POSsystem connecting to multiple POSlines;</em><br/><em>Award <strong>[1]</strong> for one POSline connecting to multiple Carts;</em></p>\n<p><em>Example answer</em>:</p>\n<p><img src=\"\"/></p>\n<p> </p>\n<p><em>Allow diagram showing aggregation for both (diamond at POSsystem end or 1 to many)</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>The (unique) name of a program element (variable / method / class);<br/><em>Must have “name” or equivalent</em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <em>[1 mark each] for definitions of a class and an object and [1 mark] </em><em>for an example relating to the UML diagram that involves both class and object for </em><em>either the POSline or the Cart classes</em>.</p>\n<p>The class is the blueprint / template of an object / defines the actions and properties of an object / an abstract representation of an object;<br/>An instantiation is the (creation of an) actual object / example of an object / object filled with data / assigned space in memory;</p>\n<p>The class <code>POSline</code> stores instantiated objects of the <code>Cart</code> class;<br/>The class <code>POSline</code> uses the constructor to set the (object’s) variables;<br/>An instance of <code>POSline</code> has values for id, active and line;<br/><em>Allow similar example for the Cart object</em>;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <em> <br/>Award <strong>[1]</strong> for using <strong><code>new</code></strong>;<br/>Award <strong>[1]</strong> for <code>Cart[20]</code>;<br/>Allow with or without </em><code>private</code><em>.<br/></em></p>\n<p><code>private Cart[] line = <strong>new</strong> Cart[20];</code></p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <em> <br/></em></p>\n<p>Award <strong>[1]</strong> for correct loop construction (for a while loop this includes initialization and incrementation);<br/>Award <strong>[1]</strong> for correct condition (can be within the loop construct);<br/>Award<strong> [1]</strong> for correct assignment;<em><br/></em></p>\n<pre>public void joinLine(Cart newCart){<br/> int i=0;<br/> while (this.line[i] != null) {i++;}<br/> this.line[i] = newCart;<br/>}</pre>\n<p><em>Notes: Do not penalize the absence of the keyword “this” in any question.</em><br/><em>With for loops, allow variations of line.length() – mark the logic</em></p>\n<p><em>Further examples:</em><br/><em>Note: if the answer takes size of array into account then the given condition <span style=\"text-decoration:underline;\">must</span> be correct</em>.</p>\n<pre>public void joinLine(Cart newCart)<br/>{<br/> int i=0;<br/> boolean placed = false;<br/> while (i<20 && placed = false)<br/> {<br/> if this.line[i]= null;<br/> {<br/> this.line[i] = newCart;<br/> placed = true;<br/> }<br/> i = i+1;<br/> {<br/>}<br/><br/>public void joinLine(Cart newCart)<br/>{<br/> for (int i; i<20; i++)<br/> {<br/> if (this.line[i] == null)<br/> {<br/> this.line[i] = newCart;<br/> break;<br/> }<br/> {<br/>}</pre>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <em> <br/></em></p>\n<p><em>Award <strong>[1]</strong> for declaring, initialising and returning a </em><code>Cart</code><em> variable;<br/>Award <strong>[1]</strong> for correct loop (including initialisation and incrementation);<br/>Award <strong>[1]</strong> for assigning / shifting;<br/>Award <strong>[1]</strong> for assigning </em><code>line[19]</code><em> to null;</em></p>\n<pre>public Cart leaveLine(int n){ // given in the stem<br/> Cart result = this.line[n];<br/> for (int i=n; i<19; i++){<br/> this.line[i] = this.line[i+1];<br/> }<br/> this.line[19] = null;<br/> return result;<br/>}</pre>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was well-answered.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Those who answered part (a) correctly tended to answer this well. Most used uml diagrams to show the relationships either with words or by using the correct arrows.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Generally well-answered.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was one of several questions in which reference to the scenario was required. This is to reward the candidates' understanding as opposed to simple memory recall. Not all candidates managed to make this connection.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>These 3 question parts tended to divide the candidates into those who were comfortable with OOP construction as those who weren't. To a certain extent this seemed to be school dependent.</p>\n<p>Straight-forward for those competent with Java.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>These 3 question parts tended to divide the candidates into those who were comfortable with OOP construction as those who weren't. To a certain extent this seemed to be school dependent.</p>\n<p>Generally well-answered, helped partly by the assumption that the array was not full. It was particularly pleasing to see the answers that included a while loop as candidates seem to be reluctant to use this type of loop construction even when logically it makes sense to do so.</p>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>These 3 question parts tended to divide the candidates into those who were comfortable with OOP construction as those who weren't. To a certain extent this seemed to be school dependent.</p>\n<p>Few managed to achieve full marks as four separate operations were required. The assignment statement was linked to the loop conditions there were interesting variations - but is was essential not to try to access an array index that was out of bounds and therefore did not exist. Many omitted setting the last value to null.</p>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.10",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-1-objects-as-a-programming-concept",
|
||
"d-3-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> characteristic of a queue.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> application of a queue.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>A linear (abstract) data structure;<br/>First in First out/FIFO;<br/>Elements can only be added at one end(rear/tail) and removed from the other (front/head);<br/>Once a new element is inserted into the queue (enqueue), all the elements inserted before the new element in the queue must be removed (dequeue), to remove the new element;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>Print queue;<br/>CPU task scheduling;<br/>Simulation of a real-life scenario (call centre, supermarket queue);<br/>Playlist queue;<br/>Interrupt queues;<br/>Queues in routers and switches;<br/>Mail queues;<br/>Buffers in devices like keyboard;<br/>Website traffic;</p>\n<p><em>Note to examiners: Reward other reasonable responses</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates correctly answered this question.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates correctly answered this question.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "22M.1.HL.TZ0.9",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Describe how data is transmitted by packet switching.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p>Packet switching entails data being separated into specially formatted units (packets);<br/>Each packet contains data and information such as packet number, address that identifies the sending computer and intended recipient, etc.;<br/>Packets are routed from source to destination using (different) network switches and routers;<br/>Using these addresses, network switches and routers determine how best to transfer the packet on the path to its destination;<br/>Packets are reassembled at the destination (using packet numbers);<br/>If any of packets is missing it should be retransmitted;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.6",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Construct a trace table for the following algorithm</p>\n<pre>A = 3<br/>B = 7<br/>loop while B >= A<br/> A = A + 1<br/> output(B − A)<br/> B = B − 1<br/>end loop</pre>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for a trace table with at least three columns</em>.<br/><em>Award <strong>[1]</strong> for each correct column (out of the four columns − A, B, B >= A, output)</em>.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.7",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Define the term child in relation to a binary tree.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Child (is either null or) is a node that has up to two references /links to other nodes;<br/>and has (only) one predecessor (parent) node;</p>\n<p>“Child” is every node in a binary tree which is descendant/ the node which has a link from its predecessor (the node which is a predecessor of any node is called as parent node);<br/>The child node can have up to two descendants (child nodes);<br/>(All the nodes except the node which is the origin of the binary tree data structure (called root) are child nodes;)</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>This question generated responses that were a little vague.</p>\n</div>",
|
||
"question_id": "22M.1.HL.TZ0.10",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between random access memory (RAM) and read only memory (ROM).</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the function of an operating system in managing primary memory.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the roles of the data bus and the address bus in the machine instruction cycle.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State how the data stored in the byte will be represented in hexadecimal.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State how many integers could be represented in this byte.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why this byte could not be used to represent characters such as those used in Chinese.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a truth table with two input variables. If the input variables are equal the value of the output variable should be True, otherwise it should be False.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.</p>\n<p>RAM acts as temporary storage of data, instructions and programs currently running (for the operating system and for the running applications) whilst ROM is permanent memory (stores the instructions and data that won't change/stores the instructions that the computer needs in order to boot up;<br/>Memory access, both read and write operations are performed on RAM whilst ROM works with read only operation;<br/>If power failures happened during access to RAM then all data will be permanently lost/RAM is volatile memory/whilst if power failure happened during the ROM access no data will be lost/ROM is non-volatile memory;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for the answer saying that the function of OS in primary memory management is allocation of specific memory blocks to individual programs and <strong>[1]</strong> for reallocation up to <strong>[2 max]</strong></em>.</p>\n<p>A part of the OS (memory manager) assigns that block of memory to the program when a running program requests a block of memory;<br/>When the program no longer needs the data in previously allocated memory blocks, they become available for reassignment;</p>\n<p>OS ensures the availability of adequate memory for data structures/objects of each running program at all times;<br/>By allocating the memory portions to programs after freeing the space (of the computer memory);</p>\n<p>OS (memory management unit) uses virtual memory which provides secondary memory (external storage) for program that does not have enough space in RAM for execution;<br/>After execution of the program this memory is reallocated (used by other programs)/freed;</p>\n<p><em>Note to examiners: Award only <strong>[1]</strong> an answer such as “OS maintains file allocation table”</em>.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p>Bus is defined as a system that transfers data between hardware components/data bus and address bus enable a processor to communicate with the primary memory;<br/>When the computer processor needs to fetch an instruction from the memory it uses the address bus to specify the (physical) address (of the memory block it needs to access);<br/>It will get the data from (the specific) memory (block) (after checking the address bus to get the read address);<br/>And then it will place this data on to the data bus/data bus carries the data;<br/>When the processor wants to store results of execution to the memory it will set the write address on the address bus;<br/>And put the data/results/to be written to memory on to the data bus (to carry this data);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>5E;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.</p>\n<p>2<sup>8</sup>/256;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying why this byte could not be used to represent characters such as those in Chinese and <strong>[1]</strong> for an expansion up to <strong>[2 max]</strong></em>.</p>\n<p>The characters must be represented as numbers so that computer can deal with them;<br/>One byte (gives us the ability to represent only 256 characters) is enough to hold every possible character in a language which uses a limited set of text symbols, punctuation marks and special characters (for example, English, Spanish, etc.);<br/>Chinese exceeds the 256 character limit and therefore requires more bytes to represent all of the characters in this language;</p>\n<div class=\"question_part_label\">c.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for all four input combinations (A,B)</em>.<br/><em>Award <strong>[1]</strong> for all four correct output values (C)</em>.<br/><em><strong>Note</strong>: 1 == True, 0 == False</em>.</p>\n<p style=\"text-align:center;\"><img src=\"\"/></p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.8",
|
||
"topics": [
|
||
"topic-2-computer-organization"
|
||
],
|
||
"subtopics": [
|
||
"2-1-computer-organization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Cars have many automated features to improve the driving experience. One example is the use of headlights that automatically switch on and off.</p>\n</div><div class=\"specification\">\n<p>Some cars have adaptive cruise control. This uses RADAR technology and a processor to ensure the car stays the same distance away from the car in front.</p>\n</div><div class=\"specification\">\n<p>A system with many functions operating independently could be managed using either centralized or decentralized processing.</p>\n</div><div class=\"specification\">\n<p>As vehicles become fully autonomous (self-driving), ethical considerations must be taken into account when designing software.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>one</strong> input device used by the automated headlights.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the interaction between the inputs, processing and the outputs of the feedback loop ensure the car stays the same distance away from the car in front.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Discuss the use of centralized and decentralized processing in the context of control systems such as those involved in the operation of motor vehicles.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> ethical concern that must be considered in the development of autonomous vehicles.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em><br/>photoelectric sensor;<br/>light sensor;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em><br/>Sensor (continuously) collecting data (related to the distance between the two vehicles);<br/>Data is converted to digital using ADC…;<br/>…and sent to the processor;<br/>Processor has access to pre-set data (minimum distance required between the two cars);<br/>Processor compares the input data against stored/pre-set data;<br/>If the vehicle is too close, the processor sends a signal to an actuator to apply the brakes/ an output signal (for example, warning light on the dashboard/ audible warning) to the driver to apply break;<br/>If the car has fallen back from the car in front, the processor sends a signal to an actuator to apply acceleration/ an output signal to the driver to apply acceleration;<br/>This process is constantly looped (feedback loop);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em><br/><em>Award <strong>[2 max]</strong> for centralised processing</em><br/>Centralized processing would allow the different features of the car to be controlled by a single processor;<br/>… this means that different features of the car are less likely to impact on the operation of other features, as the central processor can coordinate them;</p>\n<p><em>Award <strong>[2 max]</strong> for decentralised / distributed processing</em><br/>Decentralized processing allows each of the car’s features to have its own processor;<br/>… enabling each feature to function independently/more quickly;</p>\n<p><em>Award <strong>[1 max]</strong> for concluding statement</em><br/>Centralized processing is more complex for the manufacturer to program, but is possibly safer as the different components coordinate;<br/>Centralised processing is more expensive to achieve as the whole system needs to be coordinated in real time;<br/>Decentralised processing has a faster response (time due to the use of multiple smaller PLCs);<br/>Decentralised processing is simpler/cheaper for the car manufacturer as they can use standard parts that are already programmed, but it is more difficult to get them to coordinate with each other;<br/>Decentralised processing allows scalability, the subsystems can be easily customised;<br/>A crash in a centralized system would result in failure of the whole system / a critical system failure so would have far greater consequences than in a decentralized system where the system may be able to partially function hence are riskier than decentralized ones;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em><br/>Autonomous vehicles can be seen as more dangerous to pedestrians/cyclists;<br/>…as they have to be programmed to react to avoid unpredictable movements from them;<br/>The ethical consideration is how might the processor decide whether to avoid the cyclist to hit a pedestrian instead (trolley problem);</p>\n<p>When autonomous vehicle control systems are perfected;<br/>… they should be safer than human drivers;<br/>… it may then be an ethical consideration as to whether a human who cannot drive should be the responsible person in the autonomous vehicle?;</p>\n<p>An autonomous driving system could collect detailed information about the movements of the car;<br/>… this information could reveal where individuals go, and raise privacy concerns;<br/>… which could be exploited for commercial gain/ be considered as a form of surveillance (an ethical consideration);</p>\n<p>There may be times when an accident is unavoidable (the trolley problem);<br/>The autonomous vehicle has to make a ‘decision’ about who to hit;<br/>In this case is the driver, the manufacturer, the software engineer or the third party accountable?;</p>\n<p><em>Note to examiners: accept other reasonable answers</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question was reasonably answered except by weaker candidates</p>\n<p>Some candidates failed to achieve full marks as result of incomplete and vague answers.</p>\n<p>Some candidates demonstrated poor understanding of control systems.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many responses to part (b) were verbose while missing crucial information that would award the mark.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "22M.1.HL.TZ0.13",
|
||
"topics": [
|
||
"topic-7-control"
|
||
],
|
||
"subtopics": [
|
||
"topic-7-1-control"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Many health agencies are using simulations in an attempt to understand how their resources could be used in the future. With many countries experiencing aging populations, health agencies have worked with computer scientists to develop simulations that will enable them to manage their resources more effectively.</p>\n<p>One of the key features of these simulations is the development of “what-if” models.</p>\n</div><div class=\"specification\">\n<p>The following variables can be considered as part of a model to be used to simulate the management of an aging population:</p>\n<ul>\n<li>quality of health education</li>\n<li>lifestyle choices such as smoking</li>\n<li>residential region.</li>\n</ul>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the main features of a “what-if” model.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> other variables that could be included in this model.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the ethical issues that may arise from the collection of information for this model.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the model would be converted to a simulation.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Data is entered into a rule-based environment;<br/>The rules may be kept the same and the nature of the data input may be varied;<br/>Or the data that is input may remain the same and the rules may be varied;<br/>Which allows for a range of possible scenarios to be investigated;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Life expectancy;<br/>Gender;<br/>Availability of life-extending treatments;<br/>Genetic information;</p>\n<p><em>Allow other appropriate answers</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>.</p>\n<p><em>Example answer</em>:<br/>One ethical issue is invasion of privacy;<br/>to get the best quality model;<br/>sensitive personal data will need to be collected;<br/>trade-off between the benefits of this model and level of intrusion into people's lives;<br/>especially if the data is being shared with third parties;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Simulation may be used to handle uncertainty and provide ranges of expected outputs; e.g. repeatedly inputting data drawn from random samples of plausible input values;<br/>To look at the predicted spread of outcomes over time (consider the use of simulation in the analysis of queues);</p>\n<p>A simulation is considered to be a representation of a model over time;<br/>This means that the simulation can be used over a longer period of the development life cycle;<br/>It can be used to assist with stages such as the implementation stage;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates did not address the specific points related to a “what-if” model and provided a generic description of the model.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question was relatively well done. Most candidates were able to identify the correct set of variables.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates were able to identify and explain suitable ethical issues. A relatively small number of candidates had difficulty in developing their responses beyond generic points.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most responses tended to be generic. Candidates were unable to explain why the model would be converted to a simulation.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.5",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation",
|
||
"topic-1-system-fundamentals"
|
||
],
|
||
"subtopics": [
|
||
"b-2-simulations",
|
||
"b-1-the-basic-model",
|
||
"1-2-system-design-basics"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The supermarket chain wants to use this OOP simulation to experiment with different ways of organizing their check-out system. For example, it is possible to have different check-out counters such as cash-only or card only, or to have check-out counters for ten items or fewer.</p>\n</div><div class=\"specification\">\n<p>It is also possible to have one line that serves a number of check-out counters.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>inheritance</em>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>one</strong> advantage of the OOP feature “inheritance” with reference to this scenario.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> advantages of using libraries of classes.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> reasons why the use of multiple programming teams in different locations may be problematic when developing an integrated software solution.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <em> </em><br/>A new class is derived from an existing class;<br/>The new class inherits all <span style=\"text-decoration:underline;\">variables/data/properties and methods/behaviours</span> of the other class;<br/>The derived class is called a subclass/child, and the original is called a superclass/parent; </p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <em> </em><br/><em>Award <strong>[1]</strong> for an advantage;</em><br/><em>Award <strong>[1]</strong> for some elaboration;</em><br/><em>Award <strong>[1]</strong> for a reference to the context;</em></p>\n<p>Note: to a certain extent mixing and matching can take place</p>\n<p>It promotes code reuse;<br/>because the superclass <code>POSline</code>;<br/>holds common data and actions that are shared by all newly developed classes;</p>\n<p>It reduces maintenance overhead;<br/>because you only have to update the superclass;<br/>in this case <code>POSline</code>;</p>\n<p>allows extensibility / ability to create other classes easily;<br/>specific types of check-out can be created;<br/>reducing development time / costs / testing;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <em> </em><br/>Saves development time;<br/>Since classes and their methods do not need to be rewritten;</p>\n<p>Promotes abstraction;<br/>Because reusable code exists that functions without knowledge of internal working;</p>\n<p>Libraries contain error-free / robust code;<br/>because it has been used and tested many times;</p>\n<p>Promotes efficiency / organization;<br/>As code will be shorter / easier to read / develop;</p>\n<p>Familiarity with libraries;<br/>Allow for easier maintenance / modification;</p>\n<p><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <em>Mark as 4 separate points</em>.<br/>Teams may be located in different countries;<br/>therefore have communication issues;<br/>due to different languages;<br/>or different time zones;<br/>inability to discuss face-to-face;<br/>Problems with different conventions (e.g. date format);<br/>Managing the teams in different locations may be problematic (allow example);<br/>Teams may not collaborate well due to personality issues;<br/>Development time might increase;<br/>Due to time lags between communications;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>15(a)-(e) dealt with more general aspects of OOP. Candidates should look carefully at the wording in each question as to whether an explanation or description is required and at the number of examples/reasons etc. that are requested, as these aspects affect the way they should answer.</p>\n<p>Part (a) was a straight-forward definition.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>(b) asked for an explanation related to the scenario described. It should be clear from this type of question that full marks cannot be achieved if the scenario is not considered.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates generally answered the question on libraries well. Clearly candidates who have had extensive practical experience of coding with libraries would have been better prepared for this type of question.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The candidates generally came up with at least one appropriate reason.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.11",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-2-features-of-oop"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The flowchart below represents an algorithm that allows a user to enter the number of sides, length of side and apothem (see diagram below) for a regular polygon. It then calculates and outputs the area and perimeter of this shape.</p>\n<p><strong>Worked example: a regular hexagon</strong></p>\n<p>Number of sides = 6</p>\n<p>Length of side = 10 cm</p>\n<p>Apothem = 8.66 cm</p>\n<p>Perimeter = Number of sides × Length of side</p>\n<p> = 6 × 10 </p>\n<p> = 60 cm</p>\n<p>Area =<math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mfrac><mrow><mi>Perimeter</mi><mo> </mo><mo>×</mo><mo> </mo><mi>Apothem</mi></mrow><mn>2</mn></mfrac></math></p>\n<p><br/> = <math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mfrac><mrow><mn>60</mn><mo> </mo><mo>×</mo><mo> </mo><mn>8</mn><mo>.</mo><mn>66</mn></mrow><mn>2</mn></mfrac></math></p>\n<p> = 259.8 cm<sup>2</sup></p>\n<p style=\"text-align: center;\"><sup><img src=\"\"/></sup></p>\n<p style=\"text-align: center;\"><sup><img src=\"\"/></sup></p>\n<p style=\"text-align: center;\"><sup><img src=\"\"/></sup></p>\n</div><div class=\"specification\">\n<p>From the flowchart, pseudocode is to be created that will include sub‑programs to calculate and return the perimeter and area of the shape.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct pseudocode for the body of the following sub-program to calculate and return the perimeter of the shape.</p>\n<pre>SUB_PERIMETER(NUM_SIDES, LENGTH_SIDE)<br/> // Pseudocode to be added<br/>end SUB_PERIMETER</pre>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a similar sub-program to the one in part (i) to calculate and return the area of the shape.</p>\n<p>You must use an appropriate name for the sub-program and appropriate names for the parameters.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct pseudocode based on the flowchart to collect input from the user, call the sub-programs created in parts (i) and (ii), and output the results.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">a.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Without using pseudocode, explain how your algorithms could be altered to <strong>also</strong> find the area and circumference of a circle.</p>\n<p><strong>Note</strong>:</p>\n<p>Area of circle = <math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>π</mi><mi>r</mi></math><sup>2</sup></p>\n<p>Circumference of circle = 2<math xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>π</mi><mi>r</mi></math></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/><em>Award <strong>[1]</strong> for a correct formula that uses the passed arguments;</em><br/><em>Award <strong>[1]</strong> for a return statement;</em></p>\n<p><strong>Example 1</strong>:</p>\n<pre>SUB_PERIMETER(NUM_SIDES, LENGTH_SIDE)<br/> //Pseudocode to be added<br/> return NUM_SIDES * LENGTH_SIDE<br/>End SUB_PERIMETER</pre>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em><br/><em>Award <strong>[1]</strong> for a correct sub-program (function) defined with end statement;</em><br/><em>Award <strong>[1]</strong> for the correct arguments passed;</em><br/><em>Award <strong>[1]</strong> for the correct use of return;</em><br/><em>Award <strong>[1]</strong> for the correct formula used;</em></p>\n<p><strong>Example 1</strong>:</p>\n<pre>SUB_AREA(PERIM, APOTHEM)<br/> AREA = PERIM * APOTHEM / 2<br/> return AREA<br/>end SUB_AREA</pre>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em><br/><em>Award <strong>[1]</strong> for all three correct inputs;</em><br/><em>Award <strong>[1]</strong> for all three inputs with appropriate prompts;</em><br/><em>Award <strong>[1]</strong> for the correct definition of </em><code>PERIM</code><em>;</em><br/><em>Award <strong>[1]</strong> for the correct call of perimeter sub-program, including variables/arguments passed;</em><br/><em>Award <strong>[1]</strong> for the correct call of area sub-program, including variables/arguments passed;</em><br/><em>Award <strong>[1]</strong> for the return/output of both values;</em></p>\n<p><strong>Example 1</strong>:</p>\n<pre>//Main Program<br/>output \"Number of sides?\"<br/>input NUM_SIDES<br/>output \"Length of each side?\"<br/>input LENGTH_SIDE<br/>output \"Length of apothem?\"<br/>input APOTHEM<br/>PERIM = SUB_PERIMETER(NUM_SIDES, LENGTH_SIDE)<br/>output \"Perimeter is \", PERIM<br/>output \"Area is \", SUB_AREA(PERIM, APOTHEM)</pre>\n<div class=\"question_part_label\">a.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em></p>\n<p><em>Award <strong>[1]</strong> for determining whether the shape is a polygon or a circle</em><br/><em>Award <strong>[1]</strong> for inputting the radius (if a circle);</em><br/><em>Award <strong>[1]</strong> for the creation of new subprogram (for area) <strong>OR</strong></em><br/><em> changing values of input parameters for the existing one (SUB_AREA ) <strong>OR</strong></em><br/><em> the calculation using correct formula (as given in the question paper PI * RADIUS * RADIUS)</em><br/><em>Award <strong>[1]</strong> for the creation of a new subprogram (for circumference) <strong>OR</strong></em><br/><em> appropriately changing values of input parameters to the existing one (SUB_PERIMETER ) <strong>OR</strong></em><br/><em> the calculation using formula (as given in the question paper 2*PI * RADIUS)</em><br/><em>Award <strong>[1]</strong> for calling both subprograms / outputting both values</em><br/><em>Award <strong>[1]</strong> if after the alteration of the algorithm, it should still be able to calculate the area and the perimeter of the polygon as well as the area and the circumference of the circle</em></p>\n<p><strong>Example answer 1 (with existing subprograms, after inputting the three values: NUM_SIDES, LENGTH_SIDE, APOTHEM):</strong><br/>check if the inputted value for the NUM_SIDES is 1 or 0 (then the shape is a circle);<br/>then inputted value for LENGTH_SIDE is to be used as radius;<br/>2*3.14 should be set as NUM_SIDES and LENGTH_SIDE as APOTHEM;<br/>call already written sub-programs(SUB_AREA and SUB_PERIMETER) so that algorithm calculates/finds correct area of circle and circumference;<br/>if the shape is not a circle then code (as in Part(a)) for the polygon ( no other changes needed);</p>\n<p><strong>Example answer 2</strong> <strong>(with new subprograms for area and circumference created)</strong>:<br/>construct two new sub-programs (for example, getCircleArea and getCircumference) ;<br/>(in the main program) ask the user if the shape is a polygon or a circle;<br/>if it is a polygon then code is as written in part a (no changes);<br/>if it is a circle then ask the user to input the radius;<br/>call both new subprograms to output area and circumference/ call the getCircleArea(radius) to find area and getCircumference(radius) sub-program to find circumference;</p>\n<p><strong>Example answer 3</strong> <strong>(with simple if statement and formulas given in the question paper)</strong>:<br/>ask user to input if the shape is circle and use if statement to check this input value;<br/>if not circle then code for the polygon (as written in part a);<br/>otherwise (it is circle!) input radius;<br/>calculate area;<br/>and circumference using formulas given in the question;</p>\n<p><em>Note to examiners: there may be other examples of correct answers</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates constructed excellent algorithms in part (a).</p>\n<p>Some candidates showed little or no ability at algorithm construction.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates did not correctly call subprograms in part (a)(iii).</p>\n<div class=\"question_part_label\">a.iii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "22M.1.HL.TZ0.14",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming",
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An old set of 2D animated cartoons from the 1940s has been discovered and it is decided to modify them to turn them into 3D animation.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>visualization</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the need for rendering in the creation of the animated 3D characters.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>two</strong> technical implications of implementing a 3D animation in this way.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The creation of a human interpretable image from data;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>The characters are defined as mathematical models;<br/>They will need rendering to give a 3D effect;<br/>Each movement will need to be fluid;<br/>The animation is less interesting with flat figures;</p>\n<p><em>Allow mark for explanation of rendering</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/>Rendering for non-interactive media such as animations is a much slower process than for interactive media/games;<br/>Rendering times for individual frames may vary from a few seconds to days depending on the complexity of the scene;<br/>Rendered frames are stored to a hard disk and then transferred to other media for playback;<br/>3D rendering is computationally resource hungry;<br/>Computer processing power has increased rapidly and greatly over the years;<br/>Allowing a much higher degree of photorealism / realistic rendering;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was reasonably well answered by majority of the candidates.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most answers tended to be superficial and generic in nature. The responses were mostly focused on a description of rendering rather than why it was important in the process.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates focused on explaining the process of rendering and creating 3D animation rather than technical implications of doing so.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.6",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-3-visualization"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>When the number of customers in the supermarket is low, some check-out counters will close. When there are many customers waiting, a new check-out counter will open.</p>\n</div><div class=\"specification\">\n<p>When a new check-out counter opens, some customers from the nearest line will choose to move their carts to this check-out counter.</p>\n<p>For this simulation, the assumption is made that every second cart in the old line will move to the new line and the other carts will remain in the original line.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why the variable <code>active</code> in the UML of the class <code>POSline</code> was defined as a boolean data type.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the code for a method <code>split</code> (part of the class <code>POSsystem</code>), that takes an existing, non-empty <code>POSline</code> as a parameter. It should copy every second cart from the original line into a new line. Afterwards it should delete every second cart from the original line.</p>\n<p>An example call in <code>POSsystem</code> would be: <code>POSline number2 = split(number1)</code>, where <code>number1</code> is an existing <code>POSline</code>.</p>\n<p>You may use any method declared or developed.</p>\n<div class=\"marks\">[8]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>As a result of the simulation, the company has decided to create a new POS system for their supermarkets.</p>\n<p>There have been discussions about adapting existing open source code when developing modules of the new POS system.</p>\n<p>Describe <strong>two</strong> ethical issues that may arise if modules of the new POS system are developed from open source code.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><code>active</code> indicates that a POS counter is either open (true) or closed (false);<br/>boolean uses the least memory space / one bit to represent this data;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[8 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for a correct method header;</em><br/><em>Award <strong>[1]</strong> for correctly declaring and returning a new </em><code>POSline</code><em> variable;</em><br/><em>Award <strong>[1]</strong> for attempting to use modulo division / declaring and initialising a flag;</em><br/><em>Award <strong>[1]</strong> for a loop with one correct terminal condition, including increment of i;</em><br/><em>Award <strong>[1]</strong> for the second correct loop condition;</em><br/><em>Award <strong>[1]</strong> for correctly checking that i is odd / checking and setting the flag;</em><br/><em>Award <strong>[1]</strong> for copying a cart from the original line;</em><br/><em>Award <strong>[1]</strong> for correctly adding every second cart to the new line;</em><br/><em>Award <strong>[1]</strong> for a reasonable attempt at removing every second cart;</em><br/><em>Award <strong>[1]</strong> for correctly removing every second cart from the original line;</em></p>\n<pre><strong>public</strong> POSline split(POSline oldLine){<br/> POSline newLine = <strong>new</strong> POSline();<br/> Cart temp; // optional, see below<br/><strong> int</strong> i=0;<br/><strong> boolean</strong> remove=false;<br/><strong> while</strong>((i<20)&&(oldLine.getLine(i)!=<strong>null</strong>)){<br/><strong> if</strong> (remove) {<br/> temp = oldLine.getLine(i); // can be combined<br/> newLine.joinLine(temp);<br/> }<br/> remove = !remove;<br/> i++;<br/> }<br/> remove=false;<br/><strong> while</strong>((i<20)&&(oldLine.getLine(i)!=<strong>null</strong>)){<br/><strong> if</strong> (remove) {<br/> temp = oldLine.leaveLine(i)); // shifts carts<br/> remove = !remove;<br/> }<br/><strong> else</strong>{<br/> i++;<br/> }<br/> }<br/><strong> return</strong> newLine;<br/>}</pre>\n<p><em>Example answer using modulo division (MOD):</em></p>\n<pre><strong>public</strong> POSline split(POSline oldLine){<br/> POSline newLine = <strong>new</strong> POSline();<br/><strong> int</strong> i=0;<br/><strong> while</strong>((i<20)&&(oldLine.getLine(i)!=<strong>null</strong>)){<br/><strong> if</strong> (i%2==1) {<br/> newLine.joinLine(oldLine.getLine(i));//combined<br/> }<br/> i++;<br/> }<br/><strong> while</strong>(i>0){ // must be reverse order<br/><strong> if</strong> (i%2==1) {<br/> temp = oldLine.leaveLine(i);<br/> }<br/> i--;<br/> }<br/><strong> return</strong> newLine;<br/>}</pre>\n<p><em>Example answer using a flag that combines both copy and remove actions (not anticipated):</em></p>\n<pre><strong>public</strong> POSline split(POSline oldLine){<br/> POSline newLine = new POSline();<br/><strong> int</strong> i=0;<br/><strong> boolean</strong> flag=false;<br/><strong> while</strong>((i<20)&&(oldLine.getLine(i)!=<strong>null</strong>)){<br/><strong> if</strong> (flag) {<br/> newLine.joinLine(oldLine.leaveLine(i));<br/> }<br/><strong> else</strong> i++;<br/> flag = !flag;<br/> }<br/><strong> return</strong> newLine;<br/>}</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>(Any) software can be considered as a form of Intellectual property;<br/>Company should consider whether there is a need to acknowledge the work of other programmers (don’t accept answers talking about plagiarism);</p>\n<p>Open source software may have undergone many changes from the original;<br/>So adequate testing of the final product must take place;<br/>to prevent any malfunction that will affect their customers;</p>\n<p>The company will be promoting the spread of open source software;<br/>Helping to break the monopolies of the major IT companies;<br/>To the benefit of people / countries with reduced financial resources;</p>\n<p>The use of open-source software means that the code can (more easily) be read/understood/ hacked by others;<br/>Leading to possible data breaches for their customers;</p>\n<p>Code may contain malware;<br/>Leading to possible data breaches for their customers;</p>\n<p>Using open-source software results in less work for programmers;<br/>This affecting their livelihood;</p>\n<p><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p><span style=\"text-decoration:underline;\">Notes</span>:<br/>- <em>Award 2 marks for a valid issue if a detailed discussion has been provided</em><br/><em>- Only give credit for issues that have some ethical connection</em></p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most referred to the fact that only two states were possible but did not link this into saving of memory.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The most difficult questions on the paper for SL candidates. This was a good test for the better programmers, but many candidates struggled with the logic. Two separate methods of processing every other value were seen in the answers: the use of the modulo function and incrementing the loop by 2. The use of previously defined methods was suggested, and many candidates did just that.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The candidates appeared unprepared for this question but most described at least one valid ethical issue.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19N.2.SL.TZ0.12",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-1-objects-as-a-programming-concept",
|
||
"d-3-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the need for higher level languages.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>two</strong> benefits of using sub-procedures within a computer program.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>three</strong> characteristics of a collection.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Collection <code>NUMBERS</code> already exists and stores real numbers.</p>\n<p>Construct in pseudocode an algorithm, using the access methods of a collection, which will iterate through the collection <code>NUMBERS</code> and count how many elements stored in the collection are in the interval [−1,1].</p>\n<p>The final answer should be output.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for the answer identifying improved programmer productivity and <strong>[1]</strong> for making reference to machine independence up to <strong>[2 max]</strong></em>.</p>\n<p>High-level language(HLL) provides statements (for example, high level <code>if</code>(…), <code>while</code>(…) , etc.) which are not dependent on the specific machine / and ability to create various data structures;<br/>Which saves the programmer’s time;</p>\n<p>Higher level languages are closer to human language;<br/>So programmers find them easier to understand/work with than lower level languages;</p>\n<p>HLL saves programmer from knowing details of computer architecture (and using all the specific (machine) instructions);<br/>So giving more time to creating/developing the best way of coding a problem/process of coding is simpler and more understandable;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for an answer stressing the usefulness of sub-procedures in any of the following</em>:<br/><em>Program organization;</em><br/><em>Program coding;</em><br/><em>Program testing;</em><br/><em>Maintenance;</em><br/><em>etc.</em></p>\n<p><em>Award <strong>[1]</strong> for the expansion up to <strong>[2 max]</strong></em>.</p>\n<p>Problem could be divided into smaller/easier parts;<br/>Which means solving easier/smaller parts of the problem for one programmer;<br/>Or for a team of programmers, each programmer could work on different smaller parts;</p>\n<p>Simpler testing;<br/>Each part of the program could be separately tested;<br/>By the programmer who created the code or someone else in the team of programmers;</p>\n<p>Reusable code;<br/>Sub-procedures already written/tested could be used in various programs;</p>\n<p>Simpler maintenance and changes;<br/>Could be done only on required sub-programs;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for data structure implementation/objects/elements of collections.</em><br/><em>Award <strong>[1]</strong> for algorithms/methods/callback functions.</em><br/><em>Award <strong>[1]</strong> for showing that collection reduces programming effort / increases performance (by providing efficient implementations of data structures and algorithms).</em></p>\n<p><em>Award marks for description of a specific example collections (in Java or any other programming language) such as arrays, dictionaries, sets, lists, trees (they have some characteristics in common, but also each of them has different way of organizing the data elements/objects they contain).</em></p>\n<p>Collection is a container of discrete values;<br/>Usually of the same type (primitive data values and also some other data structures);<br/>(But) collection objects can be of different types (pointers afford a flexibility and thus collection objects permit references to any data structure as well as to primitive values);<br/>Collections have a set of methods that define operations performed on the elements/objects of that collection;<br/>Such as adding/removing elements to/from collection, comparing elements of collection, searching, etc.;<br/>Which reduces programming effort (because implementations of data structures and algorithms are provided);<br/>Which increases performance of the program (because efficient implementations are provided);</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong>.</em></p>\n<p><em>Award <strong>[1]</strong> for initialization and for outputting <strong>correct</strong> result (COUNTER).</em><br/><em>Award <strong>[1]</strong> for using collection methods.</em><br/><em>Award <strong>[1]</strong> for correct loop.</em><br/><em>Award <strong>[1]</strong> for retrieving a number (<code>ELEMENT</code>) from the collection.</em><br/><em>Award <strong>[1]</strong> for if statement within the loop.</em><br/><em>Award <strong>[1]</strong> for correct condition in if statement.</em><br/><em>Award <strong>[1]</strong> for increasing <code>COUNTER</code> if needed.</em></p>\n<p><em>Example answer</em>:</p>\n<pre>COUNTER = 0<br/>NUMBERS.resetNext()<br/>loop while NUMBERS.hasNext()<br/> ELEMENT = NUMBERS.getNext()<br/> if ELEMENT >= −1 and ELEMENT <= 1 then // abs(ELEMENT) <= 1<br/> COUNTER = COUNTER + 1<br/> end if<br/>end loop<br/>output COUNTER</pre>\n<p><em><strong>Note</strong>: be flexible over the method names. For example, NUMBERS.getData() is acceptable instead of <code>NUMBERS.getNext()</code></em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.9",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Reverse Polish notation (RPN) is a method used to represent mathematical expressions so they can be evaluated without the need for parentheses.</p>\n<p>An expression written in this form is known as postfix notation, whereas an expression written the traditional way is known as infix notation.</p>\n<p>For example:</p>\n<p style=\"text-align: center;\">Infix notation: <code>(8 − 5) * 7</code></p>\n<p style=\"text-align: center;\">Postfix notation: <code>8 5 − 7 *</code></p>\n<p>Both the infix and postfix expressions have the same result: 21</p>\n<p>RPN expressions are evaluated from left to right as follows:</p>\n<ul>\n<li>Each character is checked,<br/>\n<ul>\n<li>if it is a digit, it is pushed onto a stack.</li>\n<li>if it is a mathematical operator, the last two digits are popped from the stack and evaluated as though the current operator was between them. The result of this operation is then pushed back onto the stack.</li>\n</ul>\n</li>\n<li>The process is repeated until all the characters in the RPN expression have been used.</li>\n<li>The value left in the stack is the result of the expression.</li>\n</ul>\n<p>A collection named RPN already stores an expression formatted in Reverse Polish notation.<br/>The algorithm reads the values from the collection and, using a stack data structure, evaluates it.</p>\n<pre>RPN.resetNext()<br/>loop while RPN.hasNext()<br/> VALUE = RPN.getNext()<br/> loop while not (VALUE = \"+\" or VALUE = \"-\" or VALUE = \"*\" or VALUE = \"/\")<br/> stack.push(VALUE)<br/> VALUE = RPN.getNext()<br/> end loop<br/> OPERAND2 = stack.pop()<br/> OPERAND1 = stack.pop()<br/> if VALUE = \"+\" then<br/> NEW_VAL = OPERAND1 + OPERAND2<br/> stack.push(NEW_VAL)<br/> end if<br/> if VALUE = \"-\" then<br/> NEW_VAL = OPERAND1 - OPERAND2<br/> stack.push(NEW_VAL)<br/> end if<br/> if VALUE = \"*\" then<br/> NEW_VAL = OPERAND1 * OPERAND2<br/> stack.push(NEW_VAL)<br/> end if<br/> if VALUE = \"/\" then<br/> NEW_VAL = OPERAND1 / OPERAND2<br/> stack.push(NEW_VAL)<br/> end if<br/>end loop<br/>RESULT = stack.pop()<br/>output \"The result is: \", RESULT</pre>\n</div><div class=\"specification\">\n<p>An alternative data structure in which the expression used in <strong>part (a)</strong> may be stored is a binary tree. If the tree is traversed using postorder tree traversal, the output is formatted in RPN.</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the trace table for the algorithm using the RPN collection data:</p>\n<p style=\"text-align:center;\"><code>5 2 + 25 16 − * 3 /</code></p>\n<p style=\"text-align:left;\"><img src=\"\"/><code></code></p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why a stack is used in the process of evaluating the expression in the algorithm.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline the steps involved in traversing the given tree using postorder tree traversal.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the output from the given tree using inorder tree traversal.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max] <br/></strong></em><em>Award <strong>[1]</strong> for correct values in </em>VALUE column;<em><br/>Award <strong>[1]</strong> for correct values of </em>OPERAND2, OPERAND1 and NEW_VAL when VALUE is ‘+’;<em><br/>Award <strong>[1]</strong> for correct values of </em>OPERAND2, OPERAND1 and NEW_VAL when VALUE is ‘-’;<em><br/>Award <strong>[1]</strong> for correct values of </em>OPERAND2, OPERAND1 and NEW_VAL when VALUE is ‘*’;<em><br/>Award <strong>[1]</strong> for correct values of </em>OPERAND2, OPERAND1 and NEW_VAL when VALUE is ‘/’;<em><br/>Award <strong>[1]</strong> correct output: </em>‘The result is: 21’;</p>\n<p><img src=\"\"/></p>\n<p><em><strong>Note</strong>: The trace table may be differently presented.</em></p>\n<p><em><strong>Note</strong>: Allow Follow Through.</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max] <br/></strong></em>A stack is a last in first out (LIFO) / first in last out (FILO) data structure;<br/>…which means data is popped off the stack in the reverse order to which it was pushed;<br/>In the expression, it is important to evaluate some of the values in a certain order(to obtain the correct result);<br/>For example, 25 − 16 would give the wrong value if it was evaluated as 16 − 25;</p>\n<p>Pushing items onto a stack and then popping them off reverses the order;<br/>To evaluate e.g. “10 2 /” we must treat it as “do the operation on the operands 10 and 2”/ i.e. we have to access the operator before we can apply it to the operands;<br/>A stack achieves the reversing of the order of the operators and their operands as a group (but it also reverses the operands which must be fixed);</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max] <br/></strong></em>Start from the root node;<br/>If the root is null, return immediately;<br/>Traverse left subtree;<br/>Traverse right subtree;<br/>Visit root;</p>\n<p>start from the root node (for example traverse (root)) ;<br/>terminate traversal (and backtrack) when/if root equals null;<br/>(before visiting the root node) traverse (and visit/process/output) each node in the left subtree (i.e., traverse(root.left));<br/>(before visiting the root node) traverse (and visit/process/output) each node in the right subtree (i.e., traverse(root.right));<br/>visit/output/process root (for example, output(root));</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max] </strong><br/>Award <strong>[1]</strong> if the answer contains no more than one error.<br/></em></p>\n<p><code>(5+2)*(25−16)/3</code><em><br/></em></p>\n<p><em>Note to examiners: Ignore the brackets – these represent the completely correct mathematical expression, but they are not read from the tree. Some candidates might include them because they realise that they may be needed so the expression works correctly.<strong><br/></strong></em></p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates had difficulty tracing the algorithm in Part (a).</p>\n<p>There were some candidates who did not attempt question 15.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Part (b) was reasonably well answered with many gaining at least 1 or 2 of the marking points.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Only a few candidates earned full marks in Part (c).</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "22M.1.HL.TZ0.15",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming",
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Sestra.com is a website maintained by a company who sell items made by local craftspeople.</p>\n<p>The website is compatible with different screen sizes and formats ranging from desktop computers to mobile smartphones. All the site’s pages contain the following code fragment:</p>\n<p><code><link rel = \"stylesheet\" href = \"../css/default.css\"></code></p>\n</div><div class=\"specification\">\n<p>Visitors to the site can search categories of products (for example “Toys”, “Bags”, “Dresses” etc.) selected from a drop-down menu. The menu is populated from the records stored in the <code>CATEGORY</code> table of the site’s database.</p>\n<p>Parts of the code of the file <code>search.php</code> is shown below:</p>\n<pre>// Other code present here<br/><?php<br/> $categoryquerytext = 'SELECT 'category_id', 'category_name' FROM<br/> 'CATEGORY' ORDER BY 'category_name'';<br/> $categoryqueryresult = mysqli_query($con, $categoryquerytext);<br/>?><br/>// Other code present here<br/><form action = \"showresults.php\" method = \"post\"><br/> <select name = \"category\"><br/> <?php<br/> while($row = mysqli_fetch_array($categoryqueryresult))<br/> {<br/> echo '<option value = \"'. $row['category_id']. '\">'.<br/> $row['category_name']. '</option>';<br/> }<br/> ?><br/> </select><br/> <button type = \"submit\">Search</button><br/></form><br/><br/>// Other code present here</pre>\n</div><div class=\"specification\">\n<p>The owners of the company have noticed that Sestra.com does not appear very prominently in search engine results.</p>\n</div><div class=\"specification\">\n<p>The Sestra.com site includes:</p>\n<ul>\n<li>images of each product</li>\n<li>pdf documents giving background information about the craftspeople who produced the products.</li>\n</ul>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> ways that a cascading style sheet (CSS) can be used to ensure web pages are compatible with different screen sizes and formats.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the processing this code enables on the server before <code>search.php</code> is sent to the client.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>two</strong> ways in which the site developers could use white hat optimization to improve the site’s search engine ranking.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between lossy and lossless compression.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why the developers at Sestra.com would use lossless compression for the pdf documents.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Change/re-flow the layout of the page to suit different screen sizes/formats;<br/>adjust font sizes;<br/>adjust image sizes;<br/>provide alternative menus / link options;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>The code:</p>\n<ul>\n<li>uses SQL to query the <code>CATEGORY</code> table in a database, selecting all pairs of <code><category_id, category_name></code> ordered by category_name;</li>\n<li>stores the results of the query in a variable / array <code>$categoryqueryresult</code>;</li>\n<li>prepares HTML for a drop-down menu which consists of a list of option tags derived from iterating through each pair in $categoryqueryresult;</li>\n<li>sets the <code>“value”</code> attribute of each menu item to <code>category_id</code>;</li>\n<li>sets the<code> “text”</code> attribute of each menu item to <code>category_name</code>.</li>\n</ul>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>Include authoritative / high quality website content;<br/>To attract other reputable sites to link to it / promote it in the search engine ranking;</p>\n<p>Use appropriate use meta tags (e.g. keywords/descriptions);<br/>To provide clear data for web-crawlers/robots to use when categorising the page;</p>\n<p>Separate content from formatting (e.g. use of CSS etc.);<br/>To allow search engines to index the content of the site more effectively;</p>\n<p>Use site maps / site diagrams;<br/>To aid indexing by web-crawlers/robots;</p>\n<p>Include a robots.txt file in the page header;<br/>To give instructions to web-crawlers/robots as to how to index and describe the various pages on the site;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><strong>Lossy compression</strong><br/>Reduces the file-size by removing some of the data in the file;<br/>Once removed, the data cannot be recovered;<br/>This generally results in a loss of quality (e.g. picture resolution, audio frequency range);<br/>Files compressed using lossy compression are used in their compressed form (e.g. images, video, audio);</p>\n<p><strong>Lossless compression</strong><br/>Reduces file size by looking for repeated patterns of data / redundant data and replacing those with a single shorter \"token\";<br/>The tokens are associated with the data they represent by using a dictionary added to the file;<br/>Flies must be decompressed before they can be used;<br/>Decompression software reads the dictionary and replaces all the tokens with the original data They represent;<br/>Files do not lose any of the data they contain when compressed / decompressed;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Lossless compression reduces file size while preserving all the data;<br/>Once decompressed, the pdf document will contain all the data in the original document;<br/>Some pdf software allows for the automatic lossless compression of the document / the developers would not have to apply compression retrospectively;<br/>It would be hard for a lossy compression algorithm to distinguish between data that can be removed (e.g. reducing the resolution of the images) and data that is necessary for the pdf documents to make sense (e.g. parts of the text);<br/>Using lossy compression may result in an unusable/unreadable document;<br/><em>Accept answers that focus on why lossy compression would be unsuitable for the pdf files</em>.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates reasonably answered this question. However, some candidates were unable to demonstrate the understanding of how style sheets could be coded differently to tackle different screen sizes.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The vast majority of students didn’t write the expected response. Most of the responses were superficial and generic in nature.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was answered correctly by most of the candidates.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was reasonably answered by majority of the candidates.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was reasonably answered by majority of the candidates. However, some responses lacked the details.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.7",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-2-searching-the-web",
|
||
"c-3-distributed-approaches-to-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The collection, storage and sharing of data is becoming increasingly important for organizations who have a choice about which type of database to use to store their data. Two examples of database types are relational and object-oriented.</p>\n</div><div class=\"specification\">\n<p>The 2016 US presidential election was seen to be a victory for data analytics. Companies that specialize in analytics use data warehouses.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>two</strong> advantages of using a relational database rather than an object-oriented database.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>two</strong> characteristics of a data warehouse.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why data needs to be transformed before it can be loaded into the data warehouse.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why opinion poll data and other election data are timestamped when added to the data warehouse.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why analytics companies use link analysis.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why analytics companies use deviation detection.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Once data has been loaded into a data warehouse it can be mined. The use of data analytics is believed to have been important to the outcome of the US election campaign.</p>\n<p>Discuss whether the advantages of data mining techniques in this scenario outweigh the disadvantages.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>Standards and support are available for RDB…<br/>…make it more stable / easier to resolve issues / easier to recruit staff;</p>\n<p>More user tools exist for RDBs…<br/>…such as report generators / mail merge / security level permissions / concurrent access.</p>\n<p>Easier to visualise data and relationships…<br/>…so more likely to have a correctly modelled database i.e. has no redundancy / improved integrity</p>\n<p>RDB tables and relationships are simple to implement…<br/>…an OODB requires an understanding of concepts of OOP;</p>\n<p><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Repository data stored are historical/time variant;<br/>Data is collected from different sources;<br/>OLAP systems for reporting and data analysis (e.g. data mining) / provides businesses with information for informed decisions;<br/>Provides tools so that data can be validated, reformatted, reorganized, summarized, and restructured;<br/>Optimised for data retrieval;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Data is from my different external sources and (therefore) in many <span style=\"text-decoration:underline;\">different formats</span>;</em><br/><em>For example, dates may be dd/mm/yy or mm/dd/yy or yy/mm/dd (allow any valid example);</em><br/><em>To allow meaningful <span style=\"text-decoration:underline;\">analysis</span>, it must be in the same format/standardised;</em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Notes: maximum marks only if reference is made to the scenario</em><br/><em>Do not award marks just for a description of time-stamping</em></p>\n<p>The usefulness of information is often time dependent;<br/><em>Example relating to the US presidential election, such as</em><br/>Electoral opinions before a public debate may have less value than those after the debate;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Notes: don’t accept the word “link” on its own as a descriptor</em>.<br/><em>maximum marks only if reference is made to the scenario</em>.</p>\n<p>They use link analysis in order to establish relationships / associations between different data sets / different entities in the same data set;</p>\n<p><em>Examples relating to the US presidential election, such as</em>:<br/>How people voted in relation to some other factor, e.g. the level of use of social media / where they took their vacations / size of family …;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Note: maximum marks only if reference is made to the scenario</em></p>\n<p>They look for any unusual activity (anomaly pattern) in transactions;</p>\n<p><em>Examples relating to the US presidential election, such as</em><br/>Unusual switch in pre-electoral voting opinions;<br/>Sudden pro-candidate or anti-candidate sentiment in a particular state;</p>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.</p>\n<p><span style=\"text-decoration:underline;\">Mark as follows</span>:<br/>Award <strong>[1]</strong> for a generic advantage of data mining;<br/>Award <strong>[1]</strong> for expanding on this advantage;<br/>Award <strong>[1]</strong> for linking this to the scenario;<br/>Similarly for a disadvantage;<br/>Award <strong>[1]</strong> for a valid conclusion;</p>\n<p><em>Advantages of data mining <strong>[3 max]</strong></em>.<br/>Clustering / cluster analysis allows objects to be treated as one group enabling the uncovering of previously hidden patterns;<br/>For example, cluster analysis may search groups by race or gender to discover if a candidate is unpopular with a demographic;<br/>Classification methods (e.g. genetic, rough set, fuzzy set) can be used to recognize patterns that describe the groups to which an item belongs;<br/>For example, classifying voters by income may provide useful information that can affect future publicity strategies;<br/>Association analysis allows a series of statistical relationships to be further explored or tested;<br/>Associations look for If-then rules that predict a particular stance on a controversial topic (e.g. abortion) may influence the religious voters;</p>\n<p><em>Disadvantages of data mining <strong>[3 max]</strong></em>.<br/>Data mining is based on the data collected from individuals;<br/>This data may be sensitive personal information that the individual concerned may not want to be shared;<br/>This personal data may be reaggregated to compromise the privacy and/or anonymity of the data subjects;</p>\n<p><em>Conclusions <strong>[1 max]</strong></em>.<br/>The development of more sophisticated processing algorithms is inevitable, so although there are potential concerns about the invasive nature of data mining, providing sufficient safeguards are put in place, there is nothing inherently wrong with this;<br/>Data mining is the start of the slippery slope of the state or multinational companies holding inappropriate quantities of personal data about citizens that is of limited value. Therefore, unless the privacy and/or anonymity of the data subjects can be guaranteed, this is an unethical practice;</p>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to identify at least one advantage but were unable to clearly explain them.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to identify the characteristics of a data warehouse.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not well answered as answers were very generic. Candidates were aware that data is from different sources but were not aware of it having many different formats which need to be standardized to allow for a meaningful analysis.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not well answered. Candidates were not aware of the reason of having data timestamped when added to the data warehouse, and therefore very few candidates were able to connect the answer to the given scenario.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Not well answered. A few candidates mentioned the use of link analysis to establish relationships between data sets but were unable to make a good reference to the given scenario.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates were aware of the definition of deviation detection, and answered the question from this perspective, but failed to give actual examples related to the scenario and make appropriate connections.</p>\n<div class=\"question_part_label\">f.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates were aware of the definition of deviation detection, and answered the question from this perspective, but failed to give actual examples related to the scenario and make appropriate connections.</p>\n<div class=\"question_part_label\">g.</div>\n</div>",
|
||
"question_id": "19N.2.HL.TZ0.4",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-4-further-database-models-and-database-analysis"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: Genetic algorithms, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline what is meant by a heuristic algorithm.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> reasons why premature convergence may occur.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>A heuristic does not guarantee an optimal solution/finds an approximate solution;<br/>Heuristics produce a solution relatively quickly/sacrifices optimisation accuracy for speed;<br/>Used when exact algorithms (e.g. brute force) are impractical/used for computationally intractable problems;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em><br/>Small (initial) population/Lack of diversity in (initial) population;<br/>Failure to preserve population diversity/Genes of high rated individuals dominate the population early in the process; Low/zero mutation rate;<br/>Stopping condition occurs too soon;<br/>Selection strategy that reduces diversity/Elitism;<br/>Crossover strategy that reduces diversity;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "22M.3.HL.TZ0.1",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: Genetic algorithms, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"specification\">\n<p>The following example shows two tours of ten cities (A–J) that are to be used to produce a new tour using the order crossover (OX) method.</p>\n<p><strong>Parent 1</strong></p>\n<p><img src=\"\"/></p>\n<p><strong>Parent 2</strong></p>\n<p><img src=\"\"/></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Copy and complete the tables below to calculate the offspring.</p>\n<p>The initial sub-sequence of the offspring has been completed in the first row.</p>\n<p><strong>Offspring</strong></p>\n<p><img src=\"\"/></p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the initial population size <strong>and</strong> the mutation rate will affect the probability that an implementation of a genetic algorithm will provide an optimal solution.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em><br/><em>Award <strong>[1]</strong> for two values correctly entered;</em><br/><em>Award <strong>[2]</strong> for three values correctly entered;</em><br/><em>Award <strong>[3]</strong> for four values correctly entered;</em><br/><em>Award <strong>[4]</strong> for five values correctly entered;</em></p>\n<p style=\"text-align:center;\"><em><img src=\"\"/></em></p>\n<p style=\"text-align:left;\"><em>Award full marks for a correct last stage, even if the stages are not shown.</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em></p>\n<p><strong>Initial population size</strong><br/>A large population size gives enough diversity (that makes an optimum solution more likely)/ A small population size lacks diversity (that makes an optimum salutation unlikely);<br/>A large population takes too long to calculate (very long conversion) / A small population is calculated quickly (converges early);</p>\n<p><strong>Mutation rate</strong><br/>A very low mutation rate gives little diversity / A high mutation rate provides high diversity;<br/>A low mutation rate tends toward exploitation (narrow search and local optima) / A high mutation rate tends towards exploration (search for too long and never converge);</p>\n<p><strong>Example answers with mutation and population size interaction</strong><br/>A low initial population size will give limited diversity/fewer good routes;<br/>So the mutation rate will need to be higher/more cities swapped;</p>\n<p>A high initial population size gives plenty of diversity/many good routes;<br/>So a low mutation rate will be needed;</p>\n<p>A mid-point sized initial population size and low(ish) mutation rate is necessary;<br/>To stop the GA from converging on a local optima/to ensure the GA converges to a near-global optimum;</p>\n<p>To explore the search space a balance between exploration and exploitation is needed;<br/>A medium-sized population size with a low(ish) mutation rate will achieve this;</p>\n<p><em>Mark as <strong>[2]</strong> for population size + <strong>[2]</strong> mutation.</em><br/><em>You can also award up to <strong>[4]</strong> if comparisons only are made.</em></p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "22M.3.HL.TZ0.2",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The following method, <code>calcBMI()</code> accepts person’s height (H) in metres (m) and weight (W) in kilograms (kg) and returns their Body Mass Index (BMI).</p>\n<pre>calcBMI(H, W)<br/> X = H * H<br/> B = W / X<br/> return B<br/>endcalcBMI</pre>\n<p>Boris weighs 104 kg and is 2.00 m tall. His BMI can be calculated by calling method <code>calcBMI()</code> as follows</p>\n<p style=\"text-align: center;\"><code>BorisBMI = calcBMI(2.00, 104)</code>.</p>\n</div><div class=\"specification\">\n<p>A person can belong to one of the following four weight categories:</p>\n<p style=\"text-align: left;\"><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>The data about a group of adults and their height measurement (in metres) and weight measurement (in kg) is held in three one-dimensional arrays.</p>\n<p><img src=\"\"/></p>\n<p>Where<br/><code>NAME</code> is a one-dimensional array holding names (currently sorted in alphabetical order).<br/><code>WEIGHT</code> is a one-dimensional array holding weight measurement in kilograms.<br/><code>HEIGHT</code> is a one-dimensional array holding height measurement in metres.</p>\n<p>For example,<br/><code>NAME[0]</code> is Annie.<br/>Her weight measurement is 52.40 kg and can be found in <code>WEIGHT[0]</code>.<br/><code>HEIGHT[0]</code> is 1.56 which represents Annie’s height measurement in metres.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the value of variable <code>BorisBMI</code>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Use pseudocode to construct an algorithm which accepts a person’s BMI and outputs the weight category the person belongs to.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the name of the person whose height is held in <code>HEIGHT[3]</code>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> reason why a binary search algorithm cannot be used to find the name of person whose height is given.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how the name of person whose height is given could be output.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct an algorithm which will output the names of all the people whose BMI is greater than this group’s average BMI.</p>\n<p>You should call method <code>calcBMI()</code> in your answer.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.</p>\n<p>26.0;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong>.</em></p>\n<p><em>Award <strong>[1]</strong> for outputting 'underweight' and correct condition in if statement.</em><br/><em>Award <strong>[1]</strong> for outputting 'normal weight' and correct logical expression (18.5 < B < 25.0).</em><br/><em>Award <strong>[1]</strong> for outputting 'overweight ' and correct logical expression (25.0 < B < 30.0).</em><br/><em>Award <strong>[1]</strong> for outputting 'obese' (30.0 and greater than 30.0).</em><br/><em>Award <strong>[1]</strong> for using if-else.</em></p>\n<p><em>Example answer 1</em>:</p>\n<pre>category(B)<br/> if B < 18.5<br/> output('underweight')<br/> else if B < 25.0<br/> output('normal weight')<br/> else if B < 30.0<br/> output('overweight')<br/> else<br/> output('obese')<br/> end if<br/>end category</pre>\n<p><em>Example answer 2</em>:</p>\n<pre>category(B)<br/> if B < 18.5<br/> output('underweight')<br/> end if<br/> if B >= 18.5 and B < 25.0<br/> output('normal weight')<br/> end if<br/> if B >= 25.0 and B < 30.0<br/> output('overweight')<br/> end if<br/> if B >= 30.0<br/> output('obese')<br/> end if<br/>end category</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.</p>\n<p>Paul;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.</p>\n<p>Binary search can be applied only on sorted array / array <code>HEIGHT</code> is not sorted so binary search cannot be used;</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying each stage in the process of printing out a person’s name up to <strong>[2 max]</strong></em>.</p>\n<p>Linear (sequential) search could be used to find the position (array index) of a given height measurement in array <code>HEIGHT</code>;<br/>And the name in array <code>NAME</code> at found position should be outputted;</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.</p>\n<p><em>Award <strong>[3 max]</strong> marks for calculating average.</em><br/><em>Award <strong>[1]</strong> for initialization and changing the sum (of all BMIs) within the loop.</em><br/><em>Award <strong>[1]</strong> for a correct loop.</em><br/><em>Award <strong>[1]</strong> for correct parameters in the call of method <code>calcBMI()</code>.</em><br/><em>Award <strong>[1]</strong> for calculating average for the 30 persons (sum of all BMIs over 30).</em></p>\n<p><em>Award <strong>[3 max]</strong> marks for displaying appropriate names <strong>after</strong> calculating the group’s average BMI.</em><br/><em>Award <strong>[1]</strong> for an if statement within the correct loop.</em><br/><em>Award <strong>[1]</strong> for condition in if (comparing the BMI of the person with the average BMI).</em><br/><em>Award <strong>[1]</strong> for the correct output <strong>[1]</strong> for correct parameters in the </em><em>method call </em><em><br/>(<code>calcBMI(HEIGHT[K], WEIGHT[K]</code>).</em></p>\n<p><em>Example answer</em>:</p>\n<pre>sum = 0<br/>loop for K from 0 to 29<br/> sum = sum + calcBMI(HEIGHT[K], WEIGHT[K])<br/>end loop<br/>average = sum/30<br/><br/>loop for K from 0 to 29<br/> if calcBMI(HEIGHT[K], WEIGHT[K]) > average then<br/> output(NAME[K])<br/> end if<br/>end loop</pre>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18N.1.SL.TZ0.10",
|
||
"topics": [
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"4-2-connecting-computational-thinking-and-program-design",
|
||
"4-3-introduction-to-programming"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The Large Hadron Collider at CERN in Switzerland produces an average of 15 petabytes (15 million gigabytes) of experimental data every year. This data must be accessed and analysed by scientists around the world.</p>\n</div><div class=\"specification\">\n<p>CERN has established the <em>Worldwide LHC</em> <em>Computing Grid</em>.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the URL https://home.cern/topics/large-hadron-collider</p>\n<p>State the protocol used.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to the URL https://home.cern/topics/large-hadron-collider</p>\n<p>Identify the steps taken by the domain name server when the scientist enters a URL such as https://home.cern into their web browser.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>two</strong> reasons why CERN would use grid computing to support its research.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Instead of copyrighting its experimental results, CERN has decided to publish its experimental results using Creative Commons licensing.</p>\n<p>Explain <strong>two</strong> reasons why CERN would publish its experimental results using Creative Commons licensing.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>HTTPS / hypertext transport protocol secure;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>The DNS looks up the domain name “home.cern” in its database;<br/>If it doesn’t have this string, it passes the query to another DNS according to defined rules;<br/>This process continues until either an IP address is passed back to the starting DNS or an error message is returned;<br/>The IP address (or error message) is sent back to the client that initiated the call to the DNS;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><em>Mark as <strong>[3]</strong> and <strong>[3]</strong></em>.</p>\n<p>Multiple copies of all or part of the data can be kept at different sites;<br/>This ensures that there is no single point of failure;<br/>and the redundant data helps to ensure against data loss;</p>\n<p>Different computers on the grid can use different analysis and data visualization tools;<br/>This allows scientists to run whatever analysis tools best suit their own specialism/area of interest;<br/>Rather than being limited to the tools provided by CERN;</p>\n<p>Analysis can be performed using distributed processing time/capacity;<br/>This reduces load and/or reliance on a centralized system;<br/>Allowing a greater number of processes to be run concurrently;</p>\n<p>Computers on the grid can be in multiple time zones;<br/>This gives scientists more equitable access to data;<br/>And facilitates round-the-clock monitoring and the availability of expert support;</p>\n<p>Resources can be distributed across the world rather than being held in one country;<br/>This may attract funding from governments for their own locally-based research;<br/>As they may see the benefits of international cooperation;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><strong>Benefits of CC licensing</strong>:<br/>CERN want their experimental results to be freely accessible (within specified limits);<br/>Allows for the more rapid dissemination of data/information while preventing people from repackaging them and selling them as a commercial product;<br/>May further the advance of scientific knowledge / be seen as an altruistic gesture;<br/>No need to contact CERN about using the work / allows CERN to focus on their primary function, i.e. scientific research;</p>\n<p><strong>Limitations of copyright</strong>:<br/>May be impossible to enforce;<br/>Enforcement would require significant costs associated with hiring of lawyers etc.;<br/>It may not be possible to find all cases where work has been used without copyright permissions;<br/>Plagiarism may occur outside of Switzerland where different copyright laws may exist;</p>\n<p><em>Candidates are not required to make comparisons with copyright, however credit should be given where valid limitations of copyright are explained.</em><br/><em>Mark as <strong>[3]</strong> and <strong>[3]</strong></em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>The question was answered correctly by most of the candidates.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates reasonably answered this question. However, majority of the candidates failed to score full marks due to lacking specific details of the way the DNS server handles the URL.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most responses tended to be generic and focused on explaining what grid computing is. Candidates were unable to explain why the grid computing would be useful to support the research. The connection with research was not addressed.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The responses were mostly focused on description of creative common licensing rather than why it was useful for publishing the results.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.8",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-3-distributed-approaches-to-the-web",
|
||
"c-4-the-evolving-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: Genetic algorithms, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>Two selection methods used in genetic algorithms are:</p>\n<ul>\n<li>roulette wheel</li>\n<li>truncation.</li>\n</ul>\n<p>Compare and contrast these two selection methods.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[6 max]</strong></em></p>\n<p><strong>Roulette Wheel Selection (RWS)</strong><br/><em>Award <strong>[1 max]</strong></em><br/>Solutions are mapped to a roulette wheel / occupying space that is proportional to their fitness;<br/>Better solutions have a greater probability of being selected / Worse solutions have a lower probability of being selected;</p>\n<p><strong>Truncation</strong><br/><em>Award <strong>[1 max]</strong></em><br/>The best / top N solutions are selected (for entry into the mating pool)/The worst / other solutions are not selected (for entry into the mating pool);<br/>The number chosen for N (truncation point) affects the speed of convergence;</p>\n<p><strong>Comparison</strong><br/><em>Award <strong>[4 max]</strong></em><br/>Both solutions rank/sort the solutions from best to worst OR truncation must be sorted but RWS can be implemented without sorting (e.g. rejection sampling);<br/>Thus, the chosen sorting algorithm OR approach affects the solution time (because it is done every cycle);</p>\n<p>In truncation, weakest solutions will never be chosen/only strongest solutions can be chosen;<br/>Whereas in RWS every solution has a chance of being selected/even the worst solution has a chance of being selected;</p>\n<p>In truncation, once selected the top N solutions have a probability equal to that of any of the other top N solution (e.g. best and 4th best have an equal chance of being selected);<br/>whereas in RWS proportionality is used so the top N percent are differentiated (e.g. best has a high chance of being selected than 4th best);</p>\n<p>RWS is more likely to preserve diversity than truncation;<br/>Because roulette wheel is more likely to avoid local minima than truncation;</p>\n<p>Both truncation and roulette wheel make their selections based on fitness scores;<br/>So need to consider the processing required to calculate fitness;</p>\n<p>Both methods work well with large populations;<br/>So if population diversity is necessary they are good choices/should not be chosen if population sizes are small;</p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "22M.3.HL.TZ0.3",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Refer to the Paper 3 Case study: Genetic algorithms, available under the \"Your tests\" tab > supplemental materials.</p>\n</div><div class=\"question\">\n<p>To what extent do the characteristics of genetic algorithms make them an appropriate approach to solving the route optimization problems?</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[12 max]</strong></em></p>\n<p>Better essays will be structured to include the following areas:</p>\n<ul>\n<li>An introduction of genetic algorithms (GAs) and route optimization and the problem of vast search space / computational intractability.</li>\n<li>Advantages and disadvantages of GAs.</li>\n<li>Discussion of the characteristics that influence GA outcomes (population size, population diversity, selection method, crossover technique, mutation rate, stopping conditions, and hyperparameters).</li>\n<li>How GAs overcome limitations of premature convergence.</li>\n<li>A final measured conclusion in which the candidate links together the various points (good and bad) in evaluating the extent GAs can solve route optimization problems.</li>\n</ul>\n<p><strong>Introduction</strong></p>\n<ul>\n<li>A GA is a search heuristic that a near optimal solution.</li>\n<li>Based on the principle of natural selection.</li>\n<li>Designed for non-polynomial (NP) / computationally intractable combinatory optimization problems.</li>\n<li>GAs sacrifice accuracy for speed by using a combination of exploration and exploitation.</li>\n<li>GAs are useful in problems where an optimal solution is not critical (like route optimization).</li>\n<li>The route optimization in the scenario is the kind of problem where brute force is unsuitable.</li>\n<li>That is because the search space is factorial 20 / 2 or 1.216451 x 10<sup>18</sup> different routes.</li>\n</ul>\n<p><strong>Discussion points</strong><br/>GAs are suitable when:</p>\n<ul>\n<li>An optimal solution is not required.</li>\n<li>A deterministic algorithm is unavailable or impractical.</li>\n<li>Other heuristic methods are difficult to implement.</li>\n</ul>\n<p><strong>Advantages</strong></p>\n<ul>\n<li>Relatively easy to understand and implement.</li>\n<li>Can be easily configured using initialisation parameters.</li>\n<li>Can find near-optimal solutions in a much shorter time than other methods.</li>\n<li>Can use parallel sampling of the search space.</li>\n<li>Variety of approaches can be used including selection method, crossover technique, simulated annealing, and novelty search.</li>\n<li>Different techniques can be combined to improve performance (e.g. truncation selection may be used to provide an initial mating pool then switched to roulette wheel selection).</li>\n<li>A terminating condition can be used (e.g. time, number of generations) to limit the algorithms to use only the available time (e.g. before Lotte leaves).</li>\n<li>Techniques such as simulated annealing can combine early exploration and later exploitation of the problem space.</li>\n<li>Many implementations of GAs are readily available and require no specific algorithm development.</li>\n</ul>\n<p><strong>Disadvantages</strong></p>\n<ul>\n<li>Not guaranteed to find the optimum solution.</li>\n<li>Prone to converge prematurely on a local optimum, exploring only a small part of the solution space.</li>\n<li>The population may not converge at all.</li>\n<li>Because of the random aspect, the algorithm will miss good solutions and, even when it finds them, may destroy them with mutation.</li>\n<li>The performance of the algorithm may be highly sensitive to initial conditions (initial population, mutation rate) or other arbitrary choices, such as selection or crossover methods.</li>\n<li>The selection of these initial conditions is mostly by trial and error.</li>\n<li>They only take consider the quantitative data which is available (in this case distance between cities) and do not consider qualitative data (e.g. driving conditions, road closures etc.).</li>\n<li>They require some expertise to run effectively (i.e. correctly set up initialisation parameters, choose appropriate selection strategy etc.).</li>\n<li>Due to the “trial and error” nature, a GA is not able to “explain” how it arrived at the near optimum solution.</li>\n</ul>\n<p><strong>Characteristics that might be discussed</strong></p>\n<ul>\n<li>Since GAs are so dependent on initial conditions, it often happens that they are run with a range of different sets of initial conditions, in order to find fruitful ones.</li>\n<li>All of the initial conditions affect the others so the balance between them is difficult to determine.</li>\n<li>One GA can be used to find a set of initial conditions for another.</li>\n<li>Initial populations can be 'seeded' with better-than-average solutions.</li>\n<li>It is difficult to choose the ideal population size (too large and the algorithm runs slowly but too small and it lacks diversity).</li>\n<li>The mutation rate can be varied during the run. For example, mutation can be high at the beginning (exploration) and decrease as the algorithm progresses (exploitation), or it can be tied to an indicator of the current diversity of the population.</li>\n<li>The method of calculating the fitness value can slow down GAs.</li>\n<li>The method of terminating the algorithm may affect the solution.</li>\n<li>Stopping conditions include a set number of iterations/specified run time/ minimum target distance/frequency of better solutions found or a combination of these.</li>\n<li>Novelty search can be used to preserve diversity in the population.</li>\n<li>The balance between exploration and exploitation is the key to a successful algorithm;</li>\n<li>Both necessary but fundamentally opposed to each other.</li>\n<li>Functional Programming.</li>\n</ul>\n<p><strong>Conclusion</strong><br/>Any reasoned conclusion is fine. For example:</p>\n<p>In this scenario with only 20 cities, a GA is not appropriate because alternative methods such as the route inspection algorithm would be more suitable. Besides, the distance covered may not be the most important aspect of the tour. Particular sites of interest or events occurring on a particular day might be more important than a near-optimal route based on distance only.</p>\n<p>A GA is a suitable solution because a brute force approach on a home laptop would be computationally intractable and an optimal route is not required, any near-optimal one is fine. Since GAs are likely to be easier to implement than other heuristic approaches, a high school student may find it the best solution for their purpose.</p>\n<p><em>Please see markband below</em>.</p>\n<p><img src=\"\"/></p>\n</div>",
|
||
"Examiners report": "",
|
||
"question_id": "22M.3.HL.TZ0.4",
|
||
"topics": [],
|
||
"subtopics": []
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>Optical character recognition (OCR) is a method where printed text or handwritten text is converted to machine-encoded text.</p>\n</div><div class=\"specification\">\n<p>Recognizing handwritten characters presents more of a problem because people have different handwriting styles.</p>\n<p>For example, the digitized handwritten letter X in <strong>Figure 3</strong> does not exactly match the digitized letter X in <strong>Figure 4</strong>.</p>\n<p><img src=\"\" style=\"display: block; margin-left: auto; margin-right: auto;\"/></p>\n<p>Artificial neural networks (ANNs) can be used to assist with recognizing handwritten characters that do not exactly match the expected pattern.</p>\n</div><div class=\"specification\">\n<p>Predictive text, where the computer predicts the next word in the sentence, can be programmed to utilize a neural network.</p>\n</div><div class=\"specification\">\n<p>The sentence “The child is feeling” is entered into an application that uses predictive text and three options are suggested: <em>better</em>, <em>like</em>, <em>a</em>. Upon entering the two characters “hu” the word <em>hungry</em> is suggested.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> problem that may lead to printed text characters not being detected correctly.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why an ANN can be used to overcome the challenges outlined in this scenario.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how ANN pattern recognition techniques are applied to ensure that the handwritten letter X in <strong>Figure 3</strong> is recognized as a letter X.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>two</strong> features that would be required by the ANN to predict the next word in the sentence.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the application uses a neural network to suggest suitable words.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline<strong> two</strong> potential problems with training the ANN to suggest appropriate words.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Printed text quality may be poor or faint/may use an unusual typeface e.g. BrushScript/In certain typefaces some characters can look similar e.g. sans serif;<br/>For example, 5 and S may be confused/Numbers may be confused with letters 1 or I; </p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>ANN can be <span style=\"text-decoration:underline;\">trained</span> to recognise handwriting styles / supervised learning;<br/>ANN can learn to apply existing knowledge to new handwriting styles / unsupervised learning;<br/>ANN can recognize parts of the image to determine if it is a match / doesn’t require the entire image to be a match;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>The ANN accesses a database of correctly stored characters;<br/>ANN breaks the image into smaller parts / applies a filter (2 or 3 pixels) to a section of the image;<br/>Calculate whether the pixels match / multiple each image pixel to the feature pixel, add them up, divide by number of pixels / perfect match will be 1;<br/>Apply convolution / repeat the application of the filter over and over;<br/>Apply a ReLU (Rectified Linear Units) layer (remove negative values) to reduce the mathematical calculations;<br/>Apply pooling to shrink the image stack;<br/>Use the stack of filter images / convolution layer to see if the image is a match;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>Dictionary of words;<br/>Predictive text algorithms;<br/>The ability to recall the previous words in the sentence / memory;<br/>An understanding of language structure e.g. nouns, verbs, adverbs, etc.;<br/>Previous words must be added back into the neural network;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/><em>If they have used a diagram should include:</em><br/><em>Award <strong>[1]</strong> Input for previous words;</em><br/><em>Award <strong>[1]</strong> Input for new characters the user enters;</em><br/><em>Award <strong>[1]</strong> Hidden layers;</em><br/><em>Award <strong>[1]</strong> Weights inputted into the network;</em><br/><em>Award <strong>[1]</strong> Combining the two inputs;</em><br/><em>Award <strong>[1]</strong> Non-linear regression / sigmoid function;</em><br/><em>Award <strong>[1]</strong> Merge layers to produce output;</em><br/><em>Award <strong>[1]</strong> Back propagation / Output that re-enters the ANN;</em></p>\n<p style=\"text-align:center;\"><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/>Unsupervised learning may have a poor set of words / text-speak is used;<br/>So the ANN database doesn’t contain text-speak words so doesn’t learn;</p>\n<p>Vanishing gradient problem / Exploding gradient problem;<br/>Gradient signal is multiplied many times by weight matrix / The gradient signal can become smaller at every training step (vanishing) / can become excessively large at every training step (exploding) / This can make learning very slow or stops it completely;</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19N.2.HL.TZ0.8",
|
||
"topics": [
|
||
"option-b-modelling-and-simulation"
|
||
],
|
||
"subtopics": [
|
||
"b-4-communication-modelling-and-simulation"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Brownsville Council</em> run several public libraries in different areas of the city. The libraries use an Integrated Library Management System (ILMS) to manage all items (for example books, DVDs, etc.) held by the libraries. Details of the items are stored in a database on a central server.</p>\n<p>Below is part of the extensible markup language (XML) code used to describe an item.</p>\n<pre><item id = \"97812\"><br/> <category>Book</category><br/> <author>Stark, Elizabeth</author><br/> <title>Handheld Device Usability</title><br/> <genre>Computer Science</genre><br/> <publisher>Taylor & Orams Inc.</publisher><br/></item></pre>\n</div><div class=\"specification\">\n<p>XML is based on open standards.</p>\n</div><div class=\"specification\">\n<p>Library users interact with the ILMS through a web page that includes a form to search for items stored on the database.</p>\n</div><div class=\"specification\">\n<p>The library managers have decided to extend their web pages to include a blog and a forum, maintained by the head librarian, in order to increase engagement with library users.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>extensibility</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage of XML for sharing data on the web.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between open standards and interoperability.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the role of the common gateway interface (CGI) in processing search requests made via the web form.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Distinguish between a blog and a forum.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>To what extent has the use of social media, blogs and forums enabled the head librarian to be a more effective decision maker?</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>The ability of something to be extended or expanded from its initial state, e.g. software / file Formats / programming languages;<br/>The ability to add custom / user-defined elements (e.g. XML tags, plug-ins, add-ons);</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>In the real world, computer systems and databases contain data in incompatible formats;<br/>XML data is stored in plain text format. This provides a software- and hardware-independent way of storing data / makes it much easier to create data that can be shared by different applications;<br/>XML makes it easier to expand or upgrade to new operating systems / applications / browsers;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Interoperability is the ability of different computer systems (including operating systems and applications) to work cooperatively / share data;<br/>Open standards are standards that are publicly available and (normally) free to use;<br/>Open standards are one factor aiding interoperability;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>The Common Gateway Interface (GGI) is part of the Web's Hypertext Transfer Protocol (HTTP);<br/>CGI is a method or convention for passing data back and forth between the server and the application;<br/>A programmer can write a CGI application in a number of different languages. CGI provides a more efficient mechanism for data to be passed from the user's request to the application program (and back to the user);<br/>CGI is not dependent on the operating system used by the server. The methods / conventions remain the same;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>In a blog, only the owner can post an article / open a thread of discussion / start a theme;<br/>In a forum all registered participants can post an article / open a thread;</p>\n<p>In a blog, registered visitors may be allowed to comment but the blog owner may moderate the comments before displaying them;<br/>in a forum all registered users are allowed to comment (without moderation);</p>\n<p>In a blog users cannot edit or delete posts;<br/>in a forum there may be moderators who can edit or delete posts after they have been made;</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><em><strong>Note</strong>: do not award a tick for each idea, use the markband and use best-fit to determine the level of the response</em>.</p>\n<p><strong>Blog</strong></p>\n<ul>\n<li>allows the head librarian to post articles/entries that give readers a better idea of the issues/decisions affecting the library/the background context that affect decisions / may result in better informed and focused comments from readers;</li>\n<li>may foster a greater sense of participation / spirit of community / allow the head librarian to aggregate majority views;</li>\n<li>the ability of the head librarian to moderate posts may allow off-topic/ unhelpful/offensive comments to be filtered-out / however this might also allow the head librarian to censor/modify comments that are legitimate but critical of library services/contrary to decisions that the library want to push-forward;</li>\n</ul>\n<p><strong>Forum</strong></p>\n<ul>\n<li>allow library users to raise issues that they find important rather than only commenting on issues raised by the head librarian / may allow greater head librarian to develop a greater awareness of issues affecting/affected by decisions;</li>\n<li>lack of moderation may allow users to raise controversial issues / however may also reduce ability of head librarian to filter-out off-topic/unhelpful/ offensive posts;</li>\n<li>may oblige head librarian to engage in greater discussion / justification of actions / however excessive time might be spent clarifying issues / dispelling myths;</li>\n</ul>\n<p><strong>Both blog and forum</strong></p>\n<ul>\n<li>the comments/posts may not be reflective of the general/majority view / may be restricted to a biased/self-selecting sub-set of library users. This may influence the head librarian to make decisions that cater for the \"vocal\" minority;</li>\n</ul>\n<p><strong>[1–2 marks]</strong><br/>A limited response that indicates very little understanding of the topic or the reason is not clear. Uses little or no appropriate subject specific terminology. No reference is made to the scenario in the stimulus material. The response is theoretical and descriptive.</p>\n<p><strong>[3–4 marks]</strong><br/>A superficial analysis of why the increased engagement with library users through the blog and forum will assist the head librarian with decision making. There is some use of appropriate subject specific terminology in the response.</p>\n<p><strong>[5–6 marks]</strong><br/>A discussion of why the increased engagement with library users through the blog and forum will assist the head librarian with decision making. Explicit and relevant references are made to the scenario in the stimulus material. There is appropriate use of subject specific terminology throughout the response.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most answers were incorrect as the candidates were of the course in addressing ‘extensibility’ in this context.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates did not answer this correctly as the sharing data on the web using XML was not addressed specifically.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most answers were generic in nature though candidates were able to distinguish between open standards and interoperability.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Though this was a straightforward question, many candidates had difficulty in answering this.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to write at least one difference between a blog and a forum.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Though most of the responses lacked the details about how using blogs and forums could make the librarian more effective decision maker. The part where most candidates lost in this question was because they failed to address why the increased engagement with library users through the blog and forum will assist the head librarian in decision making. Explicit and relevant references had to be made to the given scenario that most candidates missed doing.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.9",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-1-creating-the-web",
|
||
"c-3-distributed-approaches-to-the-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline what is meant by the term computer network.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe <strong>one</strong> problem resulting from low bandwidth in a computer network.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for identifying the nature of a network and <strong>[1]</strong> for a development of the first point up to <strong>[2 max]</strong></em>.</p>\n<p>A group of computers and other computing hardware devices that are linked together through communication channels/cables/wirelessly;<br/>To enable communication (sharing files, sharing information) between systems/among a wide range of users;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for a definition of the term bandwidth and <strong>[1]</strong> for a description of an issue caused by low bandwidth up to <strong>[2 max]</strong></em>.</p>\n<p>Bandwidth indicates the maximum amount of data that can be transferred from one point to another in a unit of time;</p>\n<p>Low bandwidth means slow network performance / extended duration when transferring large amounts of data / loss of users’ time (money) / the whole area (of the users) is not covered;</p>\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div>",
|
||
"question_id": "18N.1.HL.TZ0.1",
|
||
"topics": [
|
||
"topic-3-networks"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Explain the importance of the method <code>isEmpty()</code> when constructing an algorithm which performs operations on a stack data structure.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em>.</p>\n<p>Method <code>isEmpty()</code> returns True if there are no elements on the stack, False otherwise;<br/>It is important to call this method in logical expression/condition in algorithm constructs such as branches and loops (<code>if/while</code>);<br/>Before popping an element from the stack / <code>popStack()</code>;<br/>To prevent errors/stack underflow/program crash;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18N.1.HL.TZ0.6",
|
||
"topics": [
|
||
"topic-5-abstract-data-structures"
|
||
],
|
||
"subtopics": [
|
||
"5-1-abstract-data-structures"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p style=\"text-align: left;\">An international organization, OBI, has three offices in Europe, see <strong>Figure 7</strong>.</p>\n<p style=\"text-align: center;\"><strong>Figure 7: The location of OBI’s offices in Europe</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n<p style=\"text-align: center;\">[Source: adapted (recoloured, cropped and annotated) Europe Map by Erin Dill 0, www.freevector.com.<br/>Under copyright and CC 4.0 licence (https://creativecommons.org/licenses/by-sa/4.0/)]</p>\n<p style=\"text-align: left;\"> </p>\n<p style=\"text-align: left;\">Office A and Office B report to Office C, the head office.</p>\n<p style=\"text-align: left;\">Office A and Office B collaborate on many projects. Office C is not involved in the collaboration between Office A and Office B.</p>\n</div><div class=\"specification\">\n<p>OBI has projects that involve large numbers of contributors from all over the world. These projects are managed by OBI staff in Office A.</p>\n<p>The contributors often include non-text based information.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Draw a directed graph based on the scenario.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe the role of graph theory in determining the connectivity of the World Wide Web.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> issues that may arise from using a non-text based search.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>OBI has decided to gather information for one project by utilizing collective intelligence.</p>\n<p>Evaluate this decision.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for bi-directional arrow between A & B.</em><br/><em>Award <strong>[1]</strong> for uni-directional arrow between A & C as well as B & C.</em></p>\n<p style=\"text-align:center;\"><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Connectivity is a basic concept in Graph Theory. Graph theory can be used to model or analyse the nature of the connectivity on a selected area, the web;<br/>In World Wide Web, each web page is represented by vertex/node;<br/>The hyper links between web pages are represented by edges/lines in the graph;<br/>Arrows would indicate the direction of the hyperlinks (1-way / 2-way);<br/>In Graph Theory, a graph is said to be connected if there is a path between every pair of vertex. From every vertex to any other vertex, there should be some path to traverse. That is called the connectivity of a graph;<br/>Similar concept is used in connectivity of World Wide Web, where each vertex representing a type of web page is connected to any other vertex representing other kind of web pages;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Multimedia are assigned meta-tags;<br/>If the appropriate tag is not assigned, the media will not appear in the search;</p>\n<p>Searched by image similarity;<br/>Google search the web using the image inputted by the user;</p>\n<p>Non-text based searches are more difficult;<br/>Because there a no specific content to search for;</p>\n<p>Fewer search engines support multimedia searches;<br/>Therefore the search engine may not be as efficient;</p>\n<p><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>. <br/><em><strong>Advantages of using collective intelligence [2 max]</strong></em><br/>Collective intelligence costs significantly less per unit / pro rata than hiring a professional;<br/>A single task is being worked on simultaneously by numerous individuals so it can be completed much more rapidly than using a single person;<br/>It allows access (maybe part time or at very short notice) to a large number of contributors for specific events or tasks;</p>\n<p><em><strong>Disadvantages of using collective intelligence [2 max]</strong></em><br/>It may be hard to ensure sufficient quality control occurs as collective intelligence is a very deregulated environment;<br/>It may be hard to verify the originality of the work, or which work was originally completed by who;<br/>There may be many ideas, but it may be difficult evaluate each idea thoroughly as there may be a lack of centralised planning and/or a lack of a clearly defined hierarchy;</p>\n<p><em><strong>Conclusions [1 max]</strong></em><br/>Collective intelligence can help organizations in solving a problem in certain contexts;<br/>These may include where there is a need to provide information quickly such as a health related requirement, or where the final information is not critical to the wellbeing of others, for example a site such as Wikipedia;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Graph theory is quite a complex area of the course. Many correctly sketched a diagram.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Answers to (b) were quite vague and did not go further that identifying the function of nodes and links.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates identified at least one of the reasons.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates gained marks here, particularly in identifying both the diversity of opinions that could be gathered and the difficulties involved in analysing them.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19N.2.HL.TZ0.12",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-5-analysing-the-web",
|
||
"c-6-the-intelligent-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Distinguish between the use of time slicing and priorities in the scheduling of processes by an operating system.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[3 max]</strong></em>.</p>\n<p><strong>Prioritizing</strong> enables execution of the (highest priority) process until a higher priority task enters;<br/>The OS/scheduler put processes (jobs) in the right place in a queue in order of priority (accept examples, an I/O operation has higher priority than calculations because it uses less CPU time);</p>\n<p><strong>Time slicing</strong> allows process to execute for a fixed time/each process is given a fixed period of time (time slice) for which the process is allowed to run/;<br/>The scheduler is run once every time slice to choose the next process to run;</p>\n<p><em>Note: Award <strong>[1 max]</strong> if evident that the scheduler software is responsible for organizing all of the processes that need servicing/responsible for looking at what resources are available (CPU time and peripheral devices) /responsible for making decisions about what order to put all the processes in (when to start any particular process, and when to finish it)</em>;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n[N/A]\n</div>",
|
||
"question_id": "18N.1.HL.TZ0.7",
|
||
"topics": [
|
||
"topic-6-resource-management"
|
||
],
|
||
"subtopics": [
|
||
"6-1-resource-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An oil and gas company has a networked computer system for use of their employees in the Head Office.</p>\n</div><div class=\"specification\">\n<p>The company also uses the internet to enable communication with employees working on exploration and production in many remote geographical areas.</p>\n</div><div class=\"specification\">\n<p>The sub-sea oil and gas exploration and production unit of the company relies on thousands of kilometres of pipeline which are monitored by a computer control system which can detect leaks.</p>\n</div><div class=\"specification\">\n<p>The process of detecting leaks is carried out by sensors which are continuously monitoring changes in the flow and pressure of the liquids in the pipes.</p>\n<p>This data is processed on a computer in the office.</p>\n<p>If any of sensor values are outside of the acceptable parameters stored on a disk in the office, the following error routines are performed:</p>\n<ul>\n<li>an alarm is sounded on the computer at the office</li>\n<li>an email message is sent to managers in the Head Office.</li>\n</ul>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> hardware security measure that will ensure that confidential data from the Head Office cannot be accessed.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> software security measure that will ensure that confidential data from the Head Office cannot be accessed.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Identify <strong>one</strong> network security measure.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the environmental benefit of using a computer control system to monitor the pipeline.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the relationship between sensors, output transducers and processor in this situation.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct a system flowchart to represent the process described above.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each hardware security measure identified up to <strong>[1 max]</strong></em>.</p>\n<p>Retina scans;<br/>Locked doors;<br/>Alarms;<br/>Protection of equipment within the building;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each software security measure identified up to <strong>[1 max]</strong></em>.</p>\n<p>Use of passwords;<br/>Different access rights;<br/>Encryption;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1]</strong> for each network security measure identified up to <strong>[1 max]</strong></em>.</p>\n<p>Encryption;<br/>UserID;<br/>Trusted MAC addresses;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.</p>\n<p>In case of leaks (depending on severity of problem) which could cause pollution (any environmental problem);<br/>Computer control system can react quickly/turn on and off appropriate devices immediately/many times in a short interval of time/(increased efficiency);<br/>Computer control systems are very reliable (will not be tired / will not lose concentration);<br/>(can continue to operate reliably 24 hours a day, 7 days a week) (increased level of safety);<br/>Control systems are reasonably cheap to run comparing to the cost involved in situations which can harm environment (and human health) (reduction of costs);</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.</p>\n<p>Input from flow/pressure sensors is analog;<br/>AD convertors are used to convert this analog data into digital form;<br/>Processor performs / logical and arithmetical / operations;<br/>The result of processing is in digital form so it should be converted (by AD convertors) into analog form;<br/>This signal is sent to output transducers (a device that converts energy from one form to another) (for example, alarm sounds in the office);</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>.</p>\n<p><em>Award <strong>[1]</strong> for sensor input.</em><br/><em>Award <strong>[1]</strong> for manual input and validation/configuration.</em><br/><em>Award <strong>[1]</strong> for a disk (which is holding data).</em><br/><em>Award <strong>[1]</strong> for a monitoring process / checking whether input values exceed the allowed range or not.</em><br/><em>Award <strong>[1]</strong> for error routines performed.</em></p>\n<p>Example 1</p>\n<p><img src=\"\"/></p>\n<p>Example 2</p>\n<p><img src=\"\"/></p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n[N/A]\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "18N.1.HL.TZ0.10",
|
||
"topics": [
|
||
"topic-3-networks",
|
||
"topic-7-control",
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"3-1-networks",
|
||
"topic-7-1-control",
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An international school organizes a regional swimming competition for students from 10 different schools. Each school will send a team of 5 to 15 swimmers.</p>\n<p>Each swimmer can enter up to 5 events (such as the “50 m freestyle” or “100 m butterfly”).</p>\n<p>Each event consists of one or more races. A race can be a qualifying heat, or a final. The final has the best 8 swimmers from all the qualifying heats in the event.</p>\n<p>Each race has a maximum of 8 swimmers.</p>\n<p>The UML diagrams for the classes <code>Swimmer</code> and <code>Race</code> are provided below.</p>\n<p><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>In this scenario, <code>Swimmer</code> objects are aggregated in a <code>Race</code> object.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>mutator method</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State <strong>one</strong> additional instance variable of type <code>boolean</code> which could be added to the class <code>Race</code> as indicated above.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>With reference to both class UMLs provided above, distinguish between a class and an instantiation.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> advantage of using aggregation in this context.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> disadvantage of using aggregation in this context.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct code for the constructor of the class <code>Swimmer</code> that instantiates an object with parameters <code>name</code> and <code>school</code>. The event IDs should be set to “empty” and the times to 0.0</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Many swimmers in the event have names that cannot be represented using basic character sets such as ASCII.</p>\n<p>Describe <strong>one</strong> feature of modern programming languages that allows the wide range of students’ names to be represented correctly.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/>A method that allows/controls changes to a private (hidden) variable;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>.<br/><code>boolean isFinals</code>;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>The class <code>Swimmer</code> is the blueprint of a <code>Swimmer</code> object;<br/>An instantiation is the actual object filled with data;<br/>The class <code>Race</code> stores up to 8 different instantiated objects of the <code>Swimmer</code> class;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying an advantage and <strong>[1]</strong> for an elaboration of the advantage up to <strong>[2 max]</strong></em>.</p>\n<p>Aggregation reduces dependencies;<br/>and therefore reduces maintenance overhead;</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for identifying a disadvantage and <strong>[1]</strong> for an elaboration of the disadvantage up to <strong>[2 max]</strong></em>.</p>\n<p>Aggregation of swimmers in a <img src=\"\"/> object can cause issues with processing;<br/>e.g. when searching for all heats that a particular swimmer participates in;</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for correct signature including parameters</em>.<br/><em>Award <strong>[1]</strong> for assigning name and school</em>.<br/><em>Award <strong>[1]</strong> for a (any) loop</em>.<br/><em>Award <strong>[1]</strong> for assigning empty to <code>eventID[i]</code></em>.<br/><em>Award <strong>[1]</strong> for assigning <code>0</code> (or <code>0.0</code>) to <code>time[i]</code></em>.</p>\n<p><em>Example answer</em>:</p>\n<pre><strong>public</strong> Swimmer(String name, String school)<br/>{<br/> this.name = name;<br/> this.school = school;<br/><strong> for</strong>(<strong>int</strong> i = 0, i < 5; i++)<br/> {<br/> eventID[i] = <strong>\"</strong>empty<strong>\"</strong>;<br/> time[i] = 0;<br/> }<br/>}</pre>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Modern programming languages use Unicode to encode characters.<br/>Which uses 16 bits / has about 64 000 characters.<br/>As opposed to ASCII which uses 8 bits / has 256 characters.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was answered well. As this is an OOP course, some reference to objects, classes or encapsulation was expected which most students gave.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Any sensible and non-trivial answer was accepted.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates experienced difficulties in clearly distinguishing between the two terms. For the purpose of this course, a class is the template for objects which are created by instantiation.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates struggled to give a clear advantage (e.g. better organization) for aggregation.</p>\n<div class=\"question_part_label\">d.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates struggled to give a clear disadvantage (e.g. dependencies) for aggregation.</p>\n<div class=\"question_part_label\">d.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was well-answered.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>It was clear from the various guesses that this topic hadn't been covered in some schools.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.10",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-3-program-development",
|
||
"d-1-objects-as-a-programming-concept"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"question\">\n<p>Southend Council in England is considering whether to use Pepper, a humanoid robot, to assist some elderly residents that live in care homes. These elderly residents suffer from memory loss and would rely on Pepper to direct them them to and from the local shops. Pepper uses ambient intelligence and is connected to the Internet of Things (IoT).</p>\n<p>Explain why Southend Council may have concerns about introducing Pepper for this purpose.</p>\n</div>",
|
||
"Markscheme": "<div class=\"question\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/>The journey from the care home to the local shops may lead to Pepper encountering a large range of environments that may go beyond the ambient intelligence that Pepper posseses;<br/>Which may mean that the information that Pepper can obtain from the environment by using ambient intelligence may be limited and lead to sub-optimal decisions being taken, some of which could have serious consequences;<br/>Some of the residents may have trust issues associated with relying on Pepper, or they have be too trusting and delegate all decision making to Pepper when it is not appropriate;<br/>Families and carers for these residents may have concerns about what information is being collected and shared by Pepper;<br/>There may be issues of accountability that have not been resolved should an accident occur when Pepper is acting as a decision maker;<br/>There may be technical issues such as black spots where Pepper is unable to communicate with the IoT that need to be addressed;<br/>The trialing of Pepper may not have been sufficiently rigorous to train Pepper to act “correctly” in any given situation;</p>\n</div>",
|
||
"Examiners report": "<div class=\"question\">\n<p>Candidates came up with a variety of reasons for not continuing with this project they clearly did not think it was a good idea.</p>\n</div>",
|
||
"question_id": "19N.2.HL.TZ0.13",
|
||
"topics": [
|
||
"option-c-web-science"
|
||
],
|
||
"subtopics": [
|
||
"c-6-the-intelligent-web"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The array <code>line</code> in <code>POSline</code> is now replaced by a singly linked <code>list</code> of <code>CartNode</code> objects. The class <code>CartNode</code> has been defined as follows.</p>\n<pre><strong>public class</strong> CartNode<br/>{<br/><strong> private</strong> Cart myCart;<br/><strong> private</strong> CartNode next;<br/><strong> <br/> public</strong> CartNode(Cart aCart)<br/> {<br/> this.myCart = aCart;<br/> this.next = null;<br/> }<br/><strong> public</strong> Cart getCart(){ return this.myCart; }<br/><strong> public</strong> CartNode getNext(){ return this.next; }<br/><strong> public</strong> void setNext(CartNode nextNode)<br/> {<br/> this.next = nextNode;<br/> }<br/>}</pre>\n</div><div class=\"specification\">\n<p>The class <code>POSlist</code> has been implemented with the standard list methods <code>addLast</code> and <code>removeFirst</code> that act on <code>list</code>.</p>\n</div><div class=\"specification\">\n<p>A method <code>leaveList(int n)</code> is required in the class <code>POSlist</code>, similar to the method <code>leaveLine(int n)</code> that was added to the class <code>POSline</code>.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>object reference</em>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using object references, construct the method <code>public Cart removeFirst()</code> that removes the first <code>CartNode</code> object from <code>list</code>. The method must return the <code>Cart</code> object in that node or <code>null</code> if <code>list</code> is empty.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Sketch the linked list <code>list</code> after running the following code fragment where <code>cart1, cart2, cart3, cart4</code> and <code>cart5</code> have been instantiated as objects of the class <code>Cart</code>.</p>\n<pre>POSlist queueList = new POSlist()<br/>queueList.addLast(cart2);<br/>queueList.addLast(cart1);<br/>queueList.addLast(cart4);<br/>queueList.removeFirst();<br/>queueList.addLast(cart5);<br/>queueList.addLast(cart3);<br/>queueList.removeFirst();</pre>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> feature of the abstract data structure <em>queue</em> that makes it unsuitable to implement customers waiting in line.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Using object references, construct the method <code>public Cart leaveList(int n)</code> that removes the nth <code>CartNode</code> object from <code>list</code>. The method must return the <code>Cart</code> object in that node.</p>\n<p>You may assume that the nth <code>CartNode</code> object exists in the list.<br/>You may use any method declared or developed.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the importance of using coding style and naming conventions when programming.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>A pointer to a memory location;<br/>where the object is stored;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for declaring a </em><code>result</code><em> variable (or similar)</em><br/><em>Award <strong>[1]</strong> for correct use of </em><code>.getCart()</code><br/><em>Award <strong>[1]</strong> for reassigning the head of the list</em><br/><em>Award <strong>[1]</strong> for returning the correct result (either the Cart or null)</em></p>\n<pre>public Cart removeFirst()<br/>{<br/> Cart result = null;<br/><br/> if (head != null)<br/> {<br/> result = head.getCart();<br/> head = head.getNext();<br/><br/> }<br/> return result;<br/>}</pre>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for a three nodes in order.</em><br/><em>Award <strong>[1]</strong> root pointer (with or without identifier) <span style=\"text-decoration:underline;\"><strong>and</strong></span> null pointer.</em></p>\n<p><em><img src=\"\"/></em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>The abstract data structure queue is a FIFO structure / only allows addition at the end and removal from the front;<br/>this is not sufficient because customers can change lines at any time;</p>\n<p>Has no fixed length;<br/>Which could lead to unmanageable/very long queues;</p>\n<p><em>Note: do not award marks for responses that focus on dynamic vs static, since queues can be implemented either way</em>.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>. <br/><em>Award <strong>[1]</strong> for declaring all variables used (including loop variable </em><code>i</code><em>);</em><br/><em>Award <strong>[1]</strong> for initialising variable(s) for list traversal;</em><br/><em>Award <strong>[1]</strong> for dealing separately with the case where n equals 1;</em><br/><em>Award <strong>[1]</strong> for attempted looping through the linked list until the correct position;</em><br/><em>Award <strong>[1]</strong> for correct loop using </em><code>curr = curr.getNext()</code><em>; (or similar)</em><br/><em>Award <strong>[1]</strong> for correctly rearranging references to unhook the nth node;</em><br/><em>Award <strong>[1]</strong> for returning the correct result;</em></p>\n<p><em>Example answer using two <code>CartNode</code> variables:</em></p>\n<pre><strong>public</strong> Cart leaveList(<strong>int</strong> n){<br/> Cart result = <strong>null</strong>; // explicit default result<br/> CartNode prev = <strong>null</strong>;<br/> CartNode curr = head;<br/><strong><br/> if</strong> (n==1){<br/> result = removeFirst();<br/> }<br/> else{<br/><strong> int</strong> i=1;<br/><strong> while</strong> (i<n){ // no need to check for null<br/> prev = curr;<br/> curr = curr.getNext();<br/> i++;<br/> }<br/> result = curr.getCart();<br/> prev.setNext(curr.getNext());<br/> }<br/><strong> return</strong> result;<br/>}</pre>\n<p><em>Example answer using one <code>CartNode</code> variable:</em></p>\n<pre><strong>public Cart</strong> leaveList(<strong>int</strong> n){<br/> Cart result = <strong>null</strong>;<br/> CartNode curr = head;<br/><strong><br/> if</strong> (n==1){<br/> result = removeFirst();<br/> }<br/> else{<br/><strong> int</strong> i=1;<br/><strong> while</strong> (i<n-1){ // no need to check for null<br/> curr = curr.getNext();<br/> i++;<br/> } // curr points to node (n-1)<br/> result = curr.getNext.getCart();<br/> curr.setNext(curr.getNext().getNext());<br/> }<br/> <strong>return</strong> result;<br/>}</pre>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong> for including any of the following elements on the discussion</em></p>\n<p>Indentation / Use of white space<br/>Annotations<br/>Meaningful identifiers<br/>Capitalization conventions</p>\n<p><em>Award <strong>[2 max]</strong> for including any of the following reasons in the discussion</em><br/>Helps understanding / reading;<br/>For easer maintenance / extension;<br/>For better team-work / collaboration / development;<br/>To help with de-bugging;</p>\n<p><em>Mark as <strong>[2]</strong> and<strong> [2]</strong></em>.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a straight-forward definition.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Required candidates to show their understanding of the use of pointers for moving through a linked list. Many were unprepared for this, although it is an established part of the course, and incorrectly attempted to make use of the Linked List library class along with associated methods.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many missed out the use of both head and null pointers in sketching the linked list.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was well-answered.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Required candidates to show their understanding of the use of pointers for moving through a linked list. Many were unprepared for this, although it is an established part of the course, and incorrectly attempted to make use of the Linked List library class along with associated methods.</p>\n<div class=\"question_part_label\">e.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was a question that demanded specific examples which were not always given.</p>\n<div class=\"question_part_label\">f.</div>\n</div>",
|
||
"question_id": "19N.2.HL.TZ0.17",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-4-advanced-program-development"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>A generic <code>Event</code> class is defined as follows:</p>\n<pre><strong>class</strong> Event<br/>{<br/><strong> private</strong> String eventID;<br/><strong> private int</strong> numberOfRaces;<br/><strong> private</strong> Race[] races;<br/><strong> private</strong> Race finals;<br/><strong> <br/> public</strong> Event(String ID, int numberOfRaces)<br/> {<br/> eventID = ID;<br/> races = <strong>new</strong> Race[numberOfRaces];<br/><strong> for</strong>(<strong>int</strong> i = 0; i < numberOfRaces; i++)<br/> {<br/> races[i] = <strong>new</strong> Race();<br/> }<br/> finals = <strong>new</strong> Race();<br/> }<br/><strong><br/> public void</strong> addSwimmers()<br/> {<br/> // fills the qualifying heats with swimmers<br/> }<br/><strong><br/> public void</strong> fillFinals()<br/> {<br/> // fills the finals race with the best 8 from the qualifying heats<br/> }<br/> // more methods()<br/>}</pre>\n</div><div class=\"specification\">\n<p>The <math style=\"font-family:'Courier New'\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>Event</mi></math> class above assumes that the event has more than 8 swimmers and requires qualifying heats. However, an event with less than 9 swimmers has no qualifying heats, so the original <math style=\"font-family:'Courier New'\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>Event</mi></math> class was inherited by a new class <math style=\"font-family:'Courier New'\" xmlns=\"http://www.w3.org/1998/Math/MathML\"><mi>FinalsOnlyEvent</mi></math>.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>The same method identifier <code>addSwimmers</code> is used in both classes <code>Race</code> and <code>Event</code>.</p>\n<p>Explain why this does not cause a conflict.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> advantages of the OOP feature “inheritance”.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how method overriding can help to create the new class <code>FinalsOnlyEvent</code>.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/><em>Each method is defined within its own class.</em><br/><em>Each method is called within an object of that class.</em><br/><em>Therefore the compiler knows which method to use.</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for an advantage and <strong>[1]</strong> for an elaboration up to <strong>[2 max]</strong></em>.<br/><em>Mark as<strong> [2]</strong> and <strong>[2]</strong></em>.</p>\n<p>It promotes code reuse;<br/>Because the parent object holds common data and action;</p>\n<p>It reduces maintenance overhead;<br/>Because you only have to update the parent;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for a clear understanding of method overriding and <strong>[1]</strong> for relating it to this situation up to <strong>[2 max]</strong></em>.</p>\n<p>Method overriding redefines/replaces a method from the inherited class;<br/>The constructor could only instantiate the <code>finals</code> object;<br/>The method <code>addSwimmers()</code> could fill <code>finals</code> directly;<br/>The method <code>fillFinals()</code> could do nothing;</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates wanted this to be about polymorphism and overriding, but the two occurrences of this methods were quite simply in different classes and would be called and distinguished between by their respective objects.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>A variety of reasons were accepted with most candidates going for code-reuse and the extensibility features.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This wasn't well-answered, probably because candidates were unsure of the exact structure of the <em>FinalsOnlyEvent</em> class.</p>\n<div class=\"question_part_label\">c.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.11",
|
||
"topics": [
|
||
"option-d-object-oriented-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-2-features-of-oop"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>The <em>Driving Licensing Agency</em> stores information about individuals who hold a driving license and/or own vehicles.<br/>The following rules apply:</p>\n<ul>\n<li>Each individual may only hold one driving license.</li>\n<li>Each individual may own more than one vehicle.</li>\n<li>Each vehicle may be owned by one individual only.</li>\n</ul>\n</div><div class=\"specification\">\n<p>When an individual applies for a driving license, they have to complete a license application form. The following is an extract from that form:</p>\n<p style=\"text-align: center;\"><img src=\"\"/></p>\n</div><div class=\"specification\">\n<p>The data in the form shown above is stored in the <strong>Person</strong> table. The license application form also requires an individual’s medical information. This is stored in a table called <strong>PersonMedical</strong>.</p>\n<p>The following extract is a sample of the medical questions that are asked.</p>\n<p style=\"text-align: center;\"><strong>Figure 2: A sample of the medical questions asked on the license application form</strong></p>\n<p style=\"text-align: center;\"><strong><img src=\"\"/></strong></p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the entity-relationship diagram (ERD) that shows the relationship between the individual, their driving license, and their vehicle(s).</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain why <em>Date of birth</em> has been separated into three fields.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain <strong>two</strong> reasons why medical information should not be stored in the <strong>Person</strong> table.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> issues caused by storing redundant data.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> situations where data stored by the <em>Driving Licensing Agency</em> may need to be open to interrogation by other parties.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.</p>\n<p><img src=\"\"/></p>\n<p><em>Accept either diagram. License, Individual, and Vehicle correctly positioned</em><br/><em>Award <strong>[1]</strong> for 1 to 1.</em><br/><em>Award <strong>[1]</strong> for 1 to m.</em></p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>The order that a date is written varies by country, e.g. dd/mm/yyyy in UK, mm/dd/yyyy in US;<br/>Some dates, such as 01 June 2018 (01/06/2018) could be confused with 06 January 2018 (06/01/2018);<br/>leading to the incorrect information being stored and consequent decisions, e.g. license expired at the wrong time due to incorrect age;</p>\n<p>The Date/String datatype will make analysing slower;<br/>integers can be analysed more quickly than Date/String datatypes;<br/>because functions will be used to split/extract the data;</p>\n<p>The Date datatype will make validating data more difficult.<br/>because it is easier to validate separate integer fields;<br/>rather than one entire data that will need to be split by functions;</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.</p>\n<p><strong>Normalisation</strong><br/>Medical information is only stored if the person has a medical condition / some people will have no medical information stored / some people may have more than one medical conditions;<br/>this requires an additional table / normalisation requires a separate table / one to many relationship;<br/>leaving in the person table will increase storage capacity / empty fields take up space;</p>\n<p><strong>Privacy</strong><br/>All employees will need access to the person table and that would include sensitive medical information;<br/>Protects people’s privacy / data needs to comply with the Data Protection Act / private medical data seen by non-authorised personnel may cause harm to the licence applicant / potentially result in legal action;<br/>having confidential data in a separate table allows that table to be only available to people with a certain permission level;</p>\n<p><strong>Updates</strong><br/>Person table is also likely to be less permanent and need updating more often;<br/>medical information rarely gets updated so is more permanent;<br/>the person table may be useful in other applications, as it offers a way of identifying citizens/the medical data is not likely to be used by other applications;</p>\n<p><em>Mark as [3] + [3]</em></p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>May lead to update/deletion anomalies;<br/>Address changes may result in duplicate addresses;<br/>so letters / fines may go to the wrong address;<br/>Storing data multiple times wastes storage space;<br/>and may slow down data retrieval / data entry; </p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/><em>Accept any suitable example</em></p>\n<p><strong>Police access</strong><br/>It is a legal requirement for the VDLA to give access to the police;<br/>e.g. a speeding vehicle / an accident / linked to a police investigation;<br/>so the police will need to look up the details of the person that owns the car;<br/>facial scanning software may be cross-referenced with the car owner’s driving license photo;<br/>so that police have a way to check the identity of the person driving the car;</p>\n<p><strong>Insurance company access</strong><br/>A person taking out car insurance signs a consent form to give VDLA access to their records;<br/>this would allow the insurance company to build up a profile e.g., check for driving offences, see how long that person had owned a car;<br/>thus, a quote could be created quickly / minimal effort;<br/>provides proof of driver eligibility (i.e., not serving a driving ban);</p>\n<p><strong>Medical access</strong><br/>Doctors may require access to an accident victim’s records;<br/>To check blood type etc.;</p>\n<p><em>Mark as [2] + [2]</em></p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most of the students clearly identified the main entities, their correct position and cardinality in the ERD diagram. Few failed to establish and correctly label the relationships.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was not well answered with many students giving vague generic answers when explaining the separation of the Date of Birth into three fields. Very few students included reasons related to data type making easier analysis / validation / correct formatting.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question was not answered well with most candidates struggling to explain reasons for having a separate table for medical information. However, the majority of students were able to explain privacy issues related to the question, but not able to explain other reasons such as normalization, updates or user access rights.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Candidates tended to comment on the waste of storage space and to mention update/deletion anomalies, but few were able to elaborate on these aspects or outline others.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This question explicitly asked for two different situations in which the database had to be open to interrogation by other parties. Successful candidates were able to combine knowledge and real-world context and provide situations with concrete examples of third parties and the reasons for interrogating the DB.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.1",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-2-the-relational-database-model",
|
||
"a-1-basic-concepts",
|
||
"a-3-further-aspects-of-database-management"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p>An <code>Event</code> has been instantiated with 2 qualifying heats for a total of 11 swimmers.</p>\n<p><code>Event free100 = <strong>new</strong> Event(\"100 m free style\",2);</code></p>\n<p>The swimmers were added to the two <code>Race</code> arrays and after the races, their times were recorded as shown in the table.</p>\n<p>(For the purpose of this question, the name represents the full swimmer object.)</p>\n<p><img src=\"\"/></p>\n<p>The method <code>fillFinals()</code> will select the 8 fastest swimmers, in ascending order of time, from both <code>swimmer</code> arrays and copy them to the <code>swimmer</code> array in the <code>finals</code> race.</p>\n</div><div class=\"specification\">\n<p>To help with this selection, all entries from <code>races[0]</code> and <code>races[1]</code> will be copied into two new parallel arrays of size 16, one array for swimmers and one array for their times.</p>\n</div><div class=\"specification\">\n<p>The two temporary arrays will be sorted using the following code.</p>\n<pre><strong>int</strong> i,j;<br/>Swimmer swapSwimmer;<br/><strong>double</strong> swapTime;<br/><strong>for</strong>(i = 0; i < 15; i++)<br/>{<br/><strong> for</strong>(j = 0; j < 15; j++)<br/> {<br/><strong> if</strong>(tempTime[j] > tempTime[j + 1]) // if wrong order then…<br/> {<br/> swapSwimmer = tempSwimmer[j]; // swap the swimmer and…<br/> tempSwimmer[j] = tempSwimmer[j + 1];<br/> tempSwimmer[j + 1] = swapSwimmer;<br/> swapTime = tempTime[j]; // swap the time<br/> tempTime[j] = tempTime[j + 1];<br/> tempTime[j + 1] = swapTime;<br/> }<br/> }<br/>}</pre>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Sketch the resulting<code> swimmer</code> array in <code>finals</code>.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the code fragment for the given situation that will copy swimmers and times into two parallel arrays named <code>tempSwimmer</code> and <code>tempTime</code>.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>State the name of this sorting algorithm.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>two</strong> improvements to this code that would make the algorithm more efficient.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Construct the code fragment that will copy the names of the 8 fastest swimmers in ascending order of time from the array <code>tempSwimmer</code> to the array <code>swimmers</code> in the race <code>finals</code>.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for array of 8 slots with array name.</em><br/><em>Award <strong>[1]</strong> for correct entries (in any order).</em><br/><em>Award <strong>[1]</strong> for correct order.</em></p>\n<p><em><img src=\"\"/></em></p>\n<p>Do not penalize the lack of subscripts.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for correctly declaring 2 arrays of size 16.</em><br/><em>Award <strong>[1]</strong> for correct outer loop.</em><br/><em>Award <strong>[1]</strong> for correct inner loop.</em><br/><em>Award <strong>[1]</strong> for copying swimmer object.</em><br/><em>Award <strong>[1]</strong> for copying time.</em><br/><em>Award <strong>[1]</strong> for incrementing the index of the new arrays.</em></p>\n<p><em>Example answers:</em></p>\n<pre>Swimmer[] tempSwim = new Swimmer[16];<br/><strong>double</strong>[] tempTime = <strong>new double</strong>[16];<br/><strong>int</strong> newIndex = 0;<br/><strong>for</strong>(<strong>int</strong> i = 0; i < 2; i++){<br/><strong> for</strong>(<strong>int</strong> j = 0; j < 8; j++){<br/> tempSwim.swimmer[newIndex] = races[i].swimmer[j];<br/> tempTime.time[newIndex] = races[i].time[j];<br/> newIndex++;<br/> }<br/>}</pre>\n<p><em><strong>Note</strong>: that the question asks for all entries to be copied. However, do not penalize \"efficient\" solutions that avoid copying the null and 0 entries.</em></p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Bubblesort;</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for stating an improvement and <strong>[1]</strong> for an elaboration up to <strong>[2 max]</strong></em>.<br/><em>Mark as <strong>[2]</strong> and <strong>[2]</strong></em>.</p>\n<p>Include a flag “swapped”;<br/>That can help stop the outer loop if there is a pass through the inner loop with no swap;<br/>Limit the inner loop by deducting the outer loop counter;<br/>So that the sorted elements are no longer compared;</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for correctly instantiating variables.</em><br/><em>Award <strong>[1]</strong> for correct loop condition (<code>count</code> < 8).</em><br/><em>Award <strong>[1]</strong> for checking for a 0 time (or null entry).</em><br/><em>Award <strong>[1]</strong> for correctly copying.</em><br/><em>Award <strong>[1]</strong> for incrementing <code>count</code> in the right place.</em><br/><em>Award <strong>[1]</strong> for incrementing <code>k</code> in the right place.</em></p>\n<p><em>Example answers:</em></p>\n<pre><strong>int</strong> k = 0;<br/><strong>int</strong> count = 0;<br/><strong>while</strong>(count < 8) && (k < 16){<br/><strong> if</strong>(tempSwim[k] != 0){<br/> finals.swimmer[count] = tempSwim[k];<br/> count++;<br/> } <br/> k++;<br/>}</pre>\n<p><em><strong>Note</strong>: Do not penalize for not including loop condition (<code>k < 16</code>)</em></p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was well-answered.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>This was the first significant piece of coding on the paper and, as in previous papers, divided the students into those who were comfortable with coding and those who weren't. From the former came a variety of solutions, some of which were quite innovative. The complexity came from ensuring that the correct indices were used for the different array items and for dealing correctly with private variables outside of their class.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Almost all correctly gave <em>Bubble Sort</em>, but clear details of improvements that could be made were limited to the candidates who were adept at programming.</p>\n<div class=\"question_part_label\">c.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Almost all correctly gave <em>Bubble Sort</em>, but clear details of improvements that could be made were limited to the candidates who were adept at programming.</p>\n<div class=\"question_part_label\">c.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates failed to realise that the 8 fastest swimmers were not the first 8 entries in the sorted array as this would give null entries.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "19M.2.SL.TZ0.12",
|
||
"topics": [
|
||
"option-d-object-oriented-programming",
|
||
"topic-4-computational-thinking-problem-solving-and-programming"
|
||
],
|
||
"subtopics": [
|
||
"d-3-program-development",
|
||
"4-2-connecting-computational-thinking-and-program-design"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>Billetmania</em> is an online company that sells tickets for theatre performances and music concerts. After a customer has chosen their seats, they can pay for the tickets through a secure online payment system. Once the transaction has been completed, the customer receives an email receipt.</p>\n</div><div class=\"specification\">\n<p>An information system and a database are used for <em>Billetmania</em>’s day-to-day operations.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Define the term <em>database transaction</em>.</p>\n<div class=\"marks\">[1]</div>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline how the <em>Billetmania</em> information system would utilize a database.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain the importance of transaction durability to <em>Billetmania</em> when clients book tickets.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Explain how the <em>Billetmania</em> database management system ensures that a seat is not booked by two people simultaneously.</p>\n<div class=\"marks\">[4]</div>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[1 max]</strong></em>. <br/>A logical unit of work that is executed in full or not at all;<br/>A transaction is a single logical operation that comprises of a sequence of database operations;<br/>A transation satisfies the ACID (Atomicity, Consistency, Isolation, Durability) properties;</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>. <br/>The database would store details of concerts, tickets sold, customers;<br/>An information system would access the database to present data it in a way that aids informs managers / aids decision making (e.g. charts of ticket sales);</p>\n<p><em>Accept any other reasonable example</em>.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>. <br/>Durability ensures that transactions are saved permanently and do not accidentally disappear or get erased;<br/><em>Billetmania</em> does not need to worry the transaction being lost even in the event of power loss, crashes, or errors;<br/>A seat in a theatre is guaranteed even if the database crashes;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[4 max]</strong></em>. <br/>Concurrency allows multiple users try to book tickets at the same time / complete a transaction at the same time;<br/>Concurrency prevents access by more than one user to the same row/record;<br/>Concurrency uses row locking;<br/>Select seats are locked for a short period of time to ensure that they aren’t double booked/overwritten;</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>A standard question that was not well answered. Many candidates presented vague responses that did not define the concept of <em>Database Transaction</em>, some of them seemed to have confusion with the concept of <em>Data Migration</em>.</p>\n<div class=\"question_part_label\">a.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to outline the role of the database in the given scenario by using correct examples but failed to point out how the information system would utilize the database access.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Some candidates provided detailed responses explaining durability in context by including characteristics of persistence in the event of system failure, but many of the responses were not specific enough and did not correctly relate the response to the given scenario.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many responses were incomplete and failed to provide a proper explanation. Some of them were very generic. Most candidates were aware of the row locking concept and its application in the given scenario.</p>\n<div class=\"question_part_label\">d.</div>\n</div>",
|
||
"question_id": "20N.2.SL.TZ0.2",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-1-basic-concepts",
|
||
"a-2-the-relational-database-model"
|
||
]
|
||
},
|
||
{
|
||
"Question": "<div class=\"specification\">\n<p><em>ZCC</em> has a chain of offices that sell different types of paper to customers all over the world. They have data stored in their data warehouses that will help them make important marketing decisions for the future, as they have plans to diversify into other products like gift-wrappers, scribble-pads, stationery, books and calculators.</p>\n</div><div class=\"specification\">\n<p><em>ZCC</em> is going to use data mining techniques to discover patterns in their data.</p>\n</div><div class=\"specification\">\n<p>The company has customers who have missed the payment deadline for their purchases from <em>ZCC</em>.</p>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why data warehousing is time dependent.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline <strong>one</strong> reason why <em>ZCC</em> uses a data warehouse.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Outline why transformation of the data is necessary prior to it being loaded into the data warehouse.</p>\n<div class=\"marks\">[2]</div>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Compare cluster analysis and classification as techniques for discovering patterns in <em>ZCC</em>'s data.</p>\n<div class=\"marks\">[6]</div>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p>Describe how the process of deviation detection can be applied to identify customers who are likely to miss the payment deadline for their purchases from <em>ZCC</em>.</p>\n<div class=\"marks\">[3]</div>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px; padding-right: 20px;\">\n<p><em>ZCC</em> is aware that other data mining and detection techniques will allow more informed marketing decisions to be made.</p>\n<p>Explain how database segmentation and link analysis can be used by <em>ZCC</em> to improve their marketing strategies.</p>\n<div class=\"marks\">[5]</div>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Markscheme": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Data warehouses contain both historical and current data;<br/>Timestamps are required to compare data from different times;</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>Increased Query and System Performance;<br/>data warehouse is built for analysis and retrieval of data rather than efficient upkeep of individual records (i.e. transactions);</p>\n<p>Timely Access to Data;<br/>ETL, are used within a data warehouse environment. These routines consolidate data from multiple source systems and transform the data into a useful format that enable quick querying;</p>\n<p>Enhanced Data Quality and Consistency;<br/>Data from the various business units and departments is standardized and the inconsistent nature of data from the different sources is removed;<br/>Individual business units will start to utilize the same data repository as the source system for their individual queries and reports;</p>\n<p>Historical Intelligence;<br/>Data warehouse stores large amounts of historical data and time-period analysis, trend analysis, and trend prediction thus allowing for advanced reporting and analysis of multiple time-periods;</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[2 max]</strong></em>.<br/>When the data is collected from different sources each source will have their own standards if we have two different data sources A and B;<br/>Selection of the data that is going to be useful in analysis – the different offices will have data relevant only to them, such as staff names, etc.;<br/>Standardization of the data – the company may have imposed a standard on all its offices, but this is not always the case, and the data will certainly have to be Checked, e.g. date formats are different in different countries;<br/>Other transformation techniques that students may give as examples are more like:</p>\n<ul>\n<li>Cleaning (e.g. “Male” to “M” and “Female” to “F” etc.)</li>\n<li>Filtering (e.g. selecting only certain columns to load)</li>\n<li>Enriching (e.g. Full name to First Name , Middle Name , Last Name)</li>\n<li>Splitting a column into multiple columns and vice versa.</li>\n</ul>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[6 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for a description of cluster analysis</em><br/><em>Award <strong>[1]</strong> for description of cluster analysis being used to find patterns</em><br/><em>Award <strong>[1]</strong> for a description of link analysis</em><br/><em>Award <strong>[1]</strong> for a description of link analysis being used to find patterns</em><br/><em>Award up to <strong>[2]</strong> for comparison between the two techniques</em></p>\n<p><strong>Cluster Analysis</strong><br/>Cluster analysis groups customers by age / according to different factors, such as region/location;<br/>Therefore, it enables comparison between groups;</p>\n<p><strong>Classification</strong><br/>A classifier or model is developed using training sets of data;<br/>New data is then added to the model and compared against the predicted outcomes / new classifiers may be developed;</p>\n<p><strong>Discussion</strong><br/>Classification requires prior knowledge of the customer base, cluster analysis does not;<br/>Data can be classed in new samples using classification whereas for cluster analysis only suggests groups based upon patterns in data;<br/>Labelled samples from a set of classes is required for classification whereas for cluster analysis unlabelled samples will do;</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[3 max]</strong></em>.<br/>Access the customer payment details for purchases of fairly large orders from the data warehouse;<br/>For a given group (and for a particular period/given a range for timestamp) of customers;<br/>Identify the outliers/customers who have defaulted more than a fixed number of times in payment after running the deviation detection (multiple if-then-else statements) algorithm;<br/>List the names of those customers;</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p><em>Award <strong>[5 max]</strong></em>.<br/><em>Award <strong>[1]</strong> for an outline of customer segmentation</em><br/><em>Award <strong>[1]</strong> for an outline of link analysis</em><br/><em>Award up to <strong>[3 max]</strong> for use by ZCC to improve marketing strategies</em></p>\n<p><strong>Customer segmentation</strong><br/>Divides a customer base into groups of individuals that are similar in specific ways relevant to marketing, such as age, gender, order of the type of paper, frequency of orders placed and the size of the orders normally placed;<br/>assign each customer to one of the segments;<br/>A typical segmentation makes each segment distinct from other segments (different segments have different needs), it is homogeneous within the segment (exhibits common needs);<br/>segmenting is using borders to form groups;<br/>Segmentation groups objects into similar groups;<br/>The resulting groups contain members that are more similar to each other than they are to other groups;</p>\n<p><strong>Link Analysis</strong><br/>Load a claim and runs a query back to the database to find all other claims sharing any similar attributes;<br/>show matches on the address of a claimant in the original case being investigated;<br/>Now combine matches-merge identical nodes. So, we can more easily see unusual connections;<br/>Once seen a suspicious link, accept or escalate;<br/>Representing data as a network offers an engaging way for analysts to rapidly understand events;</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"Examiners report": "<div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to identify why data warehouses required timed data.</p>\n<div class=\"question_part_label\">a.i.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates were unable to clearly explain why data warehouses are advantageous for a company.</p>\n<div class=\"question_part_label\">a.ii.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates were able to describe why the data from different data sources needs to be standardized before being loaded into a data warehouse.</p>\n<div class=\"question_part_label\">b.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Many candidates were able to give generic descriptions of cluster analysis and classification, but they were unable to discuss the differences between the two in any detail.</p>\n<div class=\"question_part_label\">c.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>Most candidates demonstrated a good understanding of data deviation in this situation.</p>\n<div class=\"question_part_label\">d.</div>\n</div><div class=\"question\" style=\"padding-left: 20px;\">\n<p>The majority of candidates were only able to discuss data segmentation and link analysis at an abstract level.</p>\n<div class=\"question_part_label\">e.</div>\n</div>",
|
||
"question_id": "19M.2.HL.TZ0.4",
|
||
"topics": [
|
||
"option-a-databases"
|
||
],
|
||
"subtopics": [
|
||
"a-4-further-database-models-and-database-analysis"
|
||
]
|
||
}
|
||
] |