nullnull C++程序设计
谭浩强编著
清华大学出版社
课件
超市陈列培训课件免费下载搭石ppt课件免费下载公安保密教育课件下载病媒生物防治课件 可下载高中数学必修四课件打包下载
制作:福建师范大学 Jerryhuangnull第一章C++概述 C++语言发展历史 自从1946年第一台电子数字计算机ENIAC问世以来,随着计算机应用领域的不断扩大,促进了计算机技术的高速发展,尤其是近年来计算机的硬件和软件都是日新月异。作为应用计算机的一种工具—程序设计语言,得到不断的充实和完善。每年都有新的程序设计语言问世,老的程序设计语言不断地更新换代。 null20世纪60年代,Martin Richards为计算机软件人员在开发系统软件时,作为记述语言使用而开发了BCPL语言(Basic Combined Programming Language)。1970年,Ken Thompson在继承BCPL语言的许多优点的基础上发明了实用的B语言。到了1972年,贝尔实验室的Dennis Ritchie和Brian kernighan在B语言的基础上,作了进一步的充实和完善,设计出了C语言。当时,设计C语言是为了编写UNIX操作系统的。以后,C语言经过多次改进,并开始流行。C++是在C语言的基础上发展和完善的,而C是吸收了其它语言的优点逐步成为实用性很强的语言。nullC语言的主要特点是:
1、C语言是一种结构化的程序设计语言,语言本身简洁、使用灵活方便。既适用于设计和编写大的系统程序,又适用于编写小的控制程序,也适用科学计算。2、它既有高级语言的特点,又具有汇编语言的特点。运算符丰富,除了提供对数据的算术逻辑运算外,还提供了二进制的位运算。并且也提供了灵活的数据结构。用C语言编写的程序表述灵活方便,功能强大。用C语言开发的程序,其结构性好,目标程序质量高,程序执行效率高。null3、程序的可移植性好。用C语言在某一种型号的计算机上开发的程序,基本上可以不作修改,而直接移植到其它型号和不同档次的计算机上运行。4、程序的语法结构不够严密,程序设计的自由度大。这对于比较精通C语言的程序设计者来说,可以设计出高质量的非常通用的程序。但对于初学者来说,要能比较熟练运用C语言来编写程序,并不是一件容易的事情。与其它高级语言相比而言,调试程序比较困难。往往是编好程序输入计算机后,编译时容易通过,而在执行时还会出错。但只要对C语言的语法规则真正领会,编写程序及调试程序还是比较容易掌握的。null随着C语言应用的推广,C语言存在的一些缺陷或不足也开始流露出来,并受到大家的关注。如:C语言对数据类型检查的机制比较弱;缺少支持代码重用的结构;随着软件
工程
路基工程安全技术交底工程项目施工成本控制工程量增项单年度零星工程技术标正投影法基本原理
规模的扩大,难以适应开发特大型的程度等等。null为了克服C语言本身存在的缺点,并保持C语言简洁、高效,与汇编语言接近的特点,1980年,贝尔实验室的Bjarne Stroustrup博士及其同事对C语言进行了改进和扩充,并把Simula 67中类的概念引入到C中。并在1983年由Rick Maseitti提议正式命名为C++(C Plus Plus)。后来,又把运算符的重载、引用、虚函数等功能加入到C++中,使C++的功能日趋完善。
当前用得较为广泛的C++有:VC++ (Visual C Plus Plus)、 BC++(Borland C Plus Plus)、AT&T C++等。null简单的C++程序介绍高级语言编译过程源程序
(文本文件)
*.CPP目标文件
(二进制文件)
*.OBJ可执行文件
(二进制文件)
*.EXE库文件
(各种函数)在Vitual C++系统中,可直接从源程序编译连接至可执行程序,但依然要生成*.OBJ及*.EXE这两个文件。F7compilelinknull一个简单的C++程序#include
void main(void )
{ cout<<“I am a student.\n”; //输出字符串
}主函数函数体开始函数体结束输出流,在屏幕上打印引号内的字符串分号,一条完整语句的结束符本程序编译执行后,在DOS屏幕上打印出
I am a student.包含文件注释或说明null编译过程:
1)启动Visual C++,选择“文件”菜单中的“新建”命令,选择“文件”标签中的“C++ Source File”选项。
2)选择源程序存放的目录和输入源程序名,单击“确定”。
3)在编辑器中编写源程序。
4)单击F7或“编译”中的“重建全部”编译源程序,若编译通过,单击“执行”,在DOS屏上看结果,任按一键返回编辑器。null启动VC++编译系统nullVC++编译系统界面单击“File”菜单中“New”命令null选择“Files”选项卡选择C++源文件命令输入文件名输入文件存放位置单击选择驱动器选择驱动器或目录nullC++源文件编辑界面输入C++源代码null可以将此源代码另起文件名存盘null选择编译命令,将源文件.cpp生成.obj文件null如果编译出错,会出现提示信息,指出错误的位置及种类错误所在行错误的原因null双击错误所在行光标移到该行null生成可执行文件通过后单击该命令运行程序null运行结果显示在DOS屏上注意:不可以在软盘上运行程序!应该把保存在软盘中的源文件拷贝到硬盘的目录中再运行!null源程序所在目录未编译前,只有一个源程序null编译运行后,出现众多附加文件同时,产生一个子目录DebugnullDebug目录中,有obj和EXE文件null#include
void main(void)
{
cout << “i=”; //显示提示符
int i; //说明变量i
cin >>i; //从键盘上输入变量i的值
cout << “i的值为:” <
#define PRICE 30 //常量,在程序中保持不变
void main(void)
{ int num, total; //定义变量,在内存中开辟区间
num=10; //变量赋值,10为常量
total=num*PRICE;
cout<<“total=“<
方法
快递客服问题件处理详细方法山木方法pdf计算方法pdf华与华方法下载八字理论方法下载
:
变量名、数组名、函数名…称为标识符。
标识符只能由字母、数字、下划线这三种字符组成,且第一个字符必须为字母或下划线,长度不大于247个字符,大小写不通用。(关键字不能作为标识符)。
关键字即是VC++的语法要求中使用的字。
如 int if while 等。
正确的标识符:INT, sum , de12, SUM等。变量必须使用前定义,以分配空间。
举例说明nullabc English 2xy x-y if Else b(3) ‘def’ Chine_bb b3y AbsFloat float一般变量都是用匈牙利命名法命名的。int nCount;
char chChoice;null整型数据整型常量:
常量是根据其表面形式来判定,整型量即是没有小数点的整数,范围:-231~(231-1) ,有三种形式:
1)十进制(默认方式) 43 1345 87654
2)八进制 以0开头 043, 056, 011
3)十六进制 以0x开头 0x12 0xa3 0x34 0xdf(举例说明)null#include
void main(void)
{
int int10,int8,int16; //定义3个整型变量
int10=10; //默认为十进制
int8=010; //八进制
int16=0x10; //十六进制
cout<<"int10="<
void main()
{ unsigned short a;
short int b= -1;
a=b;
cout<<"a="<
void main(void)
{ float a, b;
double c, d;
a=0.01;
b=3.45678e-2;
c=3.45678e-2;
d=9.7654e-5;
cout<<"a="<
void main(void)
{
char a,b;
a=‘A’; //输入ASCII码
b=65; //输入十进制数
cout<<"a="<
格式
pdf格式笔记格式下载页码格式下载公文格式下载简报格式下载
,则再加一个\输出 c:\tc\tc 表示为cout<<"c:\\tc\\tc";可以用转义字符表示任一一个ASCII字符 ‘\ddd’ (八进制) ‘\xhh‘ (十六进制)
'\101' '\x41' '\x61' '\141' null#include
void main(void)
{
char c1,c2,c3,c4;
char n1,n2;
c1='a'; //字符常量
c2=97; //十进制
c3='\x61'; //转义字符
c4=0141; //八进制
cout<<"c1="<
#define PI 3.14156
#define S "China"
void main(void)
{
const float pi=3.14156; //变量作为常量使用
cout<<"PI="< <= >= = = !=
= = 与 =
a=5; 赋值运算 a= =5;判断是否相等< > <= >= 的优先级大于= = !=3. 算术运算符的优先级大于关系运算符的优先级null关系表达式:用关系运算符将表达式连接起来称为关系表达式。其值非真即假。在C++语言中,用非0代表真,用0表示假。关系表达式的结果只有两个,真为1,假为0。 a=2 b=3 c=4
a>2
a>b+c
a= =2 a= ='a'
a>'a'
b=a= =2'a'>'A'
b= ='a'+1
c-a= =a001001101null 逻辑运算符 运算符 与&& 或 || 非! A B 结果
0 0 0
0 1 0
1 0 0
1 1 1
有0出0,全1出1
A,B同时成立&&A B 结果
0 0 0
0 1 1
1 0 1
1 1 1
有1出1,全0出0
A或B有一个成立| |A 结果
0 1
1 0
有0出1,
有1出0!null江苏籍的男生
江苏籍的学生和所有男生
非江苏籍的学生江苏籍&&男生例如:两个条件:江苏籍 男生江苏籍||男生!江苏籍注意:
1.优先级:!&&| |
!算术关系逻辑赋值逗号null3.不可写为 13 && 2 || 8<4-!04.当前面的表达式可以得出整个表达式的结果时,不必再求后面的表达式。a&&b&&c 当a为0时,表达式为0,不必求b与c。a||b||c 当a为1时,表达式为1,不必求b与c。nullx=4 y=5
i= ++x= =5 || ++y= =6x=5 y=5 i=1i= x++= =5&& y++= =6x=5 y=5 i=0判断某年是否为闰年
1)能被400整除
2)能被4整除,不能被100整除 (2200年不是)year%400= =0year%4= =0&& year%100!=0(year%400= =0) || (year%4= =0&&year%100!=0)null当c=4时,以下的值各多少?
(c=1)&&(c=3)&&(c=5)
(c= =1)||(c= =2) || (c= =5)
(c!=2) && (c!=4) &&(c>=1)&&(c<=5)100nullsizeof()运算符 sizeof()运算符是一个单目运算符,用于计算某一个操作数类型的字节数。其格式为:
sizeof(<类型>)sizeof(int) //其值为4
sizeof(float) //其值为4
sizeof(double) //其值为8
sizeof(char) //其值为1null逗号运算符和逗号表达式表达式1,表达式2,表达式3,…,表达式n
顺序求解,结果为最后一个表达式的值,并且优先级最低。a=(3+4, 5*6, 2+1); a=3a=3*3, a+6, a+7;16(a=3*5, a*4), a+520a=9a=15null下列语句中表达式中i, j的值各为多少
1、int i=0, j=0; 2、 int i=0, j=1;
i=3, (j++)+i ; i+=j*=3;
3、int i=1, j=0; 4、int i=1, j=1;
j=i=((i=3)*2); i+=j+=2;i=3,j=1i=3,j=3i=6,j=6i=4,j=3null各类数值型数据间的混合运算整型、实型、字符型数据间可以混合运算。10+'a'+1.5-87.65*'b'在进行运算时,不同类型的数据要先转换成同一类型的数据再进行运算。
转换规则如下:null第三章 简单的输入输出null 输入语句:cin程序在执行期间,接收外部信息的操作称为程序的输入;而把程序向外部发送信息的操作称为程序的输出。在C++中没有专门的输入输出语句,所有输入输出是通过输入输出流来实现的。 null要使用C++提供的输入输出时,必须在程序的开头增加一行:
#include
即包含输入输出流的头文件“iostream.h”。有关包含文件的作用,在编译预处理部分(第五章)作详细介绍。null 输入十进制整数和实数cin >> <变量名1>《 >> <变量名2> ...... 》(举例说明)int a,b;
cin>>a>>b; //程序运行至此停下,等待从键盘输入变量值键盘输入:3 5
或:3 5 均可。输入语句自动过滤空白字符。3键盘5键盘null浮点型数据同整型数据一样。float c,d;
cin>>c>>d;char ch1,ch2;
cin>>ch1>>ch2;若输入:ab 则ch1为a, ch2为b。若输入:a b 则ch1为a, ch2为b。字符型变量过滤空白字符。cin格式过滤空白字符nullfloat a;
int i1,i2;
char ch1,ch2;
cin>>i1>>a>>i2>>ch1>>ch2;输入:34 5.678 1a bi2:1在缺省的情况下,cin自动跳过输入的空格,换言之,cin不能将输入的空格赋给字符型变量,同样地,回车键也是作为输入字符之间的分隔符,也不能将输入的回车键字符赋给字符型变量。 a:5.578i1:34ch1:ach2:bnull若要把从键盘上输入的每一个字符,包括空格和回车键都作为一个输入字符赋给字符型变量时,必须使用函数cin.get()。其格式为:
cin.get(<字符型变量>);cin.get()从输入行中取出一个字符,并将它赋给字符型变量。这个语句一次只能从输入行中提取一个字符。char c1;
cin.get(c1);nullchar ch1,ch2,ch3;
cin.get(ch1);
cin.get(ch2);
cin.get(ch3);输入:A B则:ch1:A并且在输入缓冲区中保留回车键。 ch2:空格ch3:B空格的ASCII码为32ch2null输入十六进制或八进制数据 在缺省的情况下,系统约定输入的整型数是十进制数据。当要求按八进制或十六进制输入数据时,在cin中必须指明相应的数据类型:hex为十六进制;oct为八进制;dec为十进制。 nullint i,j,k,l;
cin>>hex>>i; //指明输入为十六进制数
cin>>oct>>j; //指明输入为八进制数
cin>>k; //输入仍为八进制数
cin>>dec>>l; //指明输入为十进制数
当执行到语句cin时,若输入的数据为:
11 11 12 12结果:i:17j:9k:10l:12null使用非十进制数输入时,要注意以下几点:
1、八进制或十六进制数的输入,只能适用于整型变量,不适用于字符型变量,实型变量。2、当在cin中指明使用的数制输入后,则所指明的数制一直有效,直到在接着的cin中指明输入时所使用的另一数制为止。如上例中,输入k的值时,仍为八进制。null3、输入数据的格式、个数和类型必须与cin中所列举的变量类型一一对应。一旦输入出错,不仅使当前的输入数据不正确,而且使得后面的提取数据也不正确。cin>>a,b; cin>>a b; cin>>ab; int a, b;cin>>a>>b; null输出数据 cout
与输入cin对应的输出是cout输出流。当要输出一个表达式的值时,可使用cout来实现,其一般格式为:
cout << <表达式> 《<< <表达式>......》;
其中运算符“<<”称为插入运算符,它将紧跟其后的表达式的值,输出到显示器当前光标的位置。 nullint a=6;
float f1=12.4;
char s1[ ]=“abcd”;
cout<int i1=4,i2=5;
float a=3.5;
cout<<“a*i1=“<2、括号中必须给出一个表达式(值为正整数),它指明紧跟其后输出项的宽度。3、该设置仅对其后的一个输出项有效。一旦按指定的宽度输出其后的输出项后,又回到原来的缺省输出方式。 null输出八、十六进制数和科学表示法的实数对于整型数据可指定以十六进制或八进制输出,而对于实型数据可指定以科学表示法形式输出。例如,设有如下一个程序:
#include
void main(void)
{ float x=3.14,y=100;
cout.setf(ios::scientific,ios::floatfield);
//表明浮点数用科学表示法输出
cout << x<<’\t’;
cout <b)
cout<b)
cout<b)
{ a=1;
b=0;
}
else
{ a=0;
b=1;
} nullif (i >j) i++;
if (i>j); i++;if 总是与它上面最近的 else 配对,如要改变,用复合语句{ }。
注意书写格式,相互配对的语句要对齐。null例:输入两个实数,按代数值由小到大次序输出这两个数。
void main( void )
{ float a,b,t; //定义变量
cout<<“ Input 2 Real Number:\n";//在屏幕上的提示信息
cin>>a>>b; //给变量赋值 a:7, b:3
if(a>b)
{ t=a; a=b; b=t; }//交换数据,用中间变量
cout<b?a:b ; // 求a, b中的大者
当 a=2 b=1 a>b为真,表达式的值等于a, max值为2
当 a=1 b=2 a>b为假,表达式的值等于b, max值为2注意:
条件运算符的优先级比赋值运算符高
x=(x=3) ? x+2 : x-3
2. 结合方向自左至右 a>b?a:c>d?c:d
3. 三个表达式的类型可不同 z=a>b?'A':a+bx=5nullx=9, y=6, z=5;
x=((x+y)%z>=x%z+y%z)?1:0;
cout<<"x= "<y?x++:y++)<y?x++:y++<=y&&y= =x)?1:0<=y&&y>=x<
题
快递公司问题件快递公司问题件货款处理关于圆的周长面积重点题型关于解方程组的题及答案关于南海问题
中常常需要用到多分支的选择。如,成绩分为A(100~85)、B(84~70)、C(69~60)、D(60以下)等。nullcin.get(grade);
if(grade= =‘A’)
cout<<“100~85\n”;
else if (grade= =‘B’)
cout<<“84~70\n”;
else if (grade= =‘C’)
cout<<“69~60\n”;
else if (grade= =‘D’)
cout<<“no pass\n”;
else
cout<<“error\n”; nullswitch(表达式)
{ case 常量表达式1:语句1
case 常量表达式2:语句2
… …
case 常量表达式n:语句n
default:语句n+1
}switch(grade)
{ case ‘A’:cout<<“100~85\n”;
case ‘B’:cout<<“84~70\n”;
case ‘C’:cout<<“69~60\n”;
case ‘D’:cout<<“no pass\n”;
default:cout<<“error\n”;
}如果grade为 ‘A’,则结果为100~85
84~70
69~60
no pass
errornull其流程为:先计算表达式的值,然后顺序地与case子句中所列出的各个常量进行比较,若表达式的值与常量中的值相等,就开始进入相应的case语句执行程序,遇到case和default也不再进行判断,直至switch语句结束。如果要使其在执行完相应的语句后中止执行下一语句,可以在语句后加break。nullswitch(grade)
{ case ‘A’:cout<<“100~85\n”; break;
case ‘B’:cout<<“84~70\n”; break;
case ‘C’:cout<<“69~60\n”; break;
case ‘D’:cout<<“no pass\n”; break;
default:cout<<“error\n”;
}null注意:
1、switch与if不同,它仅能判断一种逻辑关系,即表达式是否等于指定的常量,而 if 可以计算并判断各种表达式。2、case子句后必须为常量,常常是整型和字符型。3、default可以省略,这时,不满足条件什么也不执行。null4、case和default只起标号的作用,顺序可以颠倒,颠倒时注意后面的break语句。5、多个case语句可以共用一组程序。
case ‘A’:
case ‘B’:
case ‘C’: cout<<“pass!\n”;nullvoid main(void )
{ int i=10;
switch(i)
{ case 9: i++;
case 10: i++;
case 11: i++;
default: i++;
} cout<<“i=”<1真22真33假无nullvoid main(void)
{ int y=10;
while (y--);
cout<<“y=”<
void main()
{ char ch;
while(cin.get(ch)&&ch!='\n')
switch (ch-'2')
{ ca