Dale Roberts Department of Computer and Information Science, School of Science, IUPUI Dale Roberts, Lecturer Computer Science, IUPUI

Slides:



Advertisements
Similar presentations
Chapter 3: Beginning Problem Solving Concepts for the Computer Programming Computer Programming Skills /1436 Department of Computer Science.
Advertisements

Lecture 2 Introduction to C Programming
Introduction to C Programming
1 Chapter 2 Introduction to Java Applications Introduction Java application programming Display ____________________ Obtain information from the.
Principles of Programming Fundamental of C Programming Language and Basic Input/Output Function 1.
Bellevue University CIS 205: Introduction to Programming Using C++ Lecture 3: Primitive Data Types.
Structure of a C program
1 Chapter 4 Language Fundamentals. 2 Identifiers Program parts such as packages, classes, and class members have names, which are formally known as identifiers.
C Programming Language 4 Developed in 1972 by Dennis Ritchie at AT&T Bell Laboratories 4 Used to rewrite the UNIX operating system 4 Widely used on UNIX.
CMT Programming Software Applications
1 Lecture 2  Input-Process-Output  The Hello-world program  A Feet-to-inches program  Variables, expressions, assignments & initialization  printf()
1 Key Concepts:  Why C?  Life Cycle Of a C program,  What is a computer program?  A program statement?  Basic parts of a C program,  Printf() function?
Introduction to C Programming Overview of C Hello World program Unix environment C programming basics.
CS150 Introduction to Computer Science 1
Introduction to C Programming
1 Agenda Variables (Review) Example Input / Output Arithmetic Operations Casting Char as a Number (if time allow)
Chapter 3: Introduction to C Programming Language C development environment A simple program example Characters and tokens Structure of a C program –comment.
Basic Elements of C++ Chapter 2.
Program A computer program (also software, or just a program) is a sequence of instructions written in a sequence to perform a specified task with a computer.
Computer Science 210 Computer Organization Introduction to C.
Chapter 2: C Fundamentals Dr. Ameer Ali. Overview C Character set Identifiers and Keywords Data Types Constants Variables and Arrays Declarations Expressions.
C Programming Lecture 3. The Three Stages of Compiling a Program b The preprocessor is invoked The source code is modified b The compiler itself is invoked.
Input & Output: Console
Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley C H A P T E R 2 Input, Processing, and Output.
C Programming Lecture 4 : Variables , Data Types
C programming for Engineers Lcc compiler – a free C compiler available on the web. Some instructions.
C Tokens Identifiers Keywords Constants Operators Special symbols.
1 Do you have a CS account? Primitive types –“ building blocks ” for more complicated types Java is strongly typed –All variables in a Java program must.
Sales person receive RM200/week plus 9% of their gross sales for that week. Write an algorithms to calculate the sales person’s earning from the input.
Chapter 3 Processing and Interactive Input. 2 Assignment  The general syntax for an assignment statement is variable = operand; The operand to the right.
Computer Science 101 Introduction to Programming.
Data & Data Types & Simple Math Operation 1 Data and Data Type Standard I/O Simple Math operation.
CMSC 104, Version 9/011 Introduction to C Topics Compilation Using the gcc Compiler The Anatomy of a C Program 104 C Programming Standards and Indentation.
Week 1 Algorithmization and Programming Languages.
Copyright © 2012 Pearson Education, Inc. Chapter 2: Introduction to C++
Introduction to C Programming Chapter 2 : Data Input, Processing and Output.
 Pearson Education, Inc. All rights reserved Introduction to Java Applications.
