2024-2025-1 20241314 《计算机基础与程序设计》第七周学习总结

news/2025/1/21 3:01:02/文章来源:https://www.cnblogs.com/serene99/p/18537844

2024-2025-1 20241314 《计算机基础与程序设计》第七周学习总结

作业信息

这个作业属于哪个课程 <班级的链接>2024-2025-1-计算机基础与程序设计
这个作业要求在哪里 2024-2025-1计算机基础与程序设计第七周作业
这个作业的目标 数组与链表 基于数组和基于链表实现数据结构 无序表与有序表 树 图 子程序与参数
作业正文 正文

教材学习内容总结

计算机科学概论(第七版)第1章

《计算机科学概论(第七版)》第8章通常讨论的是计算机网络和互联网的基本概念。以下是该章的一些关键要点概括:

计算机网络的定义:介绍什么是计算机网络,以及它们如何将不同的计算机和设备连接在一起,以实现数据通信和资源共享。

网络的类型:讨论不同类型的网络,包括局域网(LAN)、广域网(WAN)和城域网(MAN),并解释其特点和应用场景。

网络协议:讲解网络通信中使用的各种协议,如TCP/IP(传输控制协议/互联网协议),以及怎样通过这些协议来确保数据的可靠传输。

网络架构:介绍网络的层次结构,包括物理层、数据链路层、网络层、传输层和应用层等,帮助读者理解各层在网络运作中的角色。

互联网及其发展:概述互联网的历史、发展和现状,包括应用程序(如HTTP、FTP等)及其在日常生活中的重要性。

网络安全:探讨网络安全的基本概念和措施,包括防火墙、加密技术和网络攻击类型等,以提高对网络安全的意识。

新兴技术:介绍一些新兴的网络技术和趋势,如物联网(IoT)、云计算和5G技术等,讨论它们如何影响未来的计算机网络。

《C语言程序设计》第6章

指针的定义和使用:介绍指针的基本概念,包括指针的声明、初始化和解引用。讲解指针在程序中的作用以及如何通过指针来访问和修改变量的值。

指针与数组:解释指针与数组之间的关系,包括如何使用指针来操作数组元素,指针算术运算等。

函数指针:介绍函数指针的概念,解释如何定义和使用函数指针,以实现回调函数和简化代码结构等。

动态内存分配:讲解如何使用 malloc、calloc、realloc 和 free 函数进行动态内存分配和管理,强调如何有效地管理内存以避免内存泄漏。

结构体与指针的结合:介绍如何使用指针来处理结构体,包括结构体指针的定义、赋值和访问结构体成员。

指针的数组和指针的指针:讨论指向指针的指针(双重指针)及其在某些程序设计中的应用场景。

常见错误和调试技巧:提醒读者在使用指针时常见的错误(例如:空指针引用、野指针等),以及如何调试和防止这些错误。

教材学习中的问题和解决过程

问:汉诺塔问题
答:汉诺塔问题是一个经典的递归问题,最早由法国数学家爱德华·卢卡斯在1883年提出。问题的叙述如下:

有三根柱子,A、B、C,初始时,所有的盘子按照从大到小的顺序叠放在柱子A上。目标是将这些盘子全部移动到柱子C上,要求遵循以下规则:

一次只能移动一个盘子。
任何时候都不能将较大的盘子放在较小的盘子上。
可以使用柱子B作为辅助柱子。
问题解决思路:

将n-1个盘子从柱子A移动到柱子B,使用柱子C作为辅助柱子。
将第n个盘子(最大的盘子)直接从柱子A移动到柱子C。
将n-1个盘子从柱子B移动到柱子C,使用柱子A作为辅助柱子。

C语言实现汉诺塔问题

#include <stdio.h>

