当前位置: 首页 > news >正文

C语言的期末复习

🌈博客主页:卿云阁

💌欢迎关注🎉点赞👍收藏⭐️留言📝

🌟本文由卿云阁原创!

🙏作者水平很有限,如果发现错误,请留言轰炸哦!万分感谢!


🍈 基础必备

0️⃣数据类型和表达式

1️⃣简单的程序设计

2️⃣C语言指针的初步了解

3️⃣指针进阶(一)(C语言)

4️⃣指针进阶(二)(C语言)

7️⃣结构体与枚举类型

 🍉常考的大题

1.简单的if-else-语句(一般第一题很简单的)

eg.

#include <stdio.h>
int main(void)
{
float x,y;
scanf("%f",&x);   //从键盘接收x的值。
if(x<=1)  
y=x;
if(x>1 && x<10)  //逻辑表达式值为1时,执行下面的这条语句。y=x*2.0f-1;
if(x>=10)
y=3*x-11;
printf("%5.2f",y);
return 0;
}

 2.实现用*画一个平行四边形

#include<stdio.h>
#include<math.h>
int main(void)
{int i=1,j,k,r=5;  //r表示行数
for(i=-1*r;i<=r;i++)
{for(k=1;k<=abs(i);k++)  //输出一行前的空格{printf(" ");                  /*加自己的代码,abs(i)为求i的绝对值*/ }   
//下面输出一行中的所有*。for(j=1;j<= 2 *(5-abs(i))+1;j++){printf("*");}printf("\n");
}
return 0;
}


3.冒泡算法

#include <stdio.h>
int main(void)
{   int i,j,z,temp;int a[10]={1, 0, 4, 8, 123, 65, -76, 100, -45, 12};for(j=1;j<10;j++){for (i=0;i<10-j;i++){if (a[i]>a[i+1]){temp=a[i];a[i]=a[i+1];a[i+1]=temp;}	}}for(z=0;z<10;z++)printf("%d ",a[z]);return 0;
}


4.编程输入某班同学的姓名以及C_language、higher_mathematics两门课的成绩,并按各学生总分从高到低进行排序后输出。

分析:首先定义两个一维数组存放两门课的成绩,然后,再定义一个二维字符数组存放同学的姓名,每一行存放一个姓名。

本例通过冒泡排序算法进行排序,前面讲的冒泡算法是比较相邻两个数据,如果前者比后者小,互换两个数据。但这里要求按学生总分排序,因此,在用冒泡算法时,要把前一同学与后一个同学的总分进行比较,如果前者总分小则互换,因为这里有三个数组,互换时同一个学生的信息(包括姓名、两门课的成绩)要同时互换。同时注意到姓名是字符串,它们之间不能用赋值符号进行赋值,所以互换时要用strcpy函数。为了互换方便,先定义一个临时的一维字符数组tempName,在互换姓名时使用。整个程序代码如下。

#include <stdio.h>
#include <string.h>
#define LEN 20  //一个学生姓名占用的长度。
int main(void)
{
int i, j, N;   //N为学生人数。
float C_language[N], higher_mathematics[N], temp; 
printf("输入学生个数:");
scanf("%d", &N); 
char name[N][LEN], tempName[LEN];
//第一步,用一个循环输入数据。for (i = 0; i < N; i++) {printf("请输入第%d个同学的姓名,输完按Enter键:\n", i + 1);gets(name[i]); //接收姓名字符串。printf("请输入第%d个同学的两门成绩,中间用空格隔开,输完按Enter键:\n", i + 1);scanf("%f%f", &C_language[i], &higher_mathematics[i]);}//第二步,用冒泡法排序。for (j = N; j >= 1; j--){for (i = 1; i < j; i++)/*前一个学生的总分比后一个的小,互换成绩和姓名*/if (C_language[i] + higher_mathematics[i] >C_language[i - 1] + higher_mathematics[i - 1]){
//互换C_language中的成绩。temp = C_language[i - 1];C_language[i - 1] = C_language[i];C_language[i] = temp;
//互换higher_mathematics中的成绩。temp = higher_mathematics[i - 1];higher_mathematics[i - 1] = higher_mathematics[i];higher_mathematics[i] = temp;
//下面对姓名进行互换,要用strcpy。strcpy(tempName, name[i - 1]); //name[i-1]看成一维数组名。strcpy(name[i - 1], name[i]);strcpy(name[i], tempName);}
} //排序完毕。printf("\n按总分排序的结果:\n");for (i = 0; i < N; i++)printf("%s,%3.0f,%3.0f\n", name[i], C_language[i],  higher_mathematics[i]);
return 0;
}

