c语言学习小结,学习笔记1:简单的c语言程序

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.计算两点间的距离

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSU 大一上 C语言实验报告 (1)教材第2章编程题第2题:编写计算球体体积的程序。 说明:本题声明适当变量,用户键入数据,运算并输出结果,较简单。 (2)教材第2章编程题第8题:编写程序计算第一、第二、第三月还贷后剩余贷款金额。 说明:本题要求用户输入总额、利率、每月还贷净额,输出每月剩余,对输入输出、类型定义考查。 (3)教材第3章编程题第2题:编写程序实现对用户输入的产品信息进行格式化。 说明:本题考查格式化输入输出、转义字符的运用。 (4)教材第4章编程题第4题:编写程序实现将输入的整数按八进制输出。 说明:本题重在考查简单的运算符和表达式运用。 (5)用户输入一个三位数,输出各位数字之和。 说明:本题重在考查如何从一个整数中取出每一个数字。 (6)教材第5章编程题第5题:编写程序计算用户输入所得额的税金。 说明:本题考查简单的选择结构。 (7)教材第5章编程题第11题:编写程序实现将用户输入的两位数转化为英文。 说明:本题考查switch语句的应用。 (8)教材第6章编程题第8题:编写程序显示单月日历,用户指定这个月的天数和该月起始日是星期几。 说明:本题考查循环结构和选择结构的综合应用,判断是否一个星期最后一天,换行符。 (9)教材第6章编程题第11题:编程序实现利用无穷级数法估计e的值。 说明:本题考查根据公式设计循环结构并实现。 (10)因子之和等于其本身的数称为完数,如28的因子为1、2、4、7、14,而28=1+2+4+7+14,因此28为完数。编程序找出2~5000中的完数。 说明:本题利用变量i在2~5000中变化,判断其是否是完数。 (11)教材第7章编程题第12题:编程计算从左至右求值的表达式的值。 说明:本题考查对运算符和操作数的判断。 (12)教材第7章编程题第14题:编程序用牛顿计算法计算浮点数平方根。 说明:本题考查对循环结构的掌握,对表达式的合理运用,对基本类型的理解。 (13)教材第8章编程题第14题:编写程序颠倒句子中单词的顺序。 说明:本题考查对字符数组的处理,对一些循环选择结构的理解。 (14)教材第8章编程题第15题:编写程序实现凯撒密码加密。 说明:本题考查对字符数组的掌握,对字符处理的理解。 (15)编程序实现将用户输入的数字字符串转化为整数输出。 说明:本题考察对字符、整数关系的掌握与理解,对循环结构的熟练运用。 (16)教材第9章编程题第1题:编写选择排序的函数,并递归调用。 说明:本题利用函数简化程序、使得结构更清晰、熟练掌握。 (17)教材第9章编程题第7题:编写计算xn的函数。 说明:本题考查函数定义、调用,并初步考察递归运用。 (18)教材第10章编程题第6题:编写程序实现逆波兰运算。 说明:本题考查对程序每部分的理解、掌握,外部、内部变量,主函数,小函数的编写与应用。初步了解栈的一些实现函数。 (19)编程序找出2~5000中满足条件的数x:x是素数且x的每位数字是素数、每位数字之和是素数,如23、223、2333等。 说明:本题考查函数方法与循环选择结构的综合运用。 (20)教材第11章编程题第3题:用指针变量编写简化一个分数的函数。 说明:本题用来解决函数无法传回传递的实际参数,指针变量。 (21)教材第12章编程题第2题:编写函数读入用户输入的一条消息,检测是否是回文,分别用数组、指针来解决。 说明:本题可以体会到数组与指针的特点,利用指针的便利。 (22)利用指针编写程序,实现从键盘键入字符串,将此字符串从m个字符开始的n个字符复制成另一个字符串。 说明:本题用指针指向字符串,进行跟踪和复制操作。 (23)教材第13章编程题第5题:编写程序实现对输入命令行参数求和。 说明:本题加深对命令行参数的理解、考查知识的综合应用。 (24)教材第16章编程题第5题:用结构变量解决搜索离用户输入时间最近的航班信息,并输出。 说明:本题考查结构与数组的结合运用,有助于理解结构。首先,定义一个存储起飞、到达时间的结构,再定义一个该类型的数组,循环搜索即可。 (25)教材第17章编程题第5题:用指针数组存储键入的字符串,对数组排序。 说明:本题应用动态分配内存、数组排序,考查综合能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值