搜索

CS-第 3 周

Jan 03, 2025 pm 07:15 PM

算法是一组以特定顺序给出的用于解决问题的指令。算法的速度和占用内存量有所不同。在编程过程中,大多数算法都是基于数据搜索(搜索)和排序(排序)。让我们来熟悉一下数据检索算法:

线性搜索(线性搜索)

让我们得到以下数组:

[20, 500, 10, 5, 100, 1, 50]

当可视化一个数组时,它可以被视为七个并排的红色柜子,如下所示:

CS- Week 3

我们需要从这个数组中找到 50 个数字。计算机必须检查每个储物柜才能找到数字 50。我们称这个过程为在数组中搜索特定的数字、字符或其他元素“搜索”.
我们可以将数组传递给算法,并要求算法打开橱柜并确定数字 50 是否存在。结果,算法将回答我们“是”“否”(正确或错误)。

CS- Week 3

我们可以使用以下指令构建算法:

Chapdan o‘ngga har bir eshikni tekshirish:
    Agar 50 soni bor bo‘lsa:
        Ha deb qaytaramiz (return true)
Yo‘q deb qaytaramiz (return false)

上面的说明是人类可读的伪代码,是向计算机发出的命令的更简单表示。

我们可以使用以下代码在 C 中实现线性搜索算法:

#include <cs50.h>
#include <stdio.h>

int main(void)
{
    // Butun sonlardan iborat massiv berilgan
    int numbers[] = {20, 500, 10, 5, 100, 1, 50};

    // Kiritilgan sonni massivdan qidiramiz
    int n = get_int("Number: ");
    for (int i = 0; i 



<p>这里使用 for 循环执行线性搜索。<br>
return 0 表示程序成功结束,程序退出。<br>
return 1 - 表示程序中发生错误。</p>

<hr>
<h2>
  
  
  二分查找
</h2>

<p><em>二分查找</em>是另一种用于搜索数字 50 的算法。<br>
如果数组中的值按升序排序,我们可以给出二分查找的伪代码如下:<br>
</p>

<pre class="brush:php;toolbar:false">Agar tekshiriladigan element qolmagan bo‘lsa:
    Yo‘q deb qaytaramiz (return false)
Agar massivning[o‘rta elementi] 50 soniga teng bo‘lsa:
    Ha deb qaytaramiz (return true)
Agar massivning[o‘rta elementi] > 50:
    Massivning chap yarmidan qidiramiz
Agar massivning[o‘rta elementi] 




<hr>

<h2>
  
  
  大O表示法
</h2>

<p><strong>大O</strong> <strong>符号</strong>用于分析运行算法所需的时间。我们来看下图:</p>

<p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/173590294458453.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="CS- Week 3"></p>

<p><em>“输入数据大小”</em> – x 轴; <em>“求解时间”</em> – y 轴;<br>
算法的效率由其曲线的形状决定:<br>
O(n²) 是最差性能时间。<br>
O(log n) 是最快的执行时间。</p><p>线性搜索算法的运行时间是 O(n),因为在最坏的情况下可能需要 n 步。<br>
而二分查找算法工作的时间是O(log n),因为在最坏的情况下,步数会越来越少。</p>

<p>程序员感兴趣的有两种情况:</p>

  • 最坏情况或上限(上限)
  • 最佳情况或下限(下限)
符号

Ω 用于表示算法的最佳情况 (下界),例如 Ω(n)。

符号

TH表示上下界相同的情况,即最好和最差运行时间相同。


排序算法(Sorting)

排序是将无序值列表更改为有序值的过程。
当数组排序后,计算机可以更轻松地搜索其中的特定元素。例如,二分搜索 (二分搜索) 适用于已排序的数组,但不适用于未排序的数组。

排序算法有很多种。让我们考虑其中之一选择排序 (选择排序)。让我们得到一个像这样的数组:

CS- Week 3

选择方法算法的伪代码如下:

[20, 500, 10, 5, 100, 1, 50]

步骤分析:

  • 第一次遍历数组元素需要 n - 1 步。
  • 第二次需要n - 2步。
  • 继续这个逻辑,所需的步骤可以表示为:
Chapdan o‘ngga har bir eshikni tekshirish:
    Agar 50 soni bor bo‘lsa:
        Ha deb qaytaramiz (return true)
Yo‘q deb qaytaramiz (return false)

简化这个公式,我们得到:n(n-1)/2 或 O(n²)。
因此,选择方法的算法在最坏情况下按 O(n²) 顺序排序。即使所有值都已排序,步数也不会改变,因此最好的情况是 O(n²) 顺序。


冒泡排序算法(Bubble sort)

冒泡排序是另一种排序算法,我们通过重复排列元素来“提升”更大的值

冒泡排序算法的伪代码如下:

#include <cs50.h>
#include <stdio.h>

int main(void)
{
    // Butun sonlardan iborat massiv berilgan
    int numbers[] = {20, 500, 10, 5, 100, 1, 50};

    // Kiritilgan sonni massivdan qidiramiz
    int n = get_int("Number: ");
    for (int i = 0; i 



<p>当我们对数组进行排序时,我们知道更多的数组将被排序,因此我们只需要检查尚未排序的对。<br>
因此,如果数组未排序,冒泡排序算法在最坏的情况下工作 O(n²),如果数组已排序,则在最好的情况下工作 O(n)。</p>
<p>我们可以在此页面直观地看到排序算法是如何工作的。</p>

<blockquote>
<p>本文使用 CS50x 2024 源码。</p>
</blockquote>


          

            
        </stdio.h></cs50.h>

以上是CS-第 3 周的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
在C中掌握多态性:深度潜水在C中掌握多态性:深度潜水May 14, 2025 am 12:13 AM

掌握C 中的多态性可以显着提高代码的灵活性和可维护性。 1)多态性允许不同类型的对象被视为同一基础类型的对象。 2)通过继承和虚拟函数实现运行时多态性。 3)多态性支持代码扩展而不修改现有类。 4)使用CRTP实现编译时多态性可提升性能。 5)智能指针有助于资源管理。 6)基类应有虚拟析构函数。 7)性能优化需先进行代码分析。

