<HTML> <h1> Data Structures Using Java </h1>

<h2>CMPU-102 Section 51</h2> <h2>Vassar College, Spring 2020</h2> <h2>Syllabus & Course Wiki</h2>

<p> Welcome to the main section of our course wiki. Use this as a starting point to access the weekly course schedule, lectures, labs, resources, etc. etc. etc. </p>

<h2> Contact Information </h2>

<ul>

  <li> Professor: Peter Lemieszewski                                                       
  <li> Office: Unfortunately, I do not have an office :( but I will have office hours.
  <li> Office Hour location: I will generally be hanging around the vicinity of SP309
  <li> Office Hours: Tues/Thurs 08:00am-9:00am, Wed 5:00pm-6:00pm... and by appointment
  <li> Email: pelemieszewski //(once my gmail account is restored!)//                

</ul>

<h2> Class sessions </h2>

<ul>

  <li> When - class sessions: Tue/Thu 09:00-10:15am 
  <li> When - lab sessions:   Wed 06:00pm-08:00pm
  <li> Where: SP 309

</ul>

<h2> Course Description: </h2>

<p>An algorithm is the specification of a method to solve a given problem. A data structure is a specific way of organizing data so that it can be used efficiently by an algorithm. This course approaches data structures and algorithms from a practical perspective,

  using Object-Oriented Programming (OOP), and particularly Java, as a framework to learn and experiment with the concepts being discussed.</p>

<p>Topics covered include:</p> <ul>

  <li>Object-Oriented Programming (OOP)
      <ul>
          <li>Encapsulation</li>
          <li>Inheritance</li>
          <li>Polymorphism</li>
          <li>The Java programming language</li>
          <ul>
              <li>OOP in Java</li>
              <li>Operators</li>
              <li>Expressions</li>
              <li>Control flow</li>
              <li>Testing and debugging</li>
              <li>Java documentation (Javadoc)</li>
              <li>Exceptions</li>
              <li>The collections framework</li>
              <li>Input/output</li>
              <li>Graphical User Interfaces (GUI)</li>
          </ul>
      </ul>
  </li>
  <li>Abstract data types (ADT)
      <ul>
          <li>Lists</li>
          <li>Queues</li>
          <li>Stacks</li>
          <li>Maps</li>
          <li>Trees</li>
      </ul>
  </li>
  <li>Data structures
      <ul>
          <li>Arrays</li>
          <li>Linked lists</li>
          <li>Array lists</li>
          <li>Hash sets</li>
          <li>Hash maps</li>
          <li>Tree sets</li>
          <li>Tree maps</li>
      </ul>
  </li>
  <li>Algorithms
      <ul>
          <li>Searching</li>
          <li>Sorting</li>
          <li>String parsing using Finite State Machines (FSMs)</li>
          <li>Arithmetic expression evaluation</li>
      </ul>
  </li>

</ul>

<h2>Prerequisites</h2> <ul>

  <li>CMPU-101</li>

</ul>

<h2> Textbooks: </h2>

  <p>We will be using the Eck book as our primary- and required - text. If you are unfamiliar with using an IDE, the BlueJ book is a good resource. And, if you prefer to use
a printed text book (does anyone use a printed textbook anymore?) then Java Precisely is recommended. Check the sidebar for additional resources as the semester progresses.</p>

<ul>

  <li>Introduction to Programming Using Java, Version 8.1 by David J. Eck. Online at <a href="http://math.hws.edu/javanotes">http://math.hws.edu/javanotes</a>.</li>
  <li>Objects First with Java - A Practical Introduction Using BlueJ, Sixth Edition by David J. Barnes and Michael Kölling. Optional.</li>
  <li>Java Preciesly, Second Edition by Peter Sestoft.</li>
  <li>Java API. Online at <a href="http://docs.oracle.com/javase/10/docs/api/">http://docs.oracle.com/javase/10/docs/api/</a>.</li>
  <li>Official Java Tutorial. Online at <a href="http://docs.oracle.com/javase/tutorial/">http://docs.oracle.com/javase/tutorial/</a>.</li>
      	

<h2>Grading</h2>

<ul>

  <li>Labs: 15%</li>
  <li>Homework projects: 35%</li>
  <li>Midterm: 25%</li>
  <li>Final exam: 25%</li>

</ul>

<h2>Class attendance</h2>

<p>Class attendance is required. I will take attendance sporadically. If you are unable to attend a class or lab session, please let me know; a simple email will suffice. Even if you happen to miss a class/lab session, you are still responsible for all of the information given in class, no matter the form in which it is given.</p>

<p>Consult this wiki and classmates to find out about any administrative/academic/other information you may have missed.</p>

<h2>Use of electronic devices in class</h2>

<p>Labs will require the use of a computer. Students may elect to use the computers provided by the College or their own if they so prefer.</p>

<p>Even when not required, students may elect to use computers or other electronic devices for class-related purposes such as note taking.</p>

<p>The use of electronic devices for non-class related purposes is prohibited. Also, devices must be in silent mode at all times so as to not disturb the class. </p>

<h2>Homework projects</h2>

<p>Homework projects shall be used to consolidate and expand upon concepts introduced in class. They will consist of Java programming assignments.</p>

<p>You can expect a total of 4 projects but there may be more than 4 projects. Expect each project to be of increasing size and complexity, except for a short, final, project. The contribution of each homework assignment to the final grade will be proportional to its size and complexity. Out of the 35 “points” dedicated to homework, homework #1 will contribute 11%, homework #2: 29%, homework #3: 51%, and homework #4: 9%. </p>

<h2>Policy on collaboration and academic integrity</h2>

<p>All labs, homework projects, and exams should be completed by each student by themselves.</p>

<p>Please do not cheat. Copying solutions is strictly forbidden.</p>

<p>Certainly, general discussions of approaches and techniques are allowed.</p>

<h2>Useful student resources</h2>

<ul>

  <li>The Quantitative Reasoning Center (<a href="http://ltrc.vassar.edu/qrc/">ltrc.vassar.edu/qrc/</a>) helps students improve their analytical skills pertaining to quantitative subjects.</li>
  <li>The Writing Center (<a href="http://ltrc.vassar.edu/writing-center/">ltrc.vassar.edu/writing-center/</a>) helps students improve the clarity and cogency of their writing.</li>

</ul>

<h2>Accessibility and educational opportunity</h2>

<p>Academic accommodations are available for students registered with the Office for Accessibility and Educational Opportunity. Students in need of ADA/504 accommodations should schedule an appointment with the professor early in the semester to arrange

  for said accommodations.</p>

<h2>Learning environment</h2>

<p>Vassar College is committed to providing a safe and respectful learning environment for all students. An environment free of all forms of discrimination and harassment, including sexual assault, domestic violence, dating violence, and stalking. Vassar

  College has staff members trained to support students in navigating campus life, accessing health and counseling services, providing academic and housing accommodations, helping with legal protective orders, and more:</p>

<ul>

  <li>Counseling Service (<a href="http://counselingservice.vassar.edu">counselingservice.vassar.edu</a>, 845-437-5700)</li>
  <li>Health Service (<a href="http://healthservice.vassar.edu">healthservice.vassar.edu</a>, 845-437-5800)</li>
  <li>Charlotte Strauss-Swanson, SAVP (Sexual Assault and Violence Prevention) director (<a href="http://savp.vassar.edu">savp.vassar.edu</a>, 845-437-7863)</li>
  <li>SART (Sexual Assault Response Team) advocate, available 24/7 by calling the CRC at 845-437-7333</li>
  <p>The SAVP website and the Title IX section of the EOAA website (eoaa.vassar.edu/title-ix/) have more information, as well as links to both on- and off-campus resources.</p>

</ul>

<h2> Acknowledgements </h2>

  <p>I would like to thank Professor Rui Meireles, who developed this course and teaches it quite often. He has graciously shared his course materials with me.</p>

</HTML>