<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en-GB">
	<id>https://wiki.kram.nz/index.php?action=history&amp;feed=atom&amp;title=SE250%3Alab-3%3Ahals016</id>
	<title>SE250:lab-3:hals016 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.kram.nz/index.php?action=history&amp;feed=atom&amp;title=SE250%3Alab-3%3Ahals016"/>
	<link rel="alternate" type="text/html" href="https://wiki.kram.nz/index.php?title=SE250:lab-3:hals016&amp;action=history"/>
	<updated>2026-06-04T19:07:40Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.45.3</generator>
	<entry>
		<id>https://wiki.kram.nz/index.php?title=SE250:lab-3:hals016&amp;diff=5526&amp;oldid=prev</id>
		<title>Mark: 8 revision(s)</title>
		<link rel="alternate" type="text/html" href="https://wiki.kram.nz/index.php?title=SE250:lab-3:hals016&amp;diff=5526&amp;oldid=prev"/>
		<updated>2008-11-03T05:19:19Z</updated>

		<summary type="html">&lt;p&gt;8 revision(s)&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;===&amp;#039;&amp;#039;&amp;#039;Lab3&amp;#039;&amp;#039;&amp;#039;===&lt;br /&gt;
&lt;br /&gt;
===Question 1===&lt;br /&gt;
&lt;br /&gt;
For question one I made a loop for the arralist_push function, to change the array value to zero, 10 million times.&lt;br /&gt;
Here is my code.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
int main() {&lt;br /&gt;
  ArrayList arra;&lt;br /&gt;
  int i;&lt;br /&gt;
  arraylist_init(&amp;amp;arra);&lt;br /&gt;
  int clock1,clock2;&lt;br /&gt;
&lt;br /&gt;
  clock1 = clock();&lt;br /&gt;
  for(i=0;i&amp;lt;10000000;i++){&lt;br /&gt;
    arraylist_push(&amp;amp;arra, 0);&lt;br /&gt;
  }&lt;br /&gt;
  clock2=clock();&lt;br /&gt;
  printf(&amp;quot;%d ms&amp;quot;, (clock2-clock1));&lt;br /&gt;
&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
The result ranged from 550-640ms.&lt;br /&gt;
&lt;br /&gt;
===Question 2===&lt;br /&gt;
&lt;br /&gt;
For question two I changed the growth factor to a variety of numbers.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;OUTPUT&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
*3 Growth Factor - &lt;br /&gt;
The for loop of 10 million loops took 594 ms.&lt;br /&gt;
&lt;br /&gt;
*9^99999 GF - &lt;br /&gt;
The for loop of 10 million loops took 531 ms.&lt;br /&gt;
&lt;br /&gt;
*1 - Error -&lt;br /&gt;
/usr/bin/bash: line 1:  5576 Segmentation fault      (core dumped) ./arraylist2.exe.&lt;br /&gt;
&lt;br /&gt;
*1.1 - &lt;br /&gt;
The for loop of 10 million loops took 1204 ms.&lt;br /&gt;
&lt;br /&gt;
*1.2 - &lt;br /&gt;
The for loop of 10 million loops took 890 ms.&lt;br /&gt;
&lt;br /&gt;
*1.3 - &lt;br /&gt;
The for loop of 10 million loops took 750 ms.&lt;br /&gt;
&lt;br /&gt;
*1.4 - &lt;br /&gt;
The for loop of 10 million loops took 672 ms.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Question 3===&lt;br /&gt;
&lt;br /&gt;
For this question the starting allocation for the array needed to be changed to various numbers.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;OUTPUT&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&amp;#039;&amp;#039;Original minimum allocation = 16&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Minimum Allocation of 1 - The for loop of 10 million loops took 562 ms.&lt;br /&gt;
&lt;br /&gt;
Minimum Allocation of 100 - The for loop of 10 million loops took 594 ms.&lt;br /&gt;
&lt;br /&gt;
Minimum Allocation of 99999 - The for loop of 10 million loops took 531 ms.&lt;br /&gt;
&lt;br /&gt;
Minimum Allocation of 0.01 - /usr/bin/bash: line 1:  5576 Segmentation fault      (core dumped) ./arraylist3.exe.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
The results suggest that the starting allocation does not affect the time it takes to do the loop 10 million times.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Question 4===&lt;br /&gt;
&lt;br /&gt;
Experiment 1 was repeated but with the added code of using the function &amp;quot;ensure_capacity&amp;quot; to allocate memory (initially) according to the number of loops in the for loop (10 million).&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Partial Code&lt;br /&gt;
&lt;br /&gt;
ensure_capacity(&amp;amp;arra,10000000);&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
The output was faster than normal.&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;OUTPUT&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
The for loop of 10 million loops took 437 ms.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Mark</name></author>
	</entry>
</feed>