C语言 第二章 数据类型、变量和输入函数

简介: 一、数据类型简介 在 C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。 类型转换: 类型存储大小值范围char 1 字节 -128 到 127 或 0 到 255 ...

一、数据类型简介

在 C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。

类型转换:

类型 存储大小 值范围
char 1 字节 -128 到 127 或 0 到 255
unsigned char 1 字节 0 到 255
signed char 1 字节 -128 到 127
int 2 或 4 字节 -32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647
unsigned int 2 或 4 字节 0 到 65,535 或 0 到 4,294,967,295
short 2 字节 -32,768 到 32,767
unsigned short 2 字节 0 到 65,535
long 4 字节 -2,147,483,648 到 2,147,483,647
unsigned long 4 字节 0 到 4,294,967,295

1.2、获得数据类型的长度

#include "stdio.h"
void main()
{
    //sizeof用于获得数字类型的长度
    //sizeof是一个关键字(32个)
    printf("char占用字节数:%d \n",sizeof(char));
    printf("short占用字节数:%d \n",sizeof(short));
    printf("int占用字节数:%d \n",sizeof(int));
    printf("long占用字节数:%d \n",sizeof(long));
    printf("float占用字节数:%d \n",sizeof(float));
    printf("double占用字节数:%d \n",sizeof(double));     
}

二、变量定义

是用数据类型在内存中开辟的空间。
一个变量应该有一个名字,也就是我们程序员给该空间取的名──叫变量名。
它在内存中占据一定的存储单元。
变量定义必须放在变量使用之前,即先定义后使用,一般都放在函数体的开头部分。

变量:在程序运行过程中可以变化的量。

常量:在程序运行过程中不可以变化的量。

#include "stdio.h"
void main()
{
    int i=100;
    i++;   //i=i+1
    printf("i=%d \n",i); //101
    i--;  //i=i-1
    printf("i=%d \n",i); //100
    i+=100;  //i=i+100    
    printf("i=%d \n",i);  //200
    i/=3;  //i=200/3=66.666667=66      
    printf("i=%d \n",i);  //66
    i+7;  //在内存中66+7完成运算,但值没有写回            
    printf("i=%d \n",i);  //66
}

2.1、变量名的取名规则

第一个字符只能是字母或下划线( _ );

第一个字符的后而只能跟字母、数字和下划线( _ );

关键字(写上去会变色的那些单词)不能用作变量名;

区分大小写;

第一位(a-zA-Z_)后续(a-zA-Z_0-9)

请问下面那些是非法的,为什么?

1name
_product
_9527
Double
int
_producT
_product
total

2.2、变量定义的多种形式

/* Note:Your choice is C IDE */
#include "stdio.h"
void main()
{
    //定义变量并赋值
    int i=100;
    
    //先定义再赋值
    float j;
    //j=99.5f; 错误,变量定义必须放在变量使用之前,即先定义后使用,一般都放在函数体的开头部分
    
    //同时定义多个变量
    char a,b,c;
    
    //同时定义多个变量并赋值
    double x=1.5,y=1.6,z;
    
    j=99.5f;
    z=x+y;
    
}

三、整型(int)

#include "stdio.h"
void main()
{
    int i;
    i++;   //i=i+1
    printf("i=%d \n",i); //101
    i--;  //i=i-1
    printf("i=%d \n",i); //100
    i+=100;  //i=i+100    
    printf("i=%d \n",i);  //200
    i/=3;  //i=200/3=66.666667=66      
    printf("i=%d \n",i);  //66
    i+7;  //在内存中66+7完成运算,但值没有写回            
    printf("i=%d \n",i);  //66
}

四、字符型(char)

五、单精度浮点型(float)

六、双精度浮点型(double)

七、输入scanf

#include "stdio.h"
void main()
{
    //判断年龄如果小于18岁则提示年轻真好,否则输出年龄
    
    //定义变量
    int age;
    
    //用户输入年龄
    printf("请输入年龄:");
    //从键盘输入,&表示取变量地址
    scanf("%d",&age);
    
    //条件判断
    if(age<18){  //如果条件成立
       printf("年轻真好");
    }
    else{  //如果条件不成立
       //输出
       printf("您的年龄是:%d",age);
    }
}

scanf("格式控制",地址列表);
“格式控制”的含义同printf函数;
“地址列表”是由若干个地址组成的表列,可以是变量的地址,或字符串首地址

%f 单精度

%lf 双精度 

%c 从键盘接收一个字符
%d 从键盘接收十进制整数
%s 从键盘接收一个字符串,遇空格、制表 符或换行符表示接收完毕。
%[] 从键盘接收一包含在括号内的字符,只 要遇到有一个不在其内的字符,便表 示接收完毕。

输入时如果遇到 空格 回车 Tab则表示结束

7.1、输入时指定分隔符

#include "stdio.h"
void main()
{
    int a,b,c;
    printf("请输入年-月-日:");
    scanf("%d-%d-%d",&a,&b,&c);
    printf("%d年%d月%d日",a,b,c);
}

7.2、清除缓冲

#include "stdio.h"
void main()
{
    char x,y,z;
    printf("输入:");
    scanf("%c",&x);
    printf("输入:");
    scanf("%c",&y);
    printf("输入:");
    scanf("%c",&z);
    printf("%c,%c,%c",x,y,z);
}

 