Chapter 3: Formatted Input/Output Copyright © 2008 W. W. Norton & Company. All rights reserved. 1 Chapter 3 Formatted Input/Output.
BASICS CONCEPTS OF ‘C’.  C Character Set C Character Set  Tokens in C Tokens in C  Constants Constants  Variables Variables  Global Variables Global.
CSCI 3133 Programming with C Instructor: Bindra Shrestha University of Houston – Clear Lake.
Chapter 4 Literals, Variables and Constants. #Page2 4.1 Literals Any numeric literal starting with 0x specifies that the following is a hexadecimal value.
A Simple Java Program //This program prints Welcome to Java! public class Welcome { public static void main(String[] args) { public static void main(String[]
C++ Programming Lecture 3 C++ Basics – Part I The Hashemite University Computer Engineering Department (Adapted from the textbook slides)
Programming Fundamentals. Overview of Previous Lecture Phases of C++ Environment Program statement Vs Preprocessor directive Whitespaces Comments.
Programming Fundamentals
C++ for Engineers and Scientists Second Edition
Tokens in C  Keywords  These are reserved words of the C language. For example int, float, if, else, for, while etc.  Identifiers  An Identifier is.
0 Chap.2. Types, Operators, and Expressions 2.1Variable Names 2.2Data Types and Sizes 2.3Constants 2.4Declarations 2.5Arithmetic Operators 2.6Relational.
Characters and Strings
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 2 September 3, 2009.
Dale Roberts Department of Computer and Information Science, School of Science, IUPUI Dale Roberts, Lecturer Computer Science, IUPUI
Dale Roberts Department of Computer and Information Science, School of Science, IUPUI Dale Roberts, Lecturer Computer Science, IUPUI
Chapter 3: Formatted Input/Output 1 Chapter 3 Formatted Input/Output.
Chapter 1 slides1 What is C? A high-level language that is extremely useful for engineering computations. A computer language that has endured for almost.
Lecture 3: More Java Basics Michael Hsu CSULA. Recall From Lecture Two  Write a basic program in Java  The process of writing, compiling, and running.
1 Lecture 2 - Introduction to C Programming Outline 2.1Introduction 2.2A Simple C Program: Printing a Line of Text 2.3Another Simple C Program: Adding.
1 ENERGY 211 / CME 211 Lecture 3 September 26, 2008.
Computer Science 210 Computer Organization
Chapter 2: Introduction to C++
Tokens in C Keywords Identifiers Constants
A First C Program (mixing datatypes)
A First C Program (mixing datatypes)
Chapter 2: Introduction to C++
Computer Science 210 Computer Organization
Variables In programming, we often need to have places to store data. These receptacles are called variables. They are called that because they can change.
CS111 Computer Programming
Lectures on Numerical Methods
A First C Program (mixing datatypes)
C++ Programming Lecture 3 C++ Basics – Part I
Introduction to C Programming
Presentation transcript:

Dale Roberts Department of Computer and Information Science, School of Science, IUPUI Dale Roberts, Lecturer Computer Science, IUPUI CSCI 230 A First C Program

Dale Roberts Try Your First C Program #include /* I/O header file */ main(){ printf(“Hello world ”); printf(“Welcome to CSCI230\n“); printf(“I am John Smith\n”); printf(“I am John Smith\n”);} A C program contains one or more functions main() is the function name of your main (root) program { }: braces (left & right) to construct a block containing the statements of a function Every statement must end with a ; \ is called an escape character \n is an example of an escape sequence which indicates newline Other escape sequences are: \t \r \a \\ \” Exercise: Use any editor to type and then save your first program as main.c % gcc main.c % a.out and observe its result. header file – contains I/O routines pre-processor directive one statement main must be present in each C program statement terminator Indicates a program building block called function comment

Dale Roberts Identifiers Variable identifiers Begin with a letter or underscore: A-Z, a-z, _ The rest of the name can be letters, underscore, or digits Guarantee that east least the first 8 characters are significant (those come after the 8th character will be ignored) while most of C compiler allows 32 significant characters. Example : _abcABCTimetime _a1abcdefgh abcdefghi (may be the same as abcdefgh ) Case sensitive Keywords: reserved names (lexical tokens) autodoubleifstaticbreakelseintstruct caseentrylongswitchcharexternregister typedeffloatreturnuniondogosizeofcontinue …

Dale Roberts Fundamental Data Type Four Data Types Four Data Types (assume 2’s complement, byte machine) Data TypeAbbreviationSize (byte) Range char ~ 127 unsigned char 10 ~ 255 int 2 or ~ or ~ unsigned intunsigned 2 or 40 ~ or 0 ~ short intshort ~ unsigned short intunsigned short 20 ~ long intlong ~ unsigned long intunsigned long 40 ~ float4 double8 Note:2 7 = 128, 2 15 =32768, 2 31 = Complex and double complex are not available

Dale Roberts Variable Declarations type v 1,v 2,v 3, …, v n Example: int i; int j; float k; char c; short int x; long int y; unsigned int z; int a1, a2, a3, a4, a5;

Dale Roberts Numeric, Char, String Literals Literal Numeric literal fixed-point octal O32 (= 24 D ) (covered later) hexadecimal OxFE or Oxfe (=254 D ) (covered later) decimal int 32 long (explicit) 32L or 32l an ordinary integer literal that is too long to fit in an int is also too long for long floating-point No single precision is used; always use double for literal Example: e E

Dale Roberts Character literal (covered later) American Standard Code for Information Interchange (ASCII) Printable: single space32 ‘0’ - ‘9’ ‘A’ - ‘Z’ ‘a’ - ‘z’ Nonprintable and special meaning chars ‘\n’ new line10 ‘\t’ tab 9 ‘\\’ back slash 9 ‘\’’ single quote39 ‘\0’ null 0 ‘\b’ back space 8 ‘\f’ formfeed12 ’\r’ carriage return13 ‘\”’ double quote34 ‘\ddd’ arbitrary bit pattern using 1-3 octal digits ‘\Xdd’ for Hexadecimal mode ‘\017’ or ‘\17’ Shift-Ins, ^O ‘\04’ or ‘\4’ or ‘\004’ EOT (^D) ‘\033’ or ‘\X1B’ Numeric, Char, String Literals

