阅读时我们的大脑里究竟发生了什么——文本理解中的知识激活现象
你是否有这样的经历:阅读一本翻译质量不太理想的书籍时,虽然某些句子读起来不够通顺,但你仍然能够理解作者想要表达的意思?这种现象特别常见在专业书籍的阅读中。
你是否有这样的经历:阅读一本翻译质量不太理想的书籍时,虽然某些句子读起来不够通顺,但你仍然能够理解作者想要表达的意思?这种现象特别常见在专业书籍的阅读中。
思路:不是见到更小的元素时就交换位置,而是在找到最小的元素时才交换位置。遍历数组的前 n - 1 个元素,从它们及之后的元素中找到最小的元素,与它们交换位置。
数组有 n 个元素,在从第 1 个元素开始的所有 n 个元素中找到最小元素,与第 1 个元素交换位置;在从第 2 个元素开始的所有 n - 1 个元素中找到最小元素,与第 2 个元素交换位置;……;在从第 n - 1 个元素开始的所有 2 个(n - i + 1)元素中找到最小元素,与第 n - 1 个元素交换位置。
插入排序(insertion sort)模拟了人们整理扑克牌的方式: 将数组分为已排序和未排序两部分;从未排序部分取出一个元素,插入到已排序部分的适当位置;初始时已排序部分只有第一个元素。
思路:将数组视为由两个部分组成,已排序部分和未排序部分。从第 2 个元素开始遍历数组元素,逐步将每个待排序的元素插入到已排序部分的合适位置。在每一轮操作中,算法将未排序部分的第一个元素插入到已排序部分中的合适位置。在插入元素时,已排序部分始终保持有序。待到数组未排序部分的元素遍历完毕,数组完全排序。
思路: 两两比较相邻元素,如果反序则交换,直到没有反序为止。
假如现在有一个陌生人朝我走过来,让我写一个使用冒泡排序算法的程序。我没有做任何准备,没有 gpt 可以问,我经过怎样的思维过程可以把这个程序写出来?