ENEE150 Discussion 02 Section 0101 Adam Wang.

Slides:



Advertisements
Similar presentations
C Language.
Advertisements

1 Loops. 2 Often we want to execute a block of code multiple times. Something is always different each time through the block. Typically a variable is.
CS 201 Functions Debzani Deb.
While Loops and Do Loops. Suppose you wanted to repeat the same code over and over again? System.out.println(“text”); System.out.println(“text”); System.out.println(“text”);
Week 4-5 Java Programming. Loops What is a loop? Loop is code that repeats itself a certain number of times There are two types of loops: For loop Used.
1 iSee Player Tutorial Using the Forest Biomass Accumulation Model as an Example ( Tutorial Developed by: (
How to make the worksheet for the TRD Gas Refill K. Andeen (KIT) Updated 7 Feb 2014 Objective : This worksheet does all of the TRD Gas Refill calculations.
Nachos Phase 1 Code -Hints and Comments
Iteration. Adding CDs to Vic Stack In many of the programs you write, you would like to have a CD on the stack before the program runs. To do this, you.
Goals of Course Introduction to the programming language C Learn how to program Learn ‘good’ programming practices.
1 SEEM3460 Tutorial Unix Introduction. 2 Introduction Unix-like system is everywhere Linux Android for smartphones Google Chrome OS for Chromebook Web.
Week 5 - Wednesday.  What did we talk about last time?  Exam 1!  And before that?  Review!  And before that?  if and switch statements.
Creating your first C++ program
224 3/30/98 CSE 143 Recursion [Sections 6.1, ]
Testing and Debugging Version 1.0. All kinds of things can go wrong when you are developing a program. The compiler discovers syntax errors in your code.
ENEE150 – 0202 ANDREW GOFFIN Introduction to ENEE150.
More on Logic Today we look at the for loop and then put all of this together to look at some more complex forms of logic that a program will need The.
Advanced Work with Embedded and Summative Assessment Dr. Steve Broskoske Misericordia University EDU 533 Computer-based Education.
Introduction to Loops For Loops. Motivation for Using Loops So far, everything we’ve done in MATLAB, you could probably do by hand: Mathematical operations.
Discussion 2: Intro to Project 1: Chess Submit Project 1 under # 11!
ENEE150: Discussion 1 Section 0104/0105 Please Sit Down at a Computer and Login!
CSCI 156: Lab 11 Paging. Our Simple Architecture Logical memory space for a process consists of 16 pages of 4k bytes each. Your program thinks it has.
Ajax Dice Game Part 1. We saw that we could use the jQuery load() function, to dynamically load a piece of an html document into another html document.
1 Project 7: Looping. Project 7 For this project you will produce two Java programs. The requirements for each program will be described separately on.
More on Logic Today we look at the for loop and then put all of this together to look at some more complex forms of logic that a program will need The.
Today… Modularity, or Writing Functions. Winter 2016CISC101 - Prof. McLeod1.
Functions. What is a Function?  We have already used a few functions. Can you give some examples?  Some functions take a comma-separated list of arguments.
ENEE150 Discussion 01 Section 0101 Adam Wang.
Lesson #5 Repetition and Loops.
EECS 183.
ENEE150 Discussion 04 Section 0101 Adam Wang.
Winter 2009 Tutorial #6 Arrays Part 2, Structures, Debugger
Repetition Structures
Lesson #5 Repetition and Loops.
Testing and Debugging.
ENEE150 Discussion 09 Section 0101 Adam Wang.
Algorithms Problem: Write pseudocode for a program that keeps asking the user to input integers until the user enters zero, and then determines and outputs.
CS1371 Introduction to Computing for Engineers
ENEE150 Discussion 06 Section 0101 Adam Wang.
Chapter 5: Looping Starting Out with C++ Early Objects Seventh Edition
ENEE150 Discussion 13 Section 0101 Adam Wang.
Scripts & Functions Scripts and functions are contained in .m-files
Engineering Innovation Center
Sentinel logic, flags, break Taken from notes by Dr. Neil Moore
Functions Inputs Output
Arrays & Functions Lesson xx
Conditions and Ifs BIS1523 – Lecture 8.
Sentinel logic, flags, break Taken from notes by Dr. Neil Moore
Lesson #5 Repetition and Loops.
Lesson Objectives Aims You should be able to:
Alice Variables Pepper.
Computer Science 1 Dice Project.
Functions In Matlab.
We’re moving on to more recap from other programming languages
Repetition Structures
Go to =>
Homework Any Questions?.
Objectives You should be able to describe: The while Statement
Functions continued.
The Generic List<> Collection class
Lesson #5 Repetition and Loops.
Computer Science 1 Dice Project.
More Loops Topics Relational Operators Logical Operators for Loops.
Computer Science 1 4/4/2016.
CSCE 206 Lab Structured Programming in C
Incremental Programming
Software Development Techniques
GCSE Computing.
Presentation transcript:

ENEE150 Discussion 02 Section 0101 Adam Wang

Overview More unix commands/logistics Functional Decomposition Project 1

X11 Forwarding Allows you to run GUI interfaces from glue Mac: Xquartz https://www.xquartz.org Open server and Ssh –X user@linux.glue.umd.edu Windows: Use mobaxterm Otherwise, download xming & run with putty Enable x11 forwarding in putty client Use ‘&’ to run application in the background Ex: emacs board.c &

Cat/less/more Displays contents of file “cat file1” or “less file1” Play around to see the differences in output

tar Bundle all your files into one zip Easier to submit one file Command is “tar –cvf bundle.tar file1 file2 file3” To unzip use “tar –xvf bundle.tar”

Wget Download files online into glue Command example: “wget ece.umd.edu/class/enee150.F2017/assignments/pr1/board.c”

Functional decomposition Making functions is important because Code reuse Code management Abstraction Testing next week probably

Project 1: backgammon Due September 21st (two weeks)

Rules Move all your pieces into your quadrant, then move them off the board Roll 2 dice to see which moves you can make Can only move to empty spots, spots with your pieces, or spots with one opponent piece

The bar If you land on a point with one opponent piece it gets kicked to the bar Opponent has to move pieces off the bar before they can move their other pieces Piece starts off back at the beginning of their respective sides

Objective Test Vectors will be given out at a later time Backgammon.c: controls the game of backgammon Check.c: The 7 functions outlined in the description Basically just how to check whether a move is valid Board.c: Prints and maintains the board Roll_die.c: simulates rolling a dice

Do/Don’t Don’t worry about whether the game is actually over; just quit when they type “0 0” Don’t worry about extra moves if they roll a double Don’t have to check whether they can’t make any moves (in this case just quit the entire game) DO check whether they need to make a bar move at the beginning using the_bar_white and the_bar_red DO check whether they can actually make an entry move using num_red and num_white

board.c Copy your print_board() function into here You also need to display the # of pieces on the bar as well now Simple printf statement using the_bar_white and the_bar_red global variables given

roll_die.c Create a file called roll_die.c and copy & paste the code in the pdf here Add “int roll_die();” to backgammon.h This simulates a random dice (and we use this for the test vectors as well) If you wanted you could change the roll_die function to return something not random for testing purposes

Check.c

check.c Create a new C file called check.c for your 7 functions No need for a main function – will be included in another file Make sure to type #include “backgammon.h” at the top To compile/link everything, just add all the files together i.e. “gcc backgammon.c check.c board.c roll_die.c” Won’t be able to compile everything until all the files are handed out

Code reuse is very important Many of the functions can make use of the other functions to work **Start from the last function listed and work up** Utilize the macros given Compiler goes through and replaces macro names with their values Return VALID_MOVE / return INVALID_MOVE BOARD_SIZE WHITE/RED for mover Makes code more readable/understandable

Int check_board_bounds (int index) Make sure the index is within the bounds of the array Shouldn’t be more than a couple lines of code

Int check_die(int mover, int from, int to, int die) Check that mover is moving exactly the number of spaces on the dice Remember: white can only move up in index, and red can only move down

Int check_basic_move(int mover, int from, int to, int die) Checks validity of a basic piece move Try to start using the other functions to help you here Besides the basic checks, return invalid if there’s no piece at the “from” index, or there are more than one opponent pieces at “to”

int check_bear_off_move(int mover, int from, int to, int die) Checks for bear off moves, i.e. the player moves the pieces off the board Valid as long as our dice roll is high enough to get off the board Don’t forget to check whether there’s a piece to move in the first place

Int check_entry_move(int mover, int from, int to, int die) Check whether is a valid entry move (i.e. moving a piece off the bar) Just have to check whether there’s too many opponent pieces on the space you’re trying to enter on (among other basic checks)

Int check_move(int mover, int from, int to, int die) Put it all together to check validity of a player move ALWAYS think about whether you could use a function to implement something Be sure to check: Whether player has to make an entry move from the bar Whether player is trying to make a bear off move You MUST check whether all their pieces are in the home quadrant Use the num_white/num_red variables Otherwise it’s just a regular move to check

backgammon.c

backgammon.c Create a new program file for the main game This will contain your main function (and other helper functions) Use the print_board, roll_die, and check_move functions from your other files here Basically a while loop that switches between the players, and makes the moves/updates the boards until game ends **Up to you how to implement this, but it is recommended to break it up into 3 functions:** Turn Make_move Move_piece

Void move_piece (int mover, int from, int to) Only handles moving a piece Don’t worry about checking whether it’s a valid move here For a normal move, remove a piece from the_board_white/the_board_red[from] and increment the_board_white/the_board_red[to] If moving from the bar, you must decrement the_bar_white/the_bar_red If moving off the board, you must decrement num_white/num_red If they land on an opponent piece, be sure to move it to the bar

Int make_move (int mover, int die1, int die2) Use scanf to process user’s moves, check if valid, then move_piece Use a loop to keep asking user until they enter a valid move Use check_move to check whether valid/invalid! Just print “invalid move” if invalid and ask again If user inputs “0 0” call exit(0); to terminate the program Check which dice causes the valid move, and use it for move_piece If both dice are valid, use the SMALLER dice! Once you call move_piece and print_board, return the other dice

void turn (int mover) Roll 2 dice & print results Call make_move twice (for both dice) Make_move returns the other dice not used, so use that for both dice parameters in your second make_move function

Int main() Have a variable that maintains the mover (WHITE/RED) Start by printing the board Use a while loop to run turn() and to flip between RED and WHITE This loop can run forever; code will terminate from inside make_move()

Backgammon.h Put all the functions you used from backgammon.c, roll_die.c, and board.c Use the same format as the required functions already there

PLEASE try to use good style Comment when you can (loops, big blocks of code, functions) We will go over testing once those are handed out too This will be very important because output has to match EXACTLY what is expected Start AT LEAST a week before due date