2017年-2021年 软件工程程序设计题(算法题)实战_c语言程序设计数据结构程序设计分析

news2025/1/14 18:07:06

文章目录

  • 2017年
    • 1.c语言程序设计部分
    • 2.数据结构程序设计部分
  • 2018年
    • 1.c语言程序设计部分
    • 2.数据结构程序设计部分
  • 2019年
    • 1.c语言程序设计部分
    • 2.数据结构程序设计部分
  • 2020年
    • 1.C语言程序设计部分
    • 2.数据结构程序设计部分
  • 2021年
    • 1.C语言程序设计部分
    • 2.数据结构程序设计部分

2017年

1.c语言程序设计部分

在这里插入图片描述


第一题 略

第二题 大循环累加,小循环求阶乘

第三题 没什么好说的,甚至数据都给你了

2.数据结构程序设计部分

在这里插入图片描述
问题1分析:

给定了结构体,多了一个频度的数据成员。
locate函数的本质就是插入函数,本质就是查找完然后平移动
本题是双向链表带头结点

代码如下:

typedef struct BiTNode
{
    Elemtype data;
    struct BiTNode *lLink;
    struct BiTNode *rLink;
    int frep;
    
}BiTNode,*BiTree;

//假设 该双向链表是 18 ,23 ,15 ,24,4个结点构成

void Locate(Elemtype x,BiTree &head)
{
    //先找到这个结点
    BiTNode *cur=head->rLink;
    while(cur!=NULL)
    {
        if(cur->data==x) break; //cur就指向x点
        
        cur=cur->rLink;
    }
    cur->frep++; //频度+1
    int target_frep=cur->frep; //记录目标频度
    BiTNode *pre=cur->lLink; //记录当前的cur的前一个元素,往前找
    
    while(pre!=head)  //如果pre没有找到,将移动到头结点后面
    {
        if(pre->frep==target_frep)break; //找到了,此时pre指向的就是跟它频度相同的点
        pre=pre->lLink;
    }
    
    //开始插入操作
    //将cur插入到pre的后面
    //先将cur去掉
    cur->lLink->rLink=cur->rLink;
    cur->rLink->lLink=cur->lLink;
    
    //将cur加入到pre后面
    cur->rLink=pre->rLink;
    pre->rLink=cur;
    cur->lLink=pre;
    cur->lLink=pre;
}

问题2:就是堆排序

堆排序需要实现swap交换操作
堆排序的调整函数中,需要传入的参数是,树结点的数组int a[],一共的结点数length,和标记当前指向的结点i(largest)

void swap(int *a,int *b)
{
    int t=*a;
    *a=*b;
    *b=t;
}

void headify(int a[],int length,int i)
{
    int largest=i;
    int lchild=2*i+1;
    int rchlid=2*i+2;
    
    if(lchild<length&&a[lchild]>largest) largest=lchild;  //注意不要忘记左孩子不能超过长度范围
    
    if(rchlid<length&&a[rchlid]>largest) largest=rchlid;
    
    if(largest!=i)
    {
        swap(&a[i], &a[largest]);
        headify(a, length, largest);
    }
    
}


void headsort(int a[],int length)
{
    //每一个叶子结点都要调整一遍,才能建立初始堆
    
    for(int i=length/2-1;i>=0;i--)
    {
        headify(a, length, i);
    }
}

2018年

1.c语言程序设计部分

在这里插入图片描述

都很基本和经典,没什么好说的

2.数据结构程序设计部分

在这里插入图片描述

问题1:力扣上面那道重排链表

typedef  int Elemtype;
typedef struct ListNode
{
    Elemtype data;
    struct ListNode *next;
}ListNode;


