CS50x 2024 - Lecture 3 - Algorithms

2024-02-11 03:52
文章标签 2024 lecture algorithms cs50x

本文主要是介绍CS50x 2024 - Lecture 3 - Algorithms,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

TABLE OF CONTENTS

00:00:00 - Introduction

一种统计班上人数的方法,全部站起来,两两配对,一个坐下,循环

00:01:01 - Overview

00:02:58 - Attendance

00:09:40 - Linear Search

00:24:58 - Binary Search 二分搜索

分而治之的方法

00:28:25 - Running Time

代表这些算法的效率
在这里插入图片描述
使用的算法将被描述为这些运动时间之一的数量级

大O代表可能计算步数的上限,考虑的是最坏的情况

O(1)代表恒定的步数,恒定时间算法
O(n) 线性搜索,一页一页翻书
O(n2) n个人与其他所有人握手

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

00:38:06 - search.c

#include <stdio.h>
#include <cs50.h>
#include <string.h>int main() {string str[] = {"apple", "tree", "dog", "cat", "captital", "aoxue"};string n = get_string("input a string:");for (int i = 0; i < 6; i++) {if(strcmp(str[i], n) == 0) {printf("found\n");return 0;}}printf("not found\n");return 1;
}

00:51:29 - phonebook.c

#include <stdio.h>
#include <cs50.h>
#include <string.h>int main(void) {string names[] = {"dc", "aoxue", "bubu", "pikaqiu"};string numbers[] = {"1818198", "11333","4343455", "5465356"};string n = get_string("input a name:");for (int i = 0; i< 4; i++) {if (strcmp(names[i], n) == 0) {printf("found %s\n", numbers[i]);return 0;}}printf("not found\n");return 1;}

即使在英语中被称为数字,也应该用字符串存储
显然以上这样的code smell不对,不应该将名字和数字分开

00:53:42 - Structs

typedef意味着定义以下数据类型,我要发明这个数据类型

#include <stdio.h>
#include <cs50.h>
#include <string.h>typedef struct {string name;string number;
}person;
int main(void) {// person people[3];// people[0].name = "dc";// people[0].number = "1919191";// people[1].name = "aoxue";// people[1].number = "423423";// people[2].name = "bubu";// people[2].number = "534543";person people[3] = {{"dc", "1919191"},{"aoxue", "423423"},{"bubu", "534543"}};string n = get_string("input a name:");for (int i = 0; i< 3; i++) {if (strcmp(people[i].name, n) == 0) {printf("found %s\n", people[i].number);return 0;}}printf("not found\n");return 1;}

01:05:26 - Sorting

每次都检查整个列表,选择最小元素

01:12:43 - Selection Sort

在这里插入图片描述
脑子一次只记得一个元素
在这里插入图片描述

01:24:50 - Bubble Sort 冒泡排序

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

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

一次次比较邻接关系

01:33:10 - Recursion 递归

在这里插入图片描述
该搜索函数正在调用自身,只要有终止条件(基本情况),可以打破无限循环

是对调用自身的函数的描述

iterration.c

#include <stdio.h>
#include <cs50.h>void draw(int n);int main() {int height = get_int("input the height:");draw(height);}void draw(int n) {for (int i = 0; i < n; i++) {for (int j =0; j < i+1; j++) {printf("*");}printf("\n");}
}

recursion.c

#include <stdio.h>
#include <cs50.h>void draw(int n);int main() {int height = get_int("input he height:");draw(height);
}void draw(int n) {if(n <= 0) {return;}draw(n - 1);for (int i = 0; i < n; i++) {printf("*");}printf("\n");
}

01:46:28 - Merge Sort 合并排序

在这里插入图片描述
选择排序和冒泡排序只允许自己使用恒定的内存,在计算机科学中,可以用一种资源换另一种资源,想节约时间,就扩展空间在这里插入图片描述

02:00:23 - Sort Race

这篇关于CS50x 2024 - Lecture 3 - Algorithms的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/698762

相关文章

创新、引领、发展——SAMPE中国2024年会在京盛大开幕

绿树阴浓夏日长,在这个色彩缤纷的季节,SAMPE中国2024年会暨第十九届国际先进复合材料制品原材料、工装及工程应用展览会在中国国际展览中心(北京朝阳馆)隆重开幕。新老朋友共聚一堂,把酒话桑麻。 为期4天的国际学术会议以“先进复合材料,引领产业创新与可持续化发展”为主题,设立了34个主题分会场,其中包括了可持续化会场、国际大学生会场、中法复合材料制造技术峰会三个国际会场和女科技工作者委员会沙龙,

2024年6月24日-6月30日(ue独立游戏为核心)

