<?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%3Asbha077</id>
	<title>SE250:lab-3:sbha077 - 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%3Asbha077"/>
	<link rel="alternate" type="text/html" href="https://wiki.kram.nz/index.php?title=SE250:lab-3:sbha077&amp;action=history"/>
	<updated>2026-05-07T20:20:27Z</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:sbha077&amp;diff=5755&amp;oldid=prev</id>
		<title>Mark: 12 revision(s)</title>
		<link rel="alternate" type="text/html" href="https://wiki.kram.nz/index.php?title=SE250:lab-3:sbha077&amp;diff=5755&amp;oldid=prev"/>
		<updated>2008-11-03T05:19:27Z</updated>

		<summary type="html">&lt;p&gt;12 revision(s)&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Lab 3 Report ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Task 1 ===&lt;br /&gt;
&lt;br /&gt;
We had to calculate the time taken to insert n elements into an array (ArrayList) using the arraylist_push function.&lt;br /&gt;
&lt;br /&gt;
CODE &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 #include &amp;quot;arraylist.c&amp;quot;&lt;br /&gt;
 #include &amp;lt;time.h&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
 int main() {&lt;br /&gt;
 &lt;br /&gt;
 	ArrayList myArr;&lt;br /&gt;
 &lt;br /&gt;
 	int n = 12345678;&lt;br /&gt;
 &lt;br /&gt;
 	clock_t start, stop;&lt;br /&gt;
 &lt;br /&gt;
 	int i;&lt;br /&gt;
 	double elapsed;&lt;br /&gt;
 &lt;br /&gt;
 	arraylist_init(&amp;amp;myArr);&lt;br /&gt;
 &lt;br /&gt;
 	start = clock();&lt;br /&gt;
 &lt;br /&gt;
 	for (i = 0; i&amp;lt;n; i++) {&lt;br /&gt;
 &lt;br /&gt;
 		arraylist_push(&amp;amp;myArr, 2);&lt;br /&gt;
 &lt;br /&gt;
 	}&lt;br /&gt;
 &lt;br /&gt;
 	stop = clock();&lt;br /&gt;
 &lt;br /&gt;
 	elapsed = ((double) (stop - start)) / CLOCKS_PER_SEC;&lt;br /&gt;
 &lt;br /&gt;
 	printf(&amp;quot;\n Time taken for %d pushes = %lf\n&amp;quot;, n, elapsed);&lt;br /&gt;
 &lt;br /&gt;
 	return 0;&lt;br /&gt;
 &lt;br /&gt;
 }&lt;br /&gt;
&lt;br /&gt;
RESULTS &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 Trial 1 : Time taken for 12345678 pushes = 0.468000 seconds&lt;br /&gt;
 Trial 2 : Time taken for 12345678 pushes = 0.468000 seconds&lt;br /&gt;
 Trial 3 : Time taken for 12345678 pushes = 0.468000 seconds&lt;br /&gt;
 Trial 4 : Time taken for 12345678 pushes = 0.484000 seconds&lt;br /&gt;
 Trial 5 : Time taken for 12345678 pushes = 0.515000 seconds&lt;br /&gt;
&lt;br /&gt;
OBSERVATION &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
It takes about 0.5 odd seconds on my laptop for 12345678 pushes.&lt;br /&gt;
&lt;br /&gt;
=== Task 2 ===&lt;br /&gt;
&lt;br /&gt;
RESULTS &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 Trial 1 ( * 3.0 ) : Time taken for 12345678 pushes = 0.453000 seconds&lt;br /&gt;
 Trial 2 ( * 4.0 ) : Time taken for 12345678 pushes = 0.421000 seconds&lt;br /&gt;
 Trial 3 ( * 5.0 ) : Time taken for 12345678 pushes = 0.421000 seconds&lt;br /&gt;
 Trial 4 ( * 10.0 ): Time taken for 12345678 pushes = 0.390000 seconds&lt;br /&gt;
 Trial 5 ( * 100.0): Time taken for 12345678 pushes = 0.390000 seconds&lt;br /&gt;
&lt;br /&gt;
OBSERVATION &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Not a major difference in time observed here.&lt;br /&gt;
&lt;br /&gt;
=== Task 3 ===&lt;br /&gt;
&lt;br /&gt;
RESULTS &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 Trial 1 (ARRAYLIST_MIN_ALLOC = 100)     : Time taken for 123456789 pushes = 4.906000 seconds&lt;br /&gt;
 Trial 2 (ARRAYLIST_MIN_ALLOC = 1000)    : Time taken for 123456789 pushes = 4.531000 seconds&lt;br /&gt;
 Trial 3 (ARRAYLIST_MIN_ALLOC = 10000)   : Time taken for 123456789 pushes = 4.812000 seconds&lt;br /&gt;
 Trial 4 (ARRAYLIST_MIN_ALLOC = 100000)  : Time taken for 123456789 pushes = 4.968000 seconds&lt;br /&gt;
 Trial 5 (ARRAYLIST_MIN_ALLOC = 1000000) : Time taken for 123456789 pushes = 4.546000 seconds&lt;br /&gt;
&lt;br /&gt;
OBSERVATION &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Interestingly, there really isn&amp;#039;t much of a time change. Infact unless we get pedantic with our times, there really isn&amp;#039;t any noticable difference in time.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Task 4 ===&lt;br /&gt;
&lt;br /&gt;
RESULTS &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
 Trial 1 (preallocated space = 10)       : Time taken for 123456789 pushes = 0.390000 seconds&lt;br /&gt;
 Trial 2 (preallocated space = 100)      : Time taken for 123456789 pushes = 0.390000 seconds&lt;br /&gt;
 Trial 3 (preallocated space = 1000)     : Time taken for 123456789 pushes = 0.375000 seconds&lt;br /&gt;
 Trial 4 (preallocated space = 10000)    : Time taken for 123456789 pushes = 0.375000 seconds&lt;br /&gt;
 Trial 5 (preallocated space = 10000000) : Time taken for 123456789 pushes = 0.390000 seconds&lt;br /&gt;
&lt;br /&gt;
OBSERVATION &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Again, no noticable time difference experienced; they are rather consistent.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Task 5 ===&lt;br /&gt;
&lt;br /&gt;
RESULTS &amp;gt;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Task 6 ===&lt;br /&gt;
&lt;br /&gt;
RESULTS &amp;gt;&amp;gt;&lt;/div&gt;</summary>
		<author><name>Mark</name></author>
	</entry>
</feed>