strcpy函数

strcpy函数的一般形式为strcpy(字符串1,字符串2,n)。其功能是将字符串2的前n个字符复制到字符串1中,并在其后加上'\0'。如果没有n,则是把字符串2全部制给字符串1。这里字符串1必须放在可修改值的内存空间中。

例如,char str2[]="math",str1[10]; 则执行strcpy(str1,str2);后,str1就变成了串"math"。执行strcpy(str1,str2,2); 后将str2的前面2个字符复制到str1中,然后再加一个'\0',所以str1就是"ma"。

字符串之间不能直接用=来赋值,即不能写成str1=str2;进行字符串的复制。使用strcpy时,要注意存放字符串1的一维数组内存空间要大于等于字符串2字面量(即不包括\0的字符个数)加1。

strcmp函数

strcmp函数的一般形式为strcmp(字符串1,字符串2);。其功能是比较两个字符串的大小。

比较的规则是对两个字符串自左至右逐个字符比较(包括串结尾字符'\0'),直到出现不同的字符或遇到'\0'为止。如全部字符相同,则认为相等;若出现不相同的字符,则字符ASCII码值大的所在串大,否则就小。

比较的结果由函数返回,当字符串1与字符串2相等,函数返回值为0;当字符串1大于字符串2,函数返回值为正整数;当字符串1小于字符串2,函数返回值为负整数。例如,

x=strcmp("A","B");    //x是一个负整数,注意A、B不能用单引号引起。

x=strcmp("a","A");    //x是一个正整数。

x=strcmp("compare","computer");  //x是一个负整数。

x= strcmp("ab","a");   //x是一个正整数。

x= strcmp("ab","ab");  //x为0


5.指向一维数组的指针,指针数组

指向一维数组的指针指向的类型类型是一个一维数组。定义一个指向一维数组的指针变量格式如下。

数据类型 (*指针变量名)[n]; 

意思是定义了一个指针变量,这个指针变量指向具有n个元素的一维数组,且这个一维数组中每个元素都是给定的数据类型。

1.ch指向由十个char类型的数据组成的一维数组

#include <stdio.h>
int main(void)
{char str[3][10]={"123","456","789"};char(*ch)[10];ch=str+1;               //ch可以赋值,str不能赋值 putchar(ch[0][1]);      //ch[0]就相当于一维数组名str[1]putchar('\n');ch=ch+1;               //改变ch的值可以改变不同的数据putchar(ch[0][1]);     //ch[0]就相当于一维数组名str[2]return 0;
}

如果一个数组,它里面的变量全部是指针类型,且每个指针指向的数据类型相同,则称这种数组称为指针数组。定义指针数组的一般格式为:

数据类型 *数组名[n];

这实质上就是一个一维数组,只是它的元素存放的是指针值,数据类型不是其元素的数据类型,而是元素指向的数据类型。

#include<stdio.h>
int main(void)
{ int a[3]={1,2,3};int b[3]={20,30,40};int c[3]={50,60,70};int *ar[3]={a,b,c}; printf("%d\n",ar[0][1]);  //ar[0]就相当于一维数组名aprintf("%d\n",ar[1][1]);printf("%d\n",ar[2][1]);return 0; 
}


6.函数参数(特容易出读程题,把3个代码运行观察是否改变a,b的值)