void sort(ListNode *head)
{
    ListNode *fast=head;
    ListNode *slow=head;
    
    while(fast->next!=NULL&&fast->next->next!=NULL)
    {
        slow=slow->next;
        fast=fast->next->next;
    }
    ListNode *cut_off=slow;
    ListNode *cur=slow->next;  //把slow后面的那个结点存起来
    cut_off->next=NULL;
    
    
    //开始反转后一个链表
    ListNode *pre=NULL;
    while(cur!=NULL)
    {
        ListNode *p=cur->next; //存储cur指向的下一个结点
        cur->next=pre;
        pre=cur;
        cur=p;
    }   //循环结束后cur==NULL,此时pre指向反转后的第一个结点
    
    
    //开始链接
    ListNode *l1=head;
    ListNode *l2=pre;
    
   
    
    while(l1&&l2)
    {
        ListNode *n1=l1->next;
        ListNode *n2=l2->next;
        l1->next=l2; l2->next=n1;
        l1=n1;l2=n2;
    }
}

问题2:就是BFS记录层数,然后当找到这个结点的时候直接返回即可

BFS模版

BFS模版描述如下
创建一个队列,初始化一个队列
如果根节点不为空,将根节点加入到队列中
大循环如果队列不为空,则定义一个空指针,存储出队列的元素
将队列头出队,接下来,如果当前结点存在左孩子,或者右孩子,则将左右孩子加入到队列中。

假如,需要统计层数,则在大循环中,先计算当前层的结点数,利用循环队列计算当前队列的元素个数,这个就是每层的结点数
根据这个就可以确定结点的所在层数

结构体如下:

typedef int Elemtype;
typedef struct BiTNode
{
    Elemtype data;
    struct BiTNode *lLink;
    struct BiTNode *rLink;
    
}BiTNode,*BiTree;

代码如下:

int  BFS(BiTree T,Elemtype p) //函数返回值int,返回结点的层数
{
    Queue q;
    initqueue(&q); //初始化一个队列
    
    if(T!=NULL) enqueue(T,q); //将T结点入队
    
    int layer=1; //假定根节点为第一层
   while(is_empty(q))  //如果队列不为空则,进入循环
   {
       int size=(q.rear-q.front+queue_size)%queue_size; //计算当前循环队列中队列的个数
       
       for(int i=0;i<size;i++)
       {
           BiTNode *pNode=NULL;
           dequeue(q,&p); //将队列中的队头取出,将该节点的地址赋给p
           if(pNode->data==p) return layer;
           
           if(pNode->lLink!=NULL) enqueue(T->lLink,q);
           if(pNode->rLink!=NULL) enqueue(T->rLink,q);
       }
       layer++; //上一层全部出队,层数加一
   }
}

2019年

1.c语言程序设计部分

在这里插入图片描述

问题1:不用多说,送分题

问题2: 通过%4d %2d 画图设计出适合的形式

void table()
{
    int i, j;

       // 打印表头
       printf("  "); // 表头的左上角空白
       for (i = 1; i <= 9; i++) {
           printf("%4d", i); // 每个数字占4个字符宽度,保持对齐
       }
       printf("\n");
       
  

       // 打印加法表
       for (i = 1; i <= 9; i++) {
           // 打印行号
           printf("%2d", i); // 打印每行的行号和分隔符

           // 打印加法结果
           for (j = 1; j <= 9; j++) {
               printf("%4d", i + j); // 计算i + j并保持对齐
           }
           printf("\n"); // 每行结束后换行
       }

}

在这里插入图片描述
在这里插入图片描述

2.数据结构程序设计部分

1.写出二叉链表定义,并编写算法求二叉链表两个结点相距最远的距离。(一个节点到另一个节点所经历的分支个数)

问题分析:求两个结点之间路径最长的路径长度,通常叫做二叉树的直径,某一个点到它的叶子结点,该点到这个点,所经过的点肯定都不是最长的距离,假如这个点,既含有左子树,又含有右子树,左子树的叶子结点到右子树的叶子结点肯定比左子树到根结点的路径要长。

解决方法:考虑DFS
通过先序遍历,将二叉树左右子树的深度返回给他的根结点,同时也不要忘记比较二叉树左子树的深度+右子树的深度是否大于max{左子树的深度或者右子树的深度}

模版:求树的深度模版

 int MAX=0;
int depth(struct TreeNode* root)
{
     if(root==NULL) return 0; //如果子树为空,返回0

    int left_length=depth(root->left);
    int right_length=depth(root->right);

     int max=0;
    if(left_length>right_length) max=left_length;
    else max=right_length;
    if(left_length+right_length>MAX)MAX=left_length+right_length;

    return max+1; //加深本身该结点的深度
}

