1:c语言的数据结构类型:
(1)基本类型:<1>数值类型:整型(短整型 short, 长整型 long/long long, 整型 int ,无符号型 unsinged ); 浮点型 (单精度浮点型 float ,双精度浮点型 double ,长双精度浮点型 long double ).
(2)结构类型:<1>数组,<2>结构体struct ,<3>公用体union <4> 枚举类型 enum
(3)指针类型 (4) 空类型void
2:内存与变量:
(1)内存:计算机执行程序时,组成程序的指令和程序所操作的数据都必须存储在某个地方,这个地方就是机器的内存。 计算机数据存储空间的基本单位:1GB=2^10MB=2^20KB=2^30byte如以下程序展示了通过变量来访问内存数据的例子:实现将华氏温度转换成摄氏温度输出
#include<stdio.h>
int main()
{
int celsius,fahr;
scanf("%d",&fahr);
celsius=5*(fahr-32)/9;
printf("fahr=%d,celsius=%d\n",fahr,celsius);
return 0;
}
程序运行后输出结果如下:
fahr=**,celsius=**
其中上述程序中的fahr,celsius是变量名,各自对应着计算机内存单元中的一个存储单元(一个或多个字节)程序通过变量名来读取某个内存单元中的数据或者在其中存储一个新数据。
(2)变量:高级语言都能通过变量名来访问内存中的数据,用变量名来标识内存中的某个存储位置——有一个或者多个连续的字节组成,在程序中使用变量名,实际上引用的是内存中对应的某个存储位置。注意将一个值存入变量中是有破坏性的,它将替换掉该内存中原有的数值。
在c语言中,变量命名必须遵守以下规则: 《1》变量名可以由字母,数字,和下划线组成;《2》变量名不能包含除下划线以外的任何特殊字符,比如:%,#,逗号,空格等;《3》变量名必须以字母或者下划线开头;《4》变量名不能包含空白字符(空白字符有:换行符,空格,制表符);《5》c语言中的某些词(int float double 等)称为保留字,具有特殊意义,不能用作变量名;《6》c语言中区分大小写,因此变量a与变量A是两个不同的变量。
《1》给变量起一个有含义的名字可以使程序具有自文档性,增加程序的可读性;《2》由多个单词组成的变量名能增加程序的可读性;《3》给简单变量命名时,第一个字母一定要小写。
(3)整数类型:短整型short int 整型int 长整型long int 无符号短整型 unsigned short int 无符号整型 unsigned int 无符号长整型 unsigned long int
(4)变量的声明和使用:1,变量声明的格式:变量声明首先要指定变量的类型,然后说明变量的名称;2:在c语言中一行代码还可以同时声明多个变量;3,在使用变量之前一定要为其赋一个值,没有默认值并且尚未在程序中被赋值变量是未初始化的,如果试图访问未初始化的变量,可能会出现不可预知的结果;4:建议将变量声明部分和可执行语句部分,用一个空行分隔;5:不要使用未被初始化的变量,否则结果会不可控制。
(5)赋值运算:用“=”号将变量和一个表达式连接起来的式子,一般称为赋值表达式;
赋值运算具有破坏性,通过赋值运算将一个新值存入到一个内存单元中,这个值将替换掉该存储单元里原有的旧值,正常情况下,赋值运算符两端的值的数据类型相同。
3:格式化输入/输出函数
(1)格式化输出函数printf():此函数位于标准c语言库中,所以在程序开头要加上文件包含指令:
#include<stdio.h>
printf()函数的标准格式为:
printf("格式控制串“,输出参数表);
格式控制串是指定数据的输出格式,格式控制串由格式字符(包括转换说明符,标志域宽,精度)和普通字符组成,转换说明符和百分号一起使用,用来说明内存中数据的输出格式。普通字符在输出时原样输出。
输出参数表是指待输出的数据,可以是常量,变量或者其他更加复杂的表达式,也可以没有输出项。当有多个输出项时,中间用逗号隔开,输出项必须与格式字符在类型和数量上完全一样。
常用的转换字符串: %c 按字符型输出单个字符;
%d 按十进制整数输出带符号整数(正数不输出符号);
%f 按小数形式输出浮点型数据,默认输出6位小数;
输出格式中的宽度修饰符,宽度修饰符用一个十进制整数来表示输出数据的位数,插在%与转换说明符之间,其作用是控制打印数据的宽度,也称为”域宽“。
%md代表数据以十进制整数形式输出,宽度为m列,数据不足m列的左补空格,超过m列的情况下按实际位数输出;例如:
#include<stdio.h>
int main()
{
int a=10000;
printf("%10d",a);
return 0;
}
输出结果为: 10000
输出结果中数位占4位,靠右对齐,左边有6个空格
%-md则与上述的宽度相同,只是这次是左对齐;
(2)格式化输入函数scanf():scanf()从标准输入流按指定格式读取数据,然后转换为机内码存入对应内存地址。变量名前的”&“是地址运算符,作用是获取变量的地址。scanf()函数的格式:scanf(格式控制字符串,内存地址1,内存地址2,......内存地址n)
一些新的转换说明符:
(1)格式符:d,i,u,o,x:%d或%i以十进制整数符号形式转变换输入数据; %u以十进制整数无符号形式转换输入数据; %o 以八进制有符号整数形式转换输入数据;%x或%X以十六进制有符号整数形式转换输入数据。
(2)h或l前缀:读入短整数时,加前缀字母h,如%hd; 读入长整数时,加前缀字母l,如%ld;
(3)读入64位整数:如果编译器支持_int64,用格式符%164d,如果编译器支持long long,用格式符%lld。
(4)宽度:用十进制整数指定输入的宽度(即字符数)。
(5)复制抑制符号*:用以表示该输入项读入后不赋予相应的变量,即跳过该输入值。
4.浮点类型
以华氏温度转换成摄氏温度的小程序为例:
#include<stdio.h>
int main()
{
double celsius fahr;
scanf("%lf",&fahr);
celsius=5*(fahr-32)/9;
printf("fahr=%f,celsius=%f\n",fahr,celsius);
return 0;
}
(1)浮点类型:单精度浮点型;float 有效位数6位 所需内存字节4 取值范围(+/-)3.4E38
双精度浮点型: double 有效位数15 所需内存字节8 取值范围(+/-)1.7E308
(2)浮点数据的输出:转换字符串%f,格式转换符f用于浮点数据的输出格式限定;转换字符串%m.nf,m表示输出宽度,n表示精度,指定小数点后显示的数字的个数。
(3)浮点数据的输入或输出这里不做讲解;
(4)常量: 字面常量:字面常量是指在源代码中直接输入的值,分为整型常量,浮点常量,字符常量,字符串常量;
宏常量:宏常量是为使程序易于阅读和修改,给程序中经常使用的常量定义一个有一定含义的名字,常量用于定义有以下特点的数据(1:在程序中保持不变2:在程序中频繁使用3:需要用某些简单的方式来替代某些数4:防止意外的修改增强程序的健壮性。 定义宏常量的格式:#define标识符常量 替换文本 。
#define语句不以分号结尾,可以位于源代码的任何位置,他定义的常量值在后面的的源代码中有效。
宏常量也有其自身的缺点:宏常量被替换成替换成替换文本后,内存中有同一个替换文本的多份副本。
const常量:const常量与变量定义的形式类似,加上const的修饰,告诉编译器它的值是固定的,其目的正是为了取代宏常量,消除其缺点的同时继承其优点。
5.基本运算符
(1)算术运算符:在c语言中,算术运算符包括一元运算(++和-- + - ) 和二元运算(+ - * % /)使用算术运算的时候要注意:1,两个整数相除,结果为整数; 2,%模运算是求余数的计算,只能在两个整数之间进行;3,*号不能省略;4,双目运算符两侧操作数的类型要相同。
(2)类型转换的方式;1,常用算术转换:当算术运算,关系运算和逻辑运算的两个操作数类型不同时,精度低的自动向精度高的转换,这叫做类型提升;2,赋值时类型转换:把赋值运算符右侧表达数的值转换成赋值运算符左侧变量的类型;3,类型转换运算符:类型转换后仅产生一个指定类型的数据继续参加运算,这种类型转换操作并不改变操作数本身。
6.计算两点间的距离