试过重点放在独立游戏上,有个indienova独立游戏团队是全职的,由于他们干了几个月,节奏暂时跟不上,紧张焦虑了。五一时也有点自暴自弃了,实在没必要,按照自己的节奏走即可。精力和时间也有限,放在周末进行即可。除非哪天失业了,再也找不到工作了,再把重心放在独立游戏上。 另外,找到一个同样业余的美术,从头做肉鸽游戏,两周一次正式交流即可。节奏一定要放慢,不能影响正常工作生活。如果影响到了,还不如自

潜艇伟伟迷杂交版植物大战僵尸2024最新免费安卓+ios苹果+iPad分享

嗨,亲爱的游戏迷们!今天我要给你们种草一个超有趣的游戏——植物大战僵尸杂交版。这款游戏不仅继承了原有经典游戏的核心玩法,还加入了许多创新元素,让玩家能够体验到前所未有的乐趣。快来跟随我一起探索这个神奇的世界吧! 植物大战僵尸杂交版最新绿色版下载链接: https://pan.quark.cn/s/d60ed6e4791c 🔥 创新与经典的完美结合 植物大战僵尸杂交版在保持了原游戏经典玩

Chromium 调试指南2024 - 远程开发(下)

1. 引言 在《Chromium 调试指南2024 - 远程开发(上)》中,我们探讨了远程开发的基本概念、优势以及如何选择合适的远程开发模式。掌握了这些基础知识后,接下来我们将深入了解如何在远程环境中高效地进行Chromium项目的调试工作。 调试是开发过程中至关重要的一环,特别是对于像Chromium这样复杂的大型项目。远程调试不仅可以充分利用远程服务器的强大计算资源,还能确保开发环境的一致

【2024最新版】Java JDK安装配置全攻略:图文详解

目录 1. 引言2. 准备工作2.1 **确定操作系统**2.2 **检查系统要求**2.3 **下载JDK安装包**3. 安装步骤(以Windows系统为例)4. 配置环境变量4.1 jdk配置验证4.2 **配置JAVA_HOME环境变量**4.3 **配置Path环境变量**4.4 验证jdk是否配置成功 5. 结语 1. 引言 随着技术的不断发展和更新,Java作为世界上

【团队成长】2024-25周周报-业务介绍内容创作

大家好!我们是IndustryOR 团队,致力于分享业界落地的算法技术。欢迎关注微信公众号/知乎/CSDN【运筹匠心】 。 记录人:张哲铭,某互联网大厂算法专家 【团队成长/个人成长】系列的推文会以 【工作周报】 的方式记录IndustryOR团队及其成员的成长过程,请大家一起见证和参与我们团队从0-1-N的发展过程。 记录人顺序:张哲铭-向杜兵-高欣甜-黄世鸿-许佳鸣

2024老年护理新前沿:养老实训室的创新应用

随着人口老龄化的加速,如何为老年人提供优质的养老服务已成为社会关注的重点。在这一背景下,养老实训室应运而生,成为培养专业养老人才、改善老年人生活质量的新兴平台。与传统的课堂教学相比,养老实训室能够为学员提供更为生动、贴近实际的培训体验,为老年护理事业注入创新动力。 一、养老实训室的功能优势 模拟真实环境,提升操作技能 养老实训室通过还原老年人的居住环境,如卧室、浴室等,让学员能实际操作各种日

湖北民族大学2024年成人高等继续教育招生简章

湖北民族大学,这所承载着深厚文化底蕴和卓越教育理念的学府,在崭新的2024年再次敞开怀抱,热烈欢迎有志于深化学习、提升自我的成人学员们。今年的成人高等继续教育招生,不仅是学校对于终身教育理念的具体实践,更是为广大社会人士提供了一次难得的学习机会。 湖北民族大学,以其悠久的历史、优秀的师资和卓越的教学质量,早已在成人教育领域树立了良好的口碑。学校秉承“博学、博爱、立人、达人”的校训,致力于培养

▶《强化学习的数学原理》(2024春)_西湖大学赵世钰 Ch5 蒙特卡洛方法【model-based ——> model-free】

PPT 截取必要信息。 课程网站做习题。总体 MOOC 过一遍 1、视频 + 学堂在线 习题 2、 过 电子书 是否遗漏 【下载:本章 PDF GitHub 页面链接 】 【第二轮 才整理的,忘光了。。。又看了一遍视频】 3、 过 MOOC 习题 看 PDF 迷迷糊糊, 恍恍惚惚。 学堂在线 课程页面链接 中国大学MOOC 课程页面链接 B 站 视频链接 PPT和书籍下载网址: 【Gi

2023-2024 学年第二学期小学数学六年级期末质量检测模拟(制作:王胤皓)(90分钟)

word效果预览: 一、我会填 1. 1.\hspace{0.5em} 1. 一个多位数,亿位上是次小的素数,千位上是最小的质数的立方,十万位是 10 10 10 和 15 15 15 的最大公约数,万位是最小的合数,十位上的数既不是质数也不是合数,这个数是 ( \hspace{4em} ),约等于 ( \hspace{1em} ) 万 2. 2.\hspace{0.5em} 2.