int diameterOfBinaryTree(struct TreeNode* root) {
    MAX=0; //注意在leetcode中MAX是局部变量,用的时候必须初始化为0
   depth(root);
   return MAX;
}

2.已知长度为n的线性表A采用顺序存储结构。
(1)写出线性表A的结构体
(2)设计一个时间复杂度为O(n),空间复杂度为O(1)的算法,将值为x的全部元素移动到A的后半部分

问题分析:
由于空间复杂度要求为1,所以不能添加新的存储空间,只能在原有的存储空间上移动,从前往后找值为x的数,从后往前找不为x的数,然后交换,采用静态存储结构即可完成该操作

typedef int ElemType;
#define MAXSIZE 1000
typedef struct seqlist
{
    Elemtype data[MAXSIZE];
    int length;
}seqlist;

void swap(Elemtype *a,Elemtype *b)
{
    int t=*a;
    *a=*b;
    *b=t;
}
void move(seqlist &seq,Elemtype x)
{
    int left=0;  //定义一个左指针
    int right=seq.length-1;  //定义一个右指针
    
    for(left=0;left<seq.length;left++)  //左指针都扫过一遍之后结束
    {
         if(seq.data[left]==x)  //如果左指针找到了x
         {
             while (seq.data[right==x]) {
                 right--;
             }  //得到了后面一个不等于x的值
             swap(&seq.data[left], &seq.data[right]);
         }
    }
}

2020年

1.C语言程序设计部分

1.请编写程序计算多项式s=1/1+1/(1+2)+…+1/(1+…+n),其中n由键盘进行输入
在这里插入图片描述

经典简单题目省略

2.数据结构程序设计部分

在这里插入图片描述
问题1:对于循环链表,左移k位之后,就是循环链表中第k+1个结点将会称为链表中第一个数据结点,所以只需要将头指针指向第k个结点,就能实现左移k的操作

问题二:就是BFS,计算一下最大值

2021年

1.C语言程序设计部分

1.银行账户信息包括:用户ID,姓名,密码,余额,写出账户信息结构体,并将数据存储在元素个数不超过90的结构体数组中,设计程序计算余额的平均值,并将余额大于平均值的账户信息输出打印。

2.输入一个数m,请编写程序计算sum=1-1/22-1/32-…-1/m2

都是比较经典的算法设计

2.数据结构程序设计部分

1.设计算法在有序单链表中删除重复元素e,使得单链表删除e后依然有序。

typedef int Elemtype;
typedef struct ListNode
{
    Elemtype data;
    struct ListNode *next;
}ListNode;

//该问题中,传入的单链表不含头结点
void delete_repeatnode(ListNode *&L)
{
    ListNode *pre=L;  //pre指向第一个结点
    ListNode *cur=L->next;  //指向第一个结点的后一个的指针,假如后一个和前一个相等,就把这后一个删除
    
    while(cur!=NULL)
    {
        if(cur->data==pre->data) //删除后一个
        {
            pre->next=cur->next;  //只有删除的时候pre指针才发生变化,否则不动
        }else
        {
            pre=pre->next;
        }
        
        cur=cur->next;
    }
}

2.设计算法在二叉排序树中查找第k大的结点

二叉排序树遍历模版-中序遍历得到有序序列,注意保存它的结点地址

补一个代码刨析:

这道题很明显是二叉排序树的中序遍历问题,找到第k个结点
由于返回值是指针类型,在写遍历模版的时候,要把返回值存下来
处理返回值的关键在于根节点的处理,根节点(子树根节点)是怎么返回的,这是关键。
通过思考来补全整个结果,找到这个结点后,不往下遍历了,else右子树,假如答案是在某个右子树中,return也把答案传回去,而且该循环结束
假如答案是在某个左子树中,return之后,接下来的操作都是没有意义的,甚至还会继续执行遍历右子树,最后会返回一个空,所以必须扼杀于此,所以判断是否找到了,如果找到了,就直接返回,不执行后面的操作。