#include "stdio.h"
void main()
{
    char x,y,z;
    printf("输入:");
    scanf("%c",&x);
    fflush(stdin);  //清除缓冲
    printf("输入:");
    scanf("%c",&y);
    fflush(stdin);  //清除缓冲
    printf("输入:");
    scanf("%c",&z);
    fflush(stdin);  //清除缓冲
    printf("%c,%c,%c",x,y,z);
}

 

7.3、输入字符串

#include "stdio.h"
void main()
{
    char a[100];  //数组,char只能是单个字符
    scanf("%s",a);  //不要取地址
    printf("%s",a);
}

7.4、限定输入范围

#include "stdio.h"
void main()
{
    //限定输入范围
    char a[100];
    scanf("%[0123456789]s",a);//只能输入0-9,其它表示结束
    printf("%s",a);
}

 

7.5、限定输入范围取反

#include "stdio.h"
void main()
{
    char a[100];
    scanf("%[^a]s",a);  //^取反,如果是a则表示结束
    //scanf("%[^\n]s",a);  //如果是换行则结束,其它字符都可以
    printf("%s",a);
}

 

 练习:

#include "stdio.h"
void main()
{
    int nianling;  //年龄
    float fenshu;  //分数
    char aihao[30];  //爱好
    printf("请输入年龄:");
    scanf("%d",&nianling);
    
    printf("请输入分数:");
    scanf("%f",&fenshu);
    
    printf("请输入爱好:");
    scanf("%s",aihao);
    
    printf("您的年龄是%d,分数:%f,爱好:%s",nianling,fenshu,aihao);
}

 

目录
相关文章
|
15天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
30 10
|
8天前
|
存储 算法 程序员
C语言:库函数
C语言的库函数是预定义的函数,用于执行常见的编程任务,如输入输出、字符串处理、数学运算等。使用库函数可以简化编程工作,提高开发效率。C标准库提供了丰富的函数,满足各种需求。
|
14天前
|
机器学习/深度学习 C语言
【c语言】一篇文章搞懂函数递归
本文详细介绍了函数递归的概念、思想及其限制条件,并通过求阶乘、打印整数每一位和求斐波那契数等实例,展示了递归的应用。递归的核心在于将大问题分解为小问题,但需注意递归可能导致效率低下和栈溢出的问题。文章最后总结了递归的优缺点,提醒读者在实际编程中合理使用递归。
37 7
|
14天前
|
存储 编译器 程序员
【c语言】函数
本文介绍了C语言中函数的基本概念,包括库函数和自定义函数的定义、使用及示例。库函数如`printf`和`scanf`,通过包含相应的头文件即可使用。自定义函数需指定返回类型、函数名、形式参数等。文中还探讨了函数的调用、形参与实参的区别、return语句的用法、函数嵌套调用、链式访问以及static关键字对变量和函数的影响,强调了static如何改变变量的生命周期和作用域,以及函数的可见性。
25 4
|
19天前
|
存储 编译器 C语言
C语言函数的定义与函数的声明的区别
C语言中,函数的定义包含函数的实现,即具体执行的代码块;而函数的声明仅描述函数的名称、返回类型和参数列表,用于告知编译器函数的存在,但不包含实现细节。声明通常放在头文件中,定义则在源文件中。
|
16天前
|
存储 C语言
【c语言】数据类型和变量
本文介绍了C语言中的数据类型和变量。数据类型分为内置类型和自定义类型,内置类型包括字符型、整型、浮点型等,每种类型有不同的内存大小和取值范围。变量分为全局变量和局部变量,它们在内存中的存储位置也有所不同,分别位于静态区和栈区。通过示例代码和图解,详细阐述了这些概念及其应用。
32 1
|
19天前
|
存储 C语言
C语言指针与指针变量的区别指针
指针是C语言中的重要概念,用于存储内存地址。指针变量是一种特殊的变量,用于存放其他变量的内存地址,通过指针可以间接访问和修改该变量的值。指针与指针变量的主要区别在于:指针是一个泛指的概念,而指针变量是具体的实现形式。
|
11天前
|
存储 C语言
【c语言】字符串函数和内存函数
本文介绍了C语言中常用的字符串函数和内存函数,包括`strlen`、`strcpy`、`strcat`、`strcmp`、`strstr`、`strncpy`、`strncat`、`strncmp`、`strtok`、`memcpy`、`memmove`和`memset`等函数的使用方法及模拟实现。文章详细讲解了每个函数的功能、参数、返回值,并提供了具体的代码示例,帮助读者更好地理解和掌握这些函数的应用。
13 0
|
11天前
|
C语言
【c语言】qsort函数及泛型冒泡排序的模拟实现
本文介绍了C语言中的`qsort`函数及其背后的回调函数概念。`qsort`函数用于对任意类型的数据进行排序,其核心在于通过函数指针调用用户自定义的比较函数。文章还详细讲解了如何实现一个泛型冒泡排序,包括比较函数、交换函数和排序函数的编写,并展示了完整的代码示例。最后,通过实际运行验证了排序的正确性,展示了泛型编程的优势。
12 0
|
14天前
|
算法 C语言
factorial函数c语言
C语言中实现阶乘函数提供了直接循环和递归两种思路,各有优劣。循环实现更适用于大规模数值,避免了栈溢出风险;而递归实现则在代码简洁度上占优,但需警惕深度递归带来的潜在问题。在实际开发中,根据具体需求与环境选择合适的实现方式至关重要。
12 0