- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为了澄清标题:我正在像 *head=(*head)->next
这样遍历链表,因为它是一个函数。在我的函数中,我选择我的当前head
以及当前head
和当前head
之间的另一个链接交换列表。
我想要的是创建一个函数,在知道交换的所有条件都满足的情况下,交换头和链接(不仅仅是数据);意味着链接不是当前的 head
或链接不是 NULL
。可以这样做还是我必须尝试其他方法?
提前致谢。
既然我的问题不清楚,我就把问题给你。
我需要创建一个这样的函数:
void intertwine(cvor **head)
我收到一个带有随机数的链接列表。我需要做的是交换链接,直到它看起来像这样:奇数、偶数、奇数、偶数等。
我必须尊重不均匀和均匀的顺序。
如果偶数和不均匀数不相等,则按照它们在列表中的顺序保留它们。
这里有 2 个例子:
输入:11, 7, 5, 16, 12, 15, 17, 13, 10, 4, 1
输出:11, 16, 7, 12, 5, 10, 15, 4, 17, 13, 1
输入:1、3、2、4
输出:1、2、3、4
我当前的代码如下所示(未完成)
edit2:抱歉忘记了语言障碍
typedef struct atom{
int el;
struct atom *next;
} cvor;
void intertwine (cvor **head){
cvor *pom,int br=1;
pom=*head;
while(*head){
if((*head)->el%2==(br%2)){
pom=(*head)->next;
while(pom){
if(pom->el%2==(br+1)%2)break;
pom=pom->next;
}
if(pom==NULL) return;
最后是我想要的交换发生的时候。
最佳答案
如果您编写一个函数,可以将链表中的一个元素移动到同一链表中的另一个元素前面,则可以解决此问题。
函数应采用的输入
指向head
指针的指针
指向要移动的元素的指针 b
指向 b 应移到其前面的元素的指针
喜欢
void move_b_in_front_of_a(cvor **head, cvor* b, cvor* a) { ... }
调用函数时要求
a
和b
都指向列表中的元素*head
a
位于列表中 b
之前
实现可能是这样的:
void move_b_in_front_of_a(cvor **head, cvor* a, cvor* b)
{
// Find the element just before a
cvor* a_prev = find_element_before(head, a);
// Find the element just before b (start from a)
cvor* b_prev = find_element_before(a, b);
if (b_prev == NULL) { .... add error handling ....}
// Take b out of the list
b_prev->next = b->next;
// Insert b in front of a
if (a_prev == NULL)
{
(*head) = b;
}
else
{
a_prev->next = b;
}
b->next = a;
}
在上面的代码中我使用了该函数
cvor* find_element_before(cvor* l, cvor* e)
{
// Add code to find the element just before e in the list l
// Return NULL if e is first element
// Add error handling if element e isn't found
...
...
return pointer_to_element_just_before_e;
}
您需要实现。
当您拥有这两个函数时,实现 intertwin
函数应该非常容易。
以下是该函数的一些伪代码,可以帮助您入门:
current_element = *head
expected-type = odd
loop:
if current_element is expected-type
toggle expected-type
current_element = next
if current_element is NULL return
else
find_element with_correct_type
if no element found return
move found_element in front of current_element (use above function)
current_element = found_element
关于c - 将链表的头与其中的链接交换?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51964851/
我正在尝试将多个项目转换为 classy-prelude眼下。虽然大多数行为对我来说似乎相当简单,但 (head . head) 在简单的 2D 列表上给出了神秘的错误。 考虑以下 GHCi sess
我创建了这个类来从请求中获取 Header 值。 public class AuthenticationHeader { private static IHttpContextAccesso
这里有两段代码。 工作: joins :: [String] -> String -> String joins [] _ = "" joins [x] _ = x joins xs d = head
我是编程新手,正在Windows中使用vscode并通过Mingw 64进行编译。尝试了数天后,我要求对此问题做出解答。我用谷歌搜索了很多次。这是我的项目树的外观。请帮助我包括并将 libA 链接到
我正在研究 Ninety-Nine Scala Problems 的 P07 问题: P07 (**) Flatten a nested list structure. Example: scala>
这里有两段代码。 工作: joins :: [String] -> String -> String joins [] _ = "" joins [x] _ = x joins xs d = head
我正在使用现成的欧洲 cookie 政策脚本。问题是,我的 Hubspot CMS 只允许所有内容的全局标题或每个页面的单独标题。我们有 120 个页面,很难手动定义它,但我们需要一个用于德语页面的脚
Solaris 10 SPARC Sun Studio C 编译器 12.3 在 SPARC64 机器上,如果您访问一个在相关 4 或 8 字节边界上未正确对齐的变量,您将获得核心转储。这需要编码人员
我正在尝试从服务器列表中获取 apache 版本。我正在考虑解析 header ,但是我无法发送 HEAD 但它可以与 GET POST 等一起使用。 这是我的代码: import java.io.B
嗨,我是 github 的新手,当我对代码做了一些更改然后 merge 到上游时,如果有任何冲突,它将执行以下操作。 Auto-merging Global.asax.cs CONFLICT (con
例如,获取偏移量 Y 之后的前 X 行的建议方法是什么?我目前正在做的是: offset, limit = 2, 2 df=pd.DataFrame([{'a':1}, {'a': 2}, {'a':
当我在R块 header 中插入长标题等内容时,能够将 header 拆分为多行会很好。 有没有简单的方法可以做到这一点? 例如。: ```{r, echo=FALSE, warning=FALSE,
我刚刚开始使用 Erlang(虽然有一些 lisp 背景)并且有一个关于列表模式匹配的问题。 如果我说 [Head | Tail] = [1, 2, 3]. 然后我得到 Head = 1 Tail =
我的 index.php 文件开头有这段代码: if ( !isset($_GET['cat']) ) die(header("Location: ?cat=top")
对第 3 方应用程序进行一些 SOAP 调用。他们提供此 soap header 作为应用程序期望的示例。如何在 PHP 中创建这样的 SOAP header ?
我对 git 仓库下的文件做了一些更改,我使用 git commit 提交了文件 然后我尝试使用 git push origin master 推送到 master,它返回了 Everything u
我刚刚尝试从 url 下载 webp 图像,但是当我尝试处理存储的图像时,我发现了一些不同的东西。 如果我从浏览器下载图像,它可以使用 x/image/webp 包解码,但如果我使用 http.Get
这是来自 slices 的略微修改的代码 var buffer [256] byte func SubtractOneFromLength(slice []byte) []byte { sli
在 Linux 中是否有一种方法可以请求 Head 或 Tail 但要忽略额外的记录偏移量。 例如,如果文件 example.lst 包含以下内容: row01 row02 row03 row04 r
代码: /* * File: problem5.c * Author: levihackwith * Description: Write a Pop() function that is th
我是一名优秀的程序员,十分优秀!