BiTNode * funtion_k(BiTree T,int *k) //输入的输出的树的根节点,和第k大,返回值是第k大的结点指针
{
    if(T==NULL)return NULL;
    
    BiTNode *left_result=funtion_k(T->lchild, k);
    if(left_result!=NULL)return left_result;//或者if(*k==0)return left_result;
  
  
    
    (*k)--;
    if(*k==0)
    {
        return T;
    }else
    {
        return funtion_k(T->rchild, k);
    }
    
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2208619.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《RabbitMQ篇》消息应答和发布确认

消息应答 消息应答机制&#xff1a;消费者接收信息并处理完之后&#xff0c;告诉rabbitmq该信息已经处理&#xff0c;rabbitmq可以把该信息删除了. 消息自动重新入队&#xff1a;如果处理某个消息的消费者异常关闭了&#xff0c;没有发送ACK确认&#xff0c;rabbitmq会将其重…

GEE 高阶应用:eeExtra包(Python、R、julia和JavaScript API)

目录 简介 功能 它是如何工作的? 安装 功能 缩放和偏移 光谱指数 STAC features JavaScript API模型 简介 Google Earth Engine (GEE) 是一个基于云的服务,用于矢量和栅格数据的地理空间处理。Earth Engine 平台具有 JavaScript 和 Python API,提供不同的方法来处…

STM32学习--5-2 旋转编码器计次

接线图 按键按下&#xff0c;旋转编码器输出低电平 Encoder.c #include "stm32f10x.h" // Device headerint16_t Encoder_Count; void Encoder_init(void) {RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE); // 开启APB2Periph外设GPIOB时钟…

Palo Alto Networks Expedition 未授权SQL注入漏洞复现(CVE-2024-9465)

0x01 产品简介 Palo Alto Networks Expedition 是一款强大的工具,帮助用户有效地迁移和优化网络安全策略,提升安全管理的效率和效果。它的自动化功能、策略分析和可视化报告使其在网络安全领域中成为一个重要的解决方案。 0x02 漏洞概述 Palo Alto Networks Expedition中存…

一键生成证件照_HivisionIDPhotosv1.2.8整合包

HivisionIDPhoto&#xff1a;智能证件照制作 HivisionIDPhoto 专注于开发一套实用且系统化的智能证件照制作算法&#xff0c;旨在为用户提供快速、准确的证件照生成服务。通过完整的 AI 模型流程&#xff0c;HivisionIDPhoto 能够识别多种拍照场景&#xff0c;精准抠图&#x…

牛客SQL练习详解 06:综合练习

牛客SQL练习详解 06&#xff1a;综合练习 SQL34 统计复旦用户8月练题情况SQL35 浙大不同难度题目的正确率SQL39 21年8月份练题总数 叮嘟&#xff01;这里是小啊呜的学习课程资料整理。好记性不如烂笔头&#xff0c;今天也是努力进步的一天。一起加油进阶吧&#xff01; SQL34 统…

手撕数据结构 —— 带头双向循环链表(C语言讲解)

目录 0.前言 1.什么是带头双向循环链表 理解带头 ​编辑 理解双向 理解循环 2.带头双向循环链表的实现 List.h文件中接口总览 具体实现 结点的定义 申请结点 初始化 打印链表 尾插 尾删 头插 头删 ​编辑​编辑 获取大小 查找 在指定位置前插入 ​编辑…

初知C++:AVL树

文章目录 初知C&#xff1a;AVL树1.AVL树的概念2.AVL树的是实现2.1.AVL树的结构2.2.AVL树的插入2.3.旋转2.4.AVL树的查找2.5.AVL树平衡检测 初知C&#xff1a;AVL树 1.AVL树的概念 • AVL树是最先发明的自平衡⼆叉查找树&#xff0c;AVL是⼀颗空树&#xff0c;或者具备下列性…

中国剩余定理 C++

题目 解题思路 原链接&#xff1a;https://www.acwing.com/solution/content/3539/ 大致步骤&#xff1a; 将第2,3,4…n个方程不断与第一个方程合并&#xff0c;得到方程a1k1a2k2m2-m1;用扩展欧几里得算法解出a1k1a2k2gcd(a1, a2)的结果&#xff0c;再将结果扩大(m2-m1)/d倍即…

2-laravel-路由配置

文章目录 定义控制器设计控制器设置路由启动服务 基本路由视图路由建立视图路由建立视图文件 控制器视图路由创建视图二级目录控制器 定义控制器 打开laravel 工程 建立一个 Demo 名字的控制器去集成 模板控制器 安装两个插件 设计控制器 <?phpnamespace App\Http\…

关于电动自行车新增的通信功能要求如下

1、 电动自行车应具有采用TLS加密的4G或5G公网通信模块&#xff0c;或类似功能的地面通信模块。 注:根据我国无线电管理有关规定&#xff0c;可能需要对无线电发射模块或整车进行无线电发射设备型号核准。 2、通信模块具备向电动自行车管理平台发送以下动态安全监测信息的功能&…

SpringBoot项目升级JDK版本(1.8 => 17)

项目&#xff1a;这里使用gitee上一个开源项目做测试《SpringBoot 流媒体项目》 工具&#xff1a;Intellij IDEA 一、下载项目&#xff08;git clone …&#xff09; 1、打开 pom.xml 看一下 2、启动项目&#xff0c;记住它最原本的样子先。成功启动后控制台后面是会输出地址…

怎么进行智能配音?一文告诉你

如何给文字智能配音呢&#xff1f;将文字转化为生动的语音&#xff0c;是提升内容吸引力的有效方式。 无论是制作视频、音频课程还是电子读物&#xff0c;合适的配音都能让信息传递更加高效。 如果你正寻找简单易用的方法来给文字添加配音&#xff0c;这里有几款智能配音软件…

0基础能不能转行做网络安全?

0基础能不能转行做网络安全&#xff1f;网络安全人才发展路线 最近有同学在后台留言&#xff0c;0基础怎么学网络安全&#xff1f;0基础可以转行做网络安全吗&#xff1f;以前也碰到过类似的问题&#xff0c;想了想&#xff0c;今天简单写一下。 我的回答是先了解&#xff0c…

Java对接ModbusRTU协议案例测试(相关代码及调试工具使用)

目的 在无设备的情况下&#xff0c;电脑搭建虚拟环境&#xff0c;进行代码编写以及测试 准备工作 一.测试工具 1.模拟虚拟串口工具&#xff0c;modbus RTU使用一问一答模式进行数据交互。 本文内容&#xff1a;模拟主站从站发送读取数据 2.个人设置&#xff1a;COM10为主站&am…

simulink分段函数

两段函数 20<v<60为真时&#xff0c;输出0.8 20<v<60为假时&#xff0c;即v<20或v>60时&#xff0c;输出0v>20时&#xff0c;输出0.8 v<20时&#xff0c;输出0 n段函数 n-1个switch模块

d3dcompiler_43.dll 文件的缺失常见方法分析,一键修复d3dcompiler_43.dll

在使用电脑的过程中&#xff0c;d3dcompiler_43.dll 文件的缺失是一个常见的技术挑战&#xff0c;这一问题通常会影响到基于Direct3D技术的应用程序的正常运行&#xff0c;可能导致程序启动失败或运行错误。d3dcompiler_43.dll 是DirectX组件的一部分&#xff0c;专责于编译用于…

CLIP图文多模态模型onnxruntime和tensorrt推理

首先下载github项目&#xff1a;https://github.com/Lednik7/CLIP-ONNX 修改clip_onnx/utils.py第61行opset_version12为opset_version15 , 运行测试脚本&#xff1a; import clip from PIL import Image import numpy as np# ONNX不支持CUDA model, preprocess clip.load(&q…

FFmpeg的简单使用【Windows】--- 视频倒叙播放

实现功能 点击【选择文件】按钮可以选择视频&#xff0c;当点击【开始处理】按钮之后&#xff0c;会先将视频上传到服务器&#xff0c;然后开始进行视频倒叙播放的处理&#xff0c;当视频处理完毕之后会将输出的文件路径返回&#xff0c;同时在页面中将处理好的视频展示出来。…

SpringBoot Data JPA基本使用

一、项目起步 1.1 pom配置 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId> </dependency><dependency><groupId>org.springframework.boot</groupId><…