Dale Roberts String Literal will be covered in Array section String is a array of chars but ended by ‘\0’ String literal is allocated in a continuous memory space of Data Segment, so it can not be rewritten Example: “ ABCD ”... A B C D ‘\0’ Ans: 13+1 = 14 bytes Question: “I am a string” takes ? Bytes 4 chars but takes 5 byte spaces in memory Numeric, Char, String Literals

Dale Roberts Character literals & ASCII codes: char x; x=‘a’;/* x = 97*/ Notes: –‘a’ and “a” are different; why? ‘a’ is the literal 97 “a” is an array of character literals, { ‘a’, ‘\0’} or {97, 0} –“a” + “b” +”c” is invalid but ‘a’+’b’+’c’ = ? (hint: ‘a’ = 97 in ASCII) –if the code used is not ASCII code, one should check out each value of character Numeric, Char, String Literals 1 38 ‘a’ + ‘b’ + ‘c’ = = 294 = in the memory

Dale Roberts Initialization If a variable is not initialized, the value of variable may be either 0 or garbage depending on the storage class of the variable. int i=5; float x=1.23; char c=‘A’; int i=1, j,k=5; char c1 = ‘A’, c2 = 97; float x=1.23, y=0.1;

Dale Roberts Memory Concepts Each variable has a name, address, type, and value 1) 1) int x; 2) 2) scanf(“%d”, &x); 3) 3) user inputs 10 4) 4) x = 200; After the execution of (1)x After the execution of (2)x After the execution of (3)x After the execution of (4)x Previous value of x was overwritten

Dale Roberts Sample Problem Write a program to take two numbers as input data and print their sum, their difference, their product and their quotient. Problem Inputs float x, y;/* two items */ problem Output float sum;/* sum of x and y */ float difference;/* difference of x and y */ float product;/* product of x and y */ float quotient;/* quotient of x divided by y */ Pseudo Code: Declare variables of x and y; Prompt user to input the value of x and y; Print the sum of x and y; Print the difference of x and y; Print the product of x and y; If y not equal to zero, print the quotient of x divided by y

Dale Roberts Example Program #include int main(void) { float x,y; float sum; printf(“Enter the value of x:”); scanf(“%f”, &x); printf(“\nEnter the value of y:”); scanf(“%f”, &y); sum = x + y; printf(“\nthe sum of x and y is:%f”,sum); printf(“\nthe sum of x and y is:%f”,x+y); printf(“\nthe difference of x and y is:%f”,x-y); printf(“\nthe product of x and y is:%f”,x*y); if (y != 0) printf(“\nthe quotient of x divided by y is:%f”,x/y); else printf(“\nquotient of x divided by y does not exist!\n”); return(0); } function name list of argument along with their types return value and its type Body inequality operator

Dale Roberts Data Type Conversion Rule #1 char, short  int float  double Rule #2 (double ← long ← unsigned ← int) If either operand is double, the other is converted to double, and the result is double Otherwise, if either operand is long, the other is converted to long, and the result is long Otherwise, if either operand is unsigned, the other is converted to unsigned, and the result is unsigned Otherwise, the operand must be int

Dale Roberts Examples Example: c: char, u: unsigned, i: int, d: double, f:float, s: short,l: long, Expression Final Data TypeExplanation c – s / i int short  int, int/int, char  int, int-int u * 3 – i unsigned int(3)  unsigned, unsigned*unsigned=unsigned, int  unsigned, unsigned-unsigned=unsigned u * 3.0 – i double unsigned  double, double*double, int  double, double-double=double c + i int char  int c double char  int (rule 1), int  double(rule 2) 3 * s * l long short  int, int*int, int  long, long*long

Dale Roberts Data Type Conversion (cont.) Note: Conversion of int to long preserves sign, so does short Var = expr f = d; /* round off */ i = f; /* truncates fractions part, if the number is too big to fit, the result is undetermined */ i = l; s = i; and c = i; /* may eliminate high order bits */

Dale Roberts If a specific type is required, the following syntax may be used, called cast operator. (type) expr Example : float f=2.5; x = (int)f + 1; /* the result is 3, Q: will f value be changed? */ Unsigned int to int: there is not actual conversion between int and unsigned int. Example : (Assuming 2’s complement machine and int is 2 bytes long) unsigned i = 65535; int j; j = i; /* j will be –1 */ j = -2; unsigned i = 1 + j; /* i= */

Dale Roberts Demo 1. Logging onto unix remotely 2. Simple unix commands 3. Editing under unix 4. Compiling 5. Running 6. Editing under Windows 7. Separating editing and compiling under unix 8. How to find an error