C Destructors vs垃圾收集器:有什么区别?C Destructors vs垃圾收集器:有什么区别?May 13, 2025 pm 03:25 PM

C DestructorSprovidePreciseControloverResourCemangement,whergarBageCollectorSautomateMoryManagementbutintroduceunPredicational.c Destructors:1)允许CustomCleanUpactionsWhenObextionsWhenObextSaredSaredEstRoyed,2)RorreasereSouresResiorSouresiorSourseResiorMeymemsmedwhenEbegtsGoOutofScop

C和XML:在项目中集成数据C和XML:在项目中集成数据May 10, 2025 am 12:18 AM

在C 项目中集成XML可以通过以下步骤实现:1)使用pugixml或TinyXML库解析和生成XML文件,2)选择DOM或SAX方法进行解析,3)处理嵌套节点和多级属性,4)使用调试技巧和最佳实践优化性能。

在C中使用XML:库和工具指南在C中使用XML:库和工具指南May 09, 2025 am 12:16 AM

在C 中使用XML是因为它提供了结构化数据的便捷方式,尤其在配置文件、数据存储和网络通信中不可或缺。1)选择合适的库,如TinyXML、pugixml、RapidXML,根据项目需求决定。2)了解XML解析和生成的两种方式:DOM适合频繁访问和修改,SAX适用于大文件或流数据。3)优化性能时,TinyXML适合小文件,pugixml在内存和速度上表现好,RapidXML处理大文件优异。

C#和C:探索不同的范例C#和C:探索不同的范例May 08, 2025 am 12:06 AM

C#和C 的主要区别在于内存管理、多态性实现和性能优化。1)C#使用垃圾回收器自动管理内存,C 则需要手动管理。2)C#通过接口和虚方法实现多态性,C 使用虚函数和纯虚函数。3)C#的性能优化依赖于结构体和并行编程,C 则通过内联函数和多线程实现。

C XML解析:技术和最佳实践C XML解析:技术和最佳实践May 07, 2025 am 12:06 AM

C 中解析XML数据可以使用DOM和SAX方法。1)DOM解析将XML加载到内存,适合小文件,但可能占用大量内存。2)SAX解析基于事件驱动,适用于大文件,但无法随机访问。选择合适的方法并优化代码可提高效率。

c在特定领域:探索其据点c在特定领域:探索其据点May 06, 2025 am 12:08 AM

C 在游戏开发、嵌入式系统、金融交易和科学计算等领域中的应用广泛,原因在于其高性能和灵活性。1)在游戏开发中,C 用于高效图形渲染和实时计算。2)嵌入式系统中,C 的内存管理和硬件控制能力使其成为首选。3)金融交易领域,C 的高性能满足实时计算需求。4)科学计算中,C 的高效算法实现和数据处理能力得到充分体现。

揭穿神话:C真的是一种死语吗?揭穿神话:C真的是一种死语吗?May 05, 2025 am 12:11 AM

C 没有死,反而在许多关键领域蓬勃发展:1)游戏开发,2)系统编程,3)高性能计算,4)浏览器和网络应用,C 依然是主流选择,展现了其强大的生命力和应用场景。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器