- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
所以我明白升序冒泡排序会检查索引 i 是否大于索引“i + 1”,如果是,则交换位置,然后继续进行直到到达循环结束,然后循环重新开始,不断切换位置,直到每个索引“i”不大于“i + 1”,然后循环完全按升序排序。
所以我正在查看这个冒泡排序代码。这是来源:www.programmingsimplified.com/c/source-code/c-program-bubble-sort
代码如下:
/* Bubble sort code */
#include <stdio.h>
int main()
{
int array[100], n, c, d, swap;
printf("Enter number of elements\n");
scanf("%d", &n);
printf("Enter %d integers\n", n);
for (c = 0; c < n; c++)
scanf("%d", &array[c]);
for (c = 0 ; c < ( n - 1 ); c++)
{
for (d = 0 ; d < n - c - 1; d++)
{
if (array[d] > array[d+1]) /* For decreasing order use < */
{
swap = array[d];
array[d] = array[d+1];
array[d+1] = swap;
}
}
}
printf("Sorted list in ascending order:\n");
for ( c = 0 ; c < n ; c++ )
printf("%d\n", array[c]);
return 0;
}
我理解除“d”之外的所有变量。我不知道他们的深奥含义。所以这是让我感到困惑的代码部分:
for (c = 0 ; c < ( n - 1 ); c++)
{
for (d = 0 ; d < n - c - 1; d++)
{
if (array[d] > array[d+1]) /* For decreasing order use < */
{
swap = array[d];
array[d] = array[d+1];
array[d+1] = swap;
}
}
}
据我了解,第一个 for 循环遍历长度为 n - 1 的数组,因为在 C 中,数组的第一个索引为 0。第二个 for 循环的长度似乎是“c”的长度,如下所示它遍历数组,但不是数组的长度 (n - 1),这让我很困惑。我不明白 d 是什么,所以我不明白为什么在交换语句中使用“d”而不是“c”。不过我完全明白交换的作用,按照我在介绍交换索引。
所以我想我最不明白的是为什么第二个for循环是必要的以及d数组的长度:
for (d = 0 ; d < n - c - 1; d++)
{
// if comparison switch check.
}
因此网站中提供的代码正确地进行了冒泡排序。我用 n = 5 和 values = {9, 8, 7, 6, 5} 尝试过
它成功地将它们按升序重新排列为 {5, 6, 7, 8 , 9}。
由于我不理解第二个for循环,所以我想看看如果不包括它会发生什么,结果很有趣。我只是更改删除了第二个 for 循环,并将提到的“d”替换为 c。
#include <stdio.h>
int main(void)
{
int array[100], n, c, swap;
printf("Enter number of elements\n");
scanf("%d", &n);
// Tell the user to enter integers in a loop.
printf("Enter %d integers\n", n);
for (c = 0; c < n; c++)
scanf("%d", &array[c]);
for(c = 0; c < (n - 1); c++)
{
if(array[c] > array[c + 1])
{
swap = array[c];
array[c] = array[c+1];
array[c+1] = swap;
}
}
printf("Sorted list in ascending order:\n");
for(c = 0; c < n; c++)
printf("%d\n", array[c]);
return (0);
}
如果我在删除第二个 for 循环时看到这段代码发生了什么,我就会得到这个结果。我输入 5 个元素:{9, 8, 7, 6, 5},我返回的顺序是:{8, 7, 6, 5, 9}。这显然不是正确的升序。但是它对整个集合进行了冒泡排序;它只完成了一次,所以这就是为什么这个排序数组从 8 开始的原因,因为它只完成了一次。
同样,这个不正确的代码现在实际上可以正确地对这个 5 元素数组进行排序:{1, 8, 2, 3, 7}。它将其更改为 {1, 2, 3, 7, 8}。但是只用了一次数组就正确地完成了这个冒泡排序。
因此,我发现第二个 for 循环可确保数组按数字升序正确排序,因为需要进行多次冒泡排序才能进行更改。
但是我还是不明白,也很难解释我怎么不明白。我很清楚“c”是从头到尾在数组中滑动的索引。但是“d”是一个什么样的索引,它真正从哪里开始,又从哪里真正结束呢?
谢谢。
如果您碰巧有更简单的代码,不需要用于冒泡排序的 for 循环起始,并且您只能使用一个变量,那么我将很欣赏该代码。
最佳答案
这里c&d用来循环遍历排序
对于c整个循环遍历n次
和对于d
遍历数组中除sorted之外的所有元素,对数组进行排序
希望你现在明白这个事实
快乐编码
关于c - 在这个冒泡排序代码中,这些变量 c 和 d 在 C 中意味着什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43751264/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How to nest OR statements in JavaScript? 有没有办法做到这一点:
在 JavaScript 中有没有办法让一个变量总是等于一个变量?喜欢var1 = var2但是当var2更新,也是var1 . 例子 var var1 = document.getElementBy
我正在努力理解这代表什么 var1 = var2 == var3 我的猜测是这等同于: if (var2 == var3): var1 = var2 最佳答案 赋值 var1 = var2
这个问题已经有答案了: What does the PHP error message "Notice: Use of undefined constant" mean? (2 个回答) 已关闭 8
我在临时表中有几条记录,我想从每条记录中获取一个值并将其添加到一个变量中,例如 color | caption -------------------------------- re
如何将字符串转为变量(字符串变量--> $variable)? 或者用逗号分隔的变量列表然后转换为实际变量。 我有 2 个文件: 列名文件 行文件 我需要根据字符串匹配行文件中的整行,并根据列名文件命
我有一个我无法解决的基本 php 问题,我也想了解为什么! $upperValueCB = 10; $passNodeMatrixSource = 'CB'; $topValue= '$uppe
这可能吗? php $variable = $variable1 || $variable2? 如果 $variable1 为空则使用 $variable2 是否存在类似的东西? 最佳答案 PHP 5
在 Perl 5.20 中,for 循环似乎能够修改模块作用域的变量,但不能修改父作用域中的词法变量。 #!/usr/bin/env perl use strict; use warnings; ou
为什么这不起作用: var variable; variable = variable.concat(variable2); $('#lunk').append(variable) 我无法弄清楚这一点
根据我的理解,在32位机器上,指针的sizeof是32位(4字节),而在64位机器上,它是8字节。无论它们指向什么数据类型,它们都有固定的大小。我的计算机在 64 位上运行,但是当我打印包含 * 的大
例如: int a = 10; a += 1.5; 这运行得很完美,但是 a = a+1.5; 此作业表示类型不匹配:无法从 double 转换为 int。所以我的问题是:+= 运算符 和= 运算符
您好,我写了这个 MySQL 存储过程,但我一直收到这个语法错误 #1064 - You have an error in your SQL syntax; check the manual that
我试图在我的场景中显示特定的奖牌,这取决于你的高分是基于关卡的目标。 // Get Medal Colour if levelHighscore goalScore { sc
我必须维护相当古老的 Visual C++ 源代码的大型代码库。我发现代码如下: bIsOk = !!m_ptr->isOpen(some Parameters) bIsOk的数据类型是bool,is
我有一个从 MySQL 数据库中提取的动态产品列表。在 list 上有一个立即联系 按钮,我正在使用一个 jquery Modal 脚本,它会弹出一个表单。 我的问题是尝试将产品信息变量传递给该弹出窗
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: What is the difference between (type)value and type(va
jQuery Core Style Guidelines建议两种不同的方法来检查变量是否已定义。 全局变量:typeof variable === "undefined" 局部变量:variable
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: “Variable” Variables in Javascript? 我想肯定有一种方法可以在 JavaScrip
在语句中使用多重赋值有什么优点或缺点吗?在简单的例子中 var1 = var2 = true; 赋值是从右到左的(我相信 C# 中的所有赋值都是如此,而且可能是 Java,尽管我没有检查后者)。但是,
我是一名优秀的程序员,十分优秀!