- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在处理一个链接列表,我想将列表中的节点从一个位置移动到另一个位置而不弄乱东西。
链表的结构是:
struct Frame
{
char* name; // Name and path are just pointers to strings
unsigned int duration;
char* path;
};
typedef struct Frame frame_t;
还有:
struct Link
{
frame_t *frame;
struct Link *next;
};
(这是我被要求这样做的,而不是我的选择)
现在我需要的是一个函数,它接收链表和一个字符串(其中一个节点的名称)和一个整数,然后将具有该名称的节点移动到该位置(收到的整数)第一个位置是 1,而不是 0(这是所要求的)
例如:如果列表包含节点:[pic1, pic2, pic3, pi4]并且用户请求将“pic1”移动到位置3,那么新列表将是:[pic2, pic3, pic1, pic4](pic2 将是新头)
我尝试过一些版本,但它们总是只有 80% 有效(要么切断列表,要么没有移动到正确的位置)。有什么想法吗?
这是我尝试过的功能:
void changePos(link_t** anchor_link, char* name1, int pos)
{
link_t* currLink = *anchor_link;
link_t* temp = NULL;
link_t* temp2 = NULL;
int i;
if (strcmp(name1, currLink->frame->name) == 0 && currLink->next)
{
*anchor_link = (*anchor_link)->next;
temp = currLink;
}
else
{
while (strcmp(name1, currLink->next->frame->name) != 0 && currLink->next)
{
currLink = currLink->next;
}
temp = currLink->next;
}
currLink = *anchor_link;
for (i = 1; i < pos - 1; i++) // Go up until the node before the pos (meaning if pos is 4 then node 3)
{
currLink = currLink->next;
}
// Now we insert the temp node at the pos
temp2 = currLink->next->next;
currLink->next->next = temp;
temp->next = temp2;
}
最佳答案
这是我想出的代码 - changePos()
函数和我创建的测试代码,以确保其正确性。
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct Frame
{
char *name;
unsigned int duration; // Effectively unused
// char *path; // Actually unused
};
typedef struct Frame Frame;
struct Link
{
Frame *frame;
struct Link *next;
};
typedef struct Link Link;
static void print_list(Link *root);
static void changePos(Link **anchor_link, const char *name, int pos)
{
assert(anchor_link != 0 && name != 0 && pos >= 0);
Link *root = *anchor_link;
Link *link = root;
Link *prev = 0;
int count = 0;
while (link != 0 && strcmp(link->frame->name, name) != 0)
{
prev = link;
link = link->next;
count++;
}
if (link == 0) // Name not found - no swap!
return;
if (count == pos) // Already in target position - no swap
return;
if (count == 0) // Moving first item; update root
{
assert(link == root);
*anchor_link = root->next;
root = *anchor_link;
}
else
{
assert(prev != 0);
prev->next = link->next;
}
// link is detached; now where does it go?
if (pos == 0) // Move to start; update root
{
link->next = root;
*anchor_link = link;
return;
}
Link *node = root;
for (int i = 0; i < pos - 1 && node->next != 0; i++)
node = node->next;
link->next = node->next;
node->next = link;
}
static void print_list(Link *root)
{
const char *pad = "";
while (root != 0)
{
printf("%s[%s]", pad, root->frame->name);
root = root->next;
pad = "->";
}
}
static void free_frame(Frame *frame)
{
if (frame != 0)
{
free(frame->name);
free(frame);
}
}
static void free_link(Link *link)
{
while (link != 0)
{
Link *next = link->next;
free_frame(link->frame);
free(link);
link = next;
}
}
static Frame *make_frame(const char *name, unsigned int number)
{
Frame *frame = malloc(sizeof(*frame));
if (frame != 0)
{
frame->name = strdup(name);
frame->duration = number;
}
return frame;
}
static Link *make_link(const char *name, unsigned int number)
{
Link *link = malloc(sizeof(*link));
if (link != 0)
{
link->frame = make_frame(name, number);
link->next = 0;
}
return link;
}
static Link *make_list(int num, Frame *frames)
{
Link *head = 0;
Link *tail = 0;
for (int k = 0; k < num; k++)
{
Link *link = make_link(frames[k].name, frames[k].duration);
assert(link != 0 && link->frame != 0); // Lazy!
if (head == 0)
head = link;
if (tail != 0)
tail->next = link;
tail = link;
}
return head;
}
int main(void)
{
Frame frames[] =
{
{ "pic0", 0 },
{ "pic1", 1 },
{ "pic2", 2 },
{ "pic3", 3 },
{ "pic4", 4 }, // Never in the list, but searched for
};
enum { NUM_FRAMES = sizeof(frames) / sizeof(frames[0]) };
for (int i = 0; i < NUM_FRAMES; i++)
{
for (int j = 0; j < NUM_FRAMES; j++)
{
Link *head = make_list(NUM_FRAMES - 1, frames);
print_list(head);
printf(" == %s to %u == ", frames[i].name, j);
changePos(&head, frames[i].name, j);
print_list(head);
putchar('\n');
free_link(head);
}
}
return 0;
}
我怀疑 changePos()
中的代码还可以进一步简化,但我还没有发现如何简化。这是一个带有数字位置和列表的丑陋界面 - 使用另一个名称来标识节点应移动到的位置会更自然。对于数字位置,您可能会想使用数组而不是列表。
示例输出:
[pic0]->[pic1]->[pic2]->[pic3] == pic0 to 0 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic0 to 1 == [pic1]->[pic0]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic0 to 2 == [pic1]->[pic2]->[pic0]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic0 to 3 == [pic1]->[pic2]->[pic3]->[pic0]
[pic0]->[pic1]->[pic2]->[pic3] == pic0 to 4 == [pic1]->[pic2]->[pic3]->[pic0]
[pic0]->[pic1]->[pic2]->[pic3] == pic1 to 0 == [pic1]->[pic0]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic1 to 1 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic1 to 2 == [pic0]->[pic2]->[pic1]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic1 to 3 == [pic0]->[pic2]->[pic3]->[pic1]
[pic0]->[pic1]->[pic2]->[pic3] == pic1 to 4 == [pic0]->[pic2]->[pic3]->[pic1]
[pic0]->[pic1]->[pic2]->[pic3] == pic2 to 0 == [pic2]->[pic0]->[pic1]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic2 to 1 == [pic0]->[pic2]->[pic1]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic2 to 2 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic2 to 3 == [pic0]->[pic1]->[pic3]->[pic2]
[pic0]->[pic1]->[pic2]->[pic3] == pic2 to 4 == [pic0]->[pic1]->[pic3]->[pic2]
[pic0]->[pic1]->[pic2]->[pic3] == pic3 to 0 == [pic3]->[pic0]->[pic1]->[pic2]
[pic0]->[pic1]->[pic2]->[pic3] == pic3 to 1 == [pic0]->[pic3]->[pic1]->[pic2]
[pic0]->[pic1]->[pic2]->[pic3] == pic3 to 2 == [pic0]->[pic1]->[pic3]->[pic2]
[pic0]->[pic1]->[pic2]->[pic3] == pic3 to 3 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic3 to 4 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic4 to 0 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic4 to 1 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic4 to 2 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic4 to 3 == [pic0]->[pic1]->[pic2]->[pic3]
[pic0]->[pic1]->[pic2]->[pic3] == pic4 to 4 == [pic0]->[pic1]->[pic2]->[pic3]
输出的 LHS 是之前的列表 — 始终相同,顺序为 pic0 到 pic3。输出的右侧是调用 changePos
后的列表。对于位置n = 0..3,可以看到,'picn'依次从位置0迁移到位置3。名称 pic4
永远不会插入到列表中,因此在查找它时不会发生任何变化。此外,当您尝试将任何名称移动到不存在的位置时,它会被移动到列表中的最后一个位置。小于 0 的位置被断言无效。
代码有偶然的错误检查。它断言解决了内存分配问题以及其他一些问题(例如位置小于 0)。
在 changePos()
中写入任何有值(value)的内容之前,我使用一个虚拟的无操作版本的 changePos()
让线束干净地运行。
使用我习惯的编译器警告选项,代码可以在带有 GCC 6.1.0 和 Valgrind 3.12.0.SVN 的 Mac OS X 10.11.5 上干净地编译和运行:
$ gcc -O3 -g -std=c11 -Wall -Wextra -Wmissing-prototypes -Wstrict-prototypes \
> -Wold-style-definition -Werror so.3807-9550.c -o so.3807-9550
$
关于C - 移动链表中的节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38079550/
我正在使用 JavaFX 8 创建一个应用程序。我使用拖/放动态更改网格 Pane 的内容。我希望每行或每行/列迭代 GridPane 内容。JavaFX 允许通过指定行和列在 GridPane 中添
我正在尝试将图像拖放到div上。图像没有被拖到div上并给出以下错误 Uncaught TypeError: Failed to execute 'appendChild' on 'Node': pa
我正在 android studio 中创建内部构建 AR 导航。我正在寻找一种方法将 anchor 与其他 anchor 或 anchor 节点/节点“连接”起来。我不确定使用哪一个。基于我将强制用
我在 Hive 上运行一些作业:首先是 4 节点,然后是 2 节点。令我惊讶的是,我的 2 节点性能比我的 4 节点更好。 首先,我在一个 4 节点(4 个事件节点)上运行查询,然后关闭 2 个节点(
我有 Node* current ,我在其中存储指向列表“顶部”当前节点的指针。当我将一个新节点设置为当前节点时,出现错误: '=' : cannot convert from 'CircularDo
我是 dcos Mesos 的新手,在本地 Ubuntu 机器上安装了 dc os。 我可以查看 dcos 仪表板。 但我无法使用 dcos node ssh --master-proxy --lea
在 JavaFX 中,是否有类似 setLayout(); 的东西?或 setBounds(); ? 例如,我想将按钮定位到我想要的位置。 最佳答案 JavaFX 场景图上的所有内容都是 Node .
我正在开发一个 JavaFX 应用程序,其中我开发的类(从 javafx.scene.Parent 扩展)是根据用户在 ListView 控件中单击的条目动态创建的。 只是要清楚这个节点,它不是使用像
我正在尝试为节点-边缘关系创建一个类图,因为它可以在有向图中找到。我想传达的是,Nodes 引用了 Edges,Edges 也引用了 Nodes。每个 Edge 都恰好需要两个 Node(源和目标)。
在mapreduce作业期间,单个任务将在随机节点上运行,是否有任何方法限制应在其中运行任务的节点? 最佳答案 Hadoop不会选择节点来随机运行任务。考虑到数据局部性,否则将有很多网络开销。 任务与
有什么区别: a) nodetool 重建 b) nodetool 修复 [-pr] 换句话来说,各个命令到底是做什么的? 最佳答案 nodetool重建:类似于引导过程(当您向集群添加新节点时),但
我已将第一个 OneToMany 关系添加到我的 hibernate 3.6.10 项目中。这是一个类: /** * */ package com.heavyweightsoftware.leal
是否有可能找到正在监听触发当前函数的事件的元素? 在下面的代码中,event.target 返回 #xScrollPane 和 event.currentTarget 和 event 的最低子节点.f
我正在尝试覆盖我数据库中的一些数据。结构很简单,就是: recipes { user_1{ recipe_1{data} recipe_2{data} } user_2{
我使用 setInterval 来运行该函数,但它会多次执行函数 2... 如何在输入中插入一个值后执行函数 第一个输入与其余输入的距离不同 如何在插入 val(tab 选项)后将插入从 1 个输入移
我不知道代码有什么问题,但在 visual studio 中不断收到这些错误消息。 Error 18 error C1903: unable to recover from previous e
我正在尝试从其类中获取 SharePoint 搜索导航节点的对象。 var nodes = $("div.ms-qSuggest-listItem"); 我正在获取节点对象,现在想要获取“_promp
D:\nodeP>node main.js module.js:327 抛出错误; ^ 错误:在 Function.Module 的 Function.Module._resolveFilename
struct node{ int key, prior, cnt, val; node *l, *r; node(){} node(int nkey) : key(nkey),
我有以下代码使用迭代器将项目插入双链表。这就是我们被要求这样做的方式。代码有效,但问题是我有 24 字节的绝对内存泄漏。 NodeIterator insert(NodeIterator & itrP
我是一名优秀的程序员,十分优秀!