- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我创建了一个包含 5 个节点的链表:
typedef struct node
{
int i;
struct node* link;
}node;
node* head = NULL;
当打印出来时,这给出:
4 3 2 1 0
头指针设置为指向 4。然后我编写了一个函数来对链表进行冒泡排序,如下所示:
void sort(void)
{
node* cur = head;
node* next = cur->link;
node* prev = NULL;
while(cur->i > next->i)
{
printf("cur is greater than next\n");
while(prev != head)
{
cur->link = next->link;
next->link = cur;
head = next;
next = cur->link;
prev = head;
}
while(next != NULL)
{
prev->link = next;
cur->link = next->link;
next->link = cur;
prev = next;
next = cur->link;
}
printf("second while loop exited\n");
for (node* ptr = head; ptr != NULL; ptr = ptr->link)
{
printf("%d", ptr->i);
}
cur = head;
next = cur->link;
}
}
有多种 printf 语句可以检查程序是否正常运行。我发现第一次跑通后,4成功冒泡如下:
3 2 1 0 4
但是,在将 cur 指针重新设置为 3 和 2 之后,下一个运行提供以下内容:
2 1 0 4 3
最终,我们完成了
0 4 3 2 1
因此可以看出“3”、“2”和“1”被夸大了。我尝试了各种条件来代替第三个 while 循环来纠正这个问题,但在大多数情况下,这会导致段错误。当然,这里的另一件事是我的逻辑可能完全错误,可能有更好的方法来实现它。你可以只交换节点的内容而不交换指针本身吗?任何帮助将非常感激。提前致谢
最佳答案
用于排序数组的普通冒泡排序实现利用直接寻址和数组的已知大小:它们自然使用索引,即项目的序数,因此它们可以随着工作的进行轻松缩小排序的区域,因为他们知道有多少元素已经在他们的最终位置。
链表是完全按顺序处理的,因此它不允许在不添加人工“索引”的情况下进行这种简单的优化,沿着列表迭代递增。这就是为什么总是遍历整个列表并在没有更多项目被交换时终止是最简单的原因,因此列表已排序:
void sort(void)
{
int swapped = 1;
while(swapped)
{
node **prev = &head, *curr, *next;
swapped = 0;
for(curr = head; curr; prev = & curr->link, curr = curr->link)
{
next = curr->link;
if(next && curr->i > next->i)
{
curr->link = next->link;
next->link = curr;
*prev = next;
swapped = 1;
}
}
}
}
编辑 – 一些解释,以回答 Matthew2015 评论中的问题。
C 中的逻辑条件需要一个数值或指针表达式,如果它们分别不为零或不为 NULL,则它们被视为“真”。这意味着 while(swapped)
本质上等同于 while(swapped != 0)
和 next && ...
相当于next != NULL && ...
. while(swapped != 0)
中的情况意味着循环将在执行内部 for
时终止。不设置 swapped
至 1
,当列表中没有任何项大于其后继项时会发生这种情况 - 也就是说,当列表已排序时。
for
循环条件表达式为curr
单独,相当于 curr != NULL
.这使得 for
沿着列表循环迭代,直到没有“当前”节点。
node **prev
变量指向一个指针,该指针指向当前节点。当“当前”和“下一个”节点需要交换时,“上一个”链接不应再指向“当前”节点,而是指向“下一个”节点。当然,可以保留指向“前一个节点”的指针并为 (previous node)->link
分配一个新值。 — 但如果列表中的第一个节点没有“前一个节点”但被 head
指向,那将不起作用多变的。必须使用附加条件来验证当前节点是否是解决此不一致的第一个节点。有一个指向指针的指针,它最初指向 head
然后到'previous node'.link
使整个代码更简单、更短,也更快一些。
关于c - 冒泡排序 C 中的链表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32653316/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!