void hanoi(int n, char source, char target, char auxiliary) { if (n == 1) {
printf("Move disk 1 from %c to %c\n", source, target); return; } hanoi(n - 1, source, auxiliary, target); // Step 1: Move n-1 disks to auxiliary
printf("Move disk %d from %c to %c\n", n, source, target); // Step 2: Move the nth disk
hanoi(n - 1, auxiliary, target, source); // Step 3: Move n-1 disks from auxiliary to target }

int main() { int n; // Number of disks printf("Enter the number of disks: "); scanf("%d", &n);
hanoi(n, 'A', 'C', 'B'); // A is source, C is target and B is auxiliary return 0; }
问:为什么有的问题只能用递归解决
答:自我相似性:

许多问题具有自我相似的特性,即问题的某个部分与整体问题形式相似。在这种情况下,递归允许我们简化问题,将其分解为相同类型的子问题(例如,汉诺塔、树的遍历等)。
复杂结构处理:

递归非常适合处理复杂的数据结构,例如树和图。对于树的遍历、图的搜索(如深度优先搜索)等问题,递归提供了简单直观的解决方案。
简化逻辑:

递归通常可以大大简化代码逻辑。例如,在处理分治算法(如归并排序、快速排序)时,递归使得实现过程更为清晰,而使用迭代可能需要更复杂的状态管理。
基于分治法:

许多算法基于分治策略,解决一个大问题的过程是将其分解为更小的相似问题。这种情况下,递归是实现分治算法的自然选择,因为每次递归调用都在处理一个更小的子问题(如合并排序)。
状态追踪问题:

在解决问题时,递归可以通过函数调用栈自动管理状态。例如,在解决问题时需要追踪路径、深度等智能信息,递归可以自然地保留这些状态而无需额外的全局变量。

基于AI的学习










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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二进制和格雷码转换

二进制和格雷码转换 二进制转为格雷码//根据二进制转换成格雷码的法则,可以得到以下的代码: static unsigned int DecimaltoGray(unsigned int x) {return x^(x>>1); }//以上代码实现了unsigned int型数据到格雷码的转换,最高可转换32位自然二进制码,超出32位将溢出。…

在鸿蒙NEXT中开发一个2048小游戏

本项目是基于api12开发的2048游戏,游戏的逻辑是当用户向某个方向滑动时,将该方向相邻且相等的数字相加,同时在空白区域的随机位置生成一个随机数字。游戏中的数字越大,分数越高。首先,游戏的界面布局分别采用两个网格组件Grid来实现,难点在于上方的菜单栏是不均等的三种尺…

nginx 整体架构

Nginx 是什么 Nginx 是一款 C 语言编写高性能 Web 服务器,反向代理服务器。占用内存少、并发能力强 使用场景 nginx主要有以下 4 个使用场景作为 Http 服务器,可以提供静态网页和静态资源的访问 HTTP代理缓存,缓存服务端请求数据 作为反向代理服务器,将请求代理转发 作为负…

[CISCN2019 华北赛区 Day2 Web1]Hack World 1

[CISCN2019 华北赛区 Day2 Web1]Hack World 1 打开实例发现是个POST注入框盲猜SQL注入,万能密码检测无果,而且经过测试存在大量sql关键字过滤尝试使用(),出现了bool(false),确定这是一道布尔注入题and被禁用,决定采用异或^注入 构建payload脚本梭哈:成功获得flag:flag{a2…

2024 AH CSP-S 迷惑行为大赏

洛谷专栏阅读:https://www.luogu.com.cn/article/0atx674s 一、概述 观前提示:本届CSP-S安徽省整活相较于其他省份不是那么“群英荟萃”,观看前请不要小零食(?) 本届CSP-S安徽共有1013人参赛,其中有效准考证号源文件夹共有1006个,7人因为种种原因最终没有留下任何参赛痕…

LeNet-5卷积神经网络的实现与改进-实验报告

摘要 在本次实验中,我实现了LeNet-5卷积神经网络模型的构建与训练,以实现图像分类任务。主模型采用Pytorch框架搭建,模型识别准确率达到了87%,体现了较好的分类效果。除此之外,我还尝试使用C++实现模型的底层核心操作,包括卷积、池化及全连接等,但最终准确率较低,未达预…

【Mplus 8.7软件下载与安装教程】

1、安装包 Mplus 8.7: 链接:https://pan.quark.cn/s/128e81c51dbe 提取码:1X7B Mplus 8.3: 链接:https://pan.quark.cn/s/5ea5ff583480 提取码:Vdjt Mplus 7.4: 链接:https://pan.quark.cn/s/414ec0c8cb14 提取码:8jhm 2、安装教程 1) 双击Mplus8.7 Demo(64-bi…

Day13 备战CCF-CSP练习

202312-3Day 13 题目描述 题目分析 大模拟,用栈储存每一个多项式,最后根据导数的加法原则依次求导相加,注意取模。 C++代码 #pragma GCC optimize(3, "Ofast", "inline") #include <bits/stdc++.h> #define int long longusing namespace std; co…

OOP实验三

任务1: 源码:1 #pragma once2 3 #include <iostream>4 #include <string>5 6 using std::string;7 using std::cout;8 9 // 按钮类 10 class Button { 11 public: 12 Button(const string &text); 13 string get_label() const; 14 void click()…

鸿蒙NEXT开发案例:转盘1W

【1】引言(完整代码在最后面) 在鸿蒙NEXT系统中,开发一个有趣且实用的转盘应用不仅可以提升用户体验,还能展示鸿蒙系统的强大功能。本文将详细介绍如何使用鸿蒙NEXT系统开发一个转盘应用,涵盖从组件定义到用户交互的完整过程。 【2】环境准备 电脑系统:windows 10 开发工…

开源 - Ideal库 - 常用时间转换扩展方法(二)Qv

合集 - Ideal库 - Common库(2)1.开源 - Ideal库 - 常用时间转换扩展方法(一)11-07:悠兔机场2.开源 - Ideal库 - 常用时间转换扩展方法(二)11-09收起 书接上回,我们继续来分享一些关于时间转换的常用扩展方法。01、时间转日期时间 TimeOnly 该方式是把TimeOnly类型转为Date…

存储器的知识

以W25Q256为例子(外部Flash),结构如下:扇区的内部结构以F10系列为例子 64位代表的是8个字节的数据,一个地址最多可以存储8个字节的数据(double数据类型就是8个字节),4k,16k,64k,32k代表的是地址的总数,主存储块又可以分为很多个页,页里面也有存储的空间大小嵌入式闪存的组成