#include <stdio.h>
void exchange(int a,int b) //定义函数,形参为a、b,并实现a、b互换。
{   int temp;temp=a;a=b;b=temp;printf("a=%d,b=%d\n",a,b); 
}
int main(void)
{int a=10,b=20;exchange (a,b);       //调用函数,执行两数互换。printf("a=%d,b=%d\n",a,b); return 0;
}#include <stdio.h>
void exchange(int a[],int b[]) //改动点 
{   int temp;temp=a[0];    //改动点 a[0]=b[0];    //改动点 b[0]=temp;    //改动点 }
int main(void)
{int a=10,b=20;exchange (&a,&b);       //改动点 printf("a=%d,b=%d\n",a,b); return 0;
}#include <stdio.h>
void exchange(int a[],int b[]) //改动点 
{   int temp;temp=a[0];    //改动点 a[0]=b[0];    //改动点 b[0]=temp;    //改动点 printf("a=%d,b=%d\n",a,b); 
}
int main(void)
{int a=10;int b=20;exchange (&a,&b);       //改动点 printf("a=%d,b=%d\n",a,b); return 0;
}

7.结构体数组,文件的写入。

#include <stdio.h>
typedef  struct student
{int num;char name[10];char sex;char addr[10];}Student;
int main(void)
{
/*定义两个变量结构体变量stu1和stu2,并初值化stu1 */
Student stu[2]={{202018080,"qingyun",'m',"xiaoxian"}, \
{202018081,"wenzhu",'w',"xiaoxian"}};
printf("no.:%d name:%s sex:%c address:%s\n",stu[0].num,stu[0].name, \ 
stu[0].sex, stu[0].addr);
printf("no.:%d name:%s sex:%c address:%s\n",stu[1].num,stu[1].name, \ 
stu[1].sex, stu[1].addr);
return 0;
}

从键盘输入一组字符,并它存入文件save.txt中,并在显示器上输出。 

分析:以写方式打开save.txt,循环用fgetc(stdin)获取从键盘上的字符,并用一个int型变量ch接收,然后分别用fputc(ch,stdout)和fputc(ch,fp)把字符ch输出到显示器和文件中。代码如下。

#include<stdio.h>#include<stdlib.h>int main (){char filename[10]="save.txt";FILE * stream=fopen (filename, "w") ; //以写模式打开文件。int ch;if(NULL== stream){printf ("Failed to open the file !\n");exit(0);}printf ("Please input characters and press enter to finish:\n");while ((ch=fgetc (stdin)) != '\n') //循环从键盘获取字符,遇换行符结束。{fputc(ch, stream);    //向打开的文件输出同样的字符。fputc (ch, stdout);    //向显示器输出字符。}fputc ('\n', stdout);      //向显示器输入字符,也可以不写此语句。fclose (stream); //关闭指向save.txt文件的流。}

执行后在显示器上的效果如下。

Please input characters and press enter to finish:

abcdefg↙

abcdefg

文件save.txt的内容显示如图11-1所示。

 

相关文章:

C语言的期末复习

&#x1f308;博客主页&#xff1a;卿云阁 &#x1f48c;欢迎关注&#x1f389;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f31f;本文由卿云阁原创&#xff01; &#x1f64f;作者水平很有限&#xff0c;如果发现错误&#xff0c;请留言轰炸哦&#xff01;万分感谢&a…...

强化学习之DQN论文介绍

强化学习之DQN论文介绍DQN摘要介绍问题特点经验回放相关工作实验算法流程结论DQN 摘要 1.基于Q-learning从高维输入学习到控制策略的卷积神经网络。 2.输入是像素&#xff0c;输出是奖励函数。 3.主要训练、学习Atari 2600游戏&#xff0c;在6款游戏中3款超越人类专家。 介绍 …...

使用luaBridge添加自己的C++脚本插件能力

概述 如果我们有一个应用需要频繁的更改业务逻辑,但是基础功能不变,那么我们可以将基础功能作为底层接口,上层的功能按照脚本方式来编写。很多插件都这样的原理,比如我们的浏览器的JS就这样,小程序也是这样的原理,我们使用C++也很容易实现这样的功能。 lua是最小最精致的…...

再拾起博客

一切要从去年12月27日被裁员的那天说起。 那天是星期二&#xff0c;和平常一样&#xff0c;8点20的闹钟响起&#xff0c;但我习惯性的磨蹭到8点40起床&#xff0c;洗漱完成后9点过几分出门&#xff0c;骑车20多分钟几乎是踩点到的公司&#xff0c;正当我坐在工位准备平复心情切…...

Mybatis流式游标查询-大数据DB查询OOM查询问题

问题场景Mysql数据处理类型分以下三种com.mysql.cj.protocol.a.result.ResultsetRowsStatic&#xff1a;普通查询&#xff0c;将结果集一次性全部拉取到内存com.mysql.cj.protocol.a.result.ResultsetRowsCursor&#xff1a;游标查询&#xff0c;将结果集分批拉取到内存&#x…...

以before为例 完成一个aop代理强化方法案例

观看本文 首先 您需要做好Spring aop的准备工作 具体可以参考我的文章 java Spring aop入门准备工作 首先 我们创建一个包 我这里叫 Aop 然后在Aop包下创建一个类 叫 User 参考代码如下 package Aop;public class User {public void add(){System.out.println("add....…...

好记性不如烂笔头之Java基础复习笔记

未完待续。。。 代码块先于构造方法执行&#xff0c;不管类中有多少个代码块&#xff0c;都会先将所有代码块执行完再执行构造方法和其他方法。类中如果没有自定义的构造方法&#xff0c;那么JVM会提供默认的无参构造方法&#xff1b;如果类中有自定义的构造方法&#xff0c;那…...

MyBatisPlus

这里写目录标题1.MyBatisPlus概述2.MyBatisPlus的开发步骤2.1 MyBatisPlus的CRUD操作2.2 MyBatisPlus的分页查询3.MyBatisPlus的DQL编程控制(封装sql)3.1 条件查询方式3.1.1 条件查询3.1.2 组合条件3.1.3 Null值处理3.2 查询投影-设置【查询字段、分组、分页】3.2.1 查询结果包…...

【C语言】编程初学者入门训练(11)

文章目录101. 矩阵相等判定102. 上三角矩阵判定103. 矩阵转置104. 矩阵交换105. 杨辉三角106. 井字棋107. 小乐乐与进制转换108. 小乐乐求和109. 小乐乐定闹钟110. 小乐乐排电梯101. 矩阵相等判定 问题描述&#xff1a;KiKi得到了两个n行m列的矩阵&#xff0c;他想知道两个矩阵…...

HTTP 1.1响应码

HTTP 1.1响应码 响应码和信息含义HttpURLConnection1XX信息100 Continue服务器准备接受请求主体&#xff0c;客户端应当发送请求主体&#xff1b;这允许客户端在请求中发送大量数据之前询问服务器是否将接受请求N/A101 Switching Protocols服务器接受客户端在Upgrade首部字段中…...

常用设计模式介绍

java设计模式类型创建型模式&#xff1a;将对象的创建与使用分离结构型模式&#xff1a;如何将类和对象按照某种布局组成更大的格局行为型模式&#xff1a;用于描述类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务23种设计模式介绍1.单例&#xff08;Singleton&…...

关于货物物品横竖摆放的问题

货车内宽是2.4米。考虑到最多装载&#xff0c;长宽130100的货品&#xff0c;应该横竖摆放。 横竖摆放的数量如何自动计算呢&#xff1f; 采用数学公式&#xff0c;计算如下&#xff1a; 横向摆放数(int)(横长竖高)*数量/4/横长 竖向摆放数数量-横向摆放数 结果如下&#x…...

人员定位需求多,场景目标各不同

GPS技术为现代人带来了许多便利&#xff0c;也提供了诸多基于位置的新型服务。随着科技的发展&#xff0c;人员位置信息在如今的生产生活中也越发重要起来。因此&#xff0c;不同行业领域开始关注人员定位&#xff0c;尤其关注室内人员定位。室内人员定位需求从目的性出发&…...

怎么解决首屏加载速度过慢的问题

怎么解决首屏加载速度过慢的问题首屏加载速度指的是什么&#xff1f;解决方法首屏加载速度指的是什么&#xff1f; 首屏加载速度指的是浏览器从响应用户输入网站地址到首屏内容渲染完成的时间。值得注意的是此时整个网页不一定要全部渲染完成&#xff0c;只需展示当前视窗所需要…...

3d视觉相关论文阅读目录汇总

目录3d视觉综述论文 Deep Learning for 3D Point Clouds: A Survey 基础概念 3d目标检测常见基础概念 3d目标检测 & 自动驾驶 数据集 3d目标检测数据集介绍&#xff08;数据格式&#xff0c;保存形式&#xff0c;适配算法库等&#xff09; KITTI数据集 Waymo数据集 nu…...

最简单的计算机视觉

百度为大家提供了计算机视觉模型。能够识别图像中的相关物体。 给大家介绍计算机视觉工具&#xff0c;EasyDL是能够识别物体&#xff0c;图像分类的工具&#xff0c;可以在线&#xff0c;也可以本地下载&#xff0c;本地下载大概1.5G。 图像识别真实距离。 图片真实距离/物体…...

泛微采知连,为组织提供安全、合规、智能的数字化文控系统

作为市场主体&#xff0c;企业需要建立健全的质量管理体系&#xff0c;并且及时更新&#xff0c;以应对激烈的市场竞争&#xff0c;实现企业可持续发展。 质量体系在很大程度上通过文件化的形式表现出来。《质量管理体系要求》(GB/T19001—2016/ISO9001&#xff1a;2015)标准指…...

Python if else对缩进的要求

前面的《Python if else》一节展示了选择结构的三种基本形式&#xff0c;并给出了实例演示&#xff0c;但是大家在编写代码过程中仍然要注意一些细节&#xff0c;尤其是代码块的缩进&#xff0c;这对 if else 选择结构极其重要。 Python 是以缩进来标记代码块的&#xff0c;代…...

java常用设计模式

java设计模式java设计模式类型常用设计模式单例模式单例模式的两种创建方式饿汉式单例懒汉式单例工厂模式简单工厂模式工厂方法模式抽象工厂模式原型模式代理模式代理模式结构静态代理动态代理jdk代理Cglib代理java设计模式类型 根据完成的工作类型设计模式分为创建型模式、结…...

死锁(5.1)

死锁 1 死锁的基本概念 1.1 死锁的定义 死锁是发生在一组相互合作或竞争的线程或进程中的一个问题。因此可以定义为&#xff1a;一组竞争系统资源或相互通信的进程相互的“永久”阻塞。若无外力作用&#xff0c;这组进程将永远不能继续执行。 1.2死锁产生的原因进程 &…...

黑马Mybatis

Mybatis 表现层&#xff1a;页面展示 业务层&#xff1a;逻辑处理 持久层&#xff1a;持久数据化保存 在这里插入图片描述 Mybatis快速入门 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/6501c2109c4442118ceb6014725e48e4.png //logback.xml <?xml ver…...

Qt Widget类解析与代码注释

#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码&#xff0c;写上注释 当然可以&#xff01;这段代码是 Qt …...

Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)

目录 1.TCP的连接管理机制&#xff08;1&#xff09;三次握手①握手过程②对握手过程的理解 &#xff08;2&#xff09;四次挥手&#xff08;3&#xff09;握手和挥手的触发&#xff08;4&#xff09;状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...

家政维修平台实战20:权限设计

目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系&#xff0c;主要是分成几个表&#xff0c;用户表我们是记录用户的基础信息&#xff0c;包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题&#xff0c;不同的角色&#xf…...

Linux云原生安全:零信任架构与机密计算

Linux云原生安全&#xff1a;零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言&#xff1a;云原生安全的范式革命 随着云原生技术的普及&#xff0c;安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测&#xff0c;到2025年&#xff0c;零信任架构将成为超…...

JDK 17 新特性

#JDK 17 新特性 /**************** 文本块 *****************/ python/scala中早就支持&#xff0c;不稀奇 String json “”" { “name”: “Java”, “version”: 17 } “”"; /**************** Switch 语句 -> 表达式 *****************/ 挺好的&#xff…...

select、poll、epoll 与 Reactor 模式

在高并发网络编程领域&#xff0c;高效处理大量连接和 I/O 事件是系统性能的关键。select、poll、epoll 作为 I/O 多路复用技术的代表&#xff0c;以及基于它们实现的 Reactor 模式&#xff0c;为开发者提供了强大的工具。本文将深入探讨这些技术的底层原理、优缺点。​ 一、I…...

在Ubuntu24上采用Wine打开SourceInsight

1. 安装wine sudo apt install wine 2. 安装32位库支持,SourceInsight是32位程序 sudo dpkg --add-architecture i386 sudo apt update sudo apt install wine32:i386 3. 验证安装 wine --version 4. 安装必要的字体和库(解决显示问题) sudo apt install fonts-wqy…...

站群服务器的应用场景都有哪些?

站群服务器主要是为了多个网站的托管和管理所设计的&#xff0c;可以通过集中管理和高效资源的分配&#xff0c;来支持多个独立的网站同时运行&#xff0c;让每一个网站都可以分配到独立的IP地址&#xff0c;避免出现IP关联的风险&#xff0c;用户还可以通过控制面板进行管理功…...

【JavaSE】多线程基础学习笔记

多线程基础 -线程相关概念 程序&#xff08;Program&#xff09; 是为完成特定任务、用某种语言编写的一组指令的集合简单的说:就是我们写的代码 进程 进程是指运行中的程序&#xff0c;比如我们使用QQ&#xff0c;就启动了一个进程&#xff0c;操作系统就会为该进程分配内存…...