- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我创建一个链接列表来复制费用经理时,我陷入了寻找费用最高的日子的困境。我以某种方式设法通过遍历找到了总计的最大值,但无法打印与之关联的日期。请帮忙。
我的结构代码:
struct node{
int day;
int movies;
int groceries;
int travel;
int total;
struct node* left;
struct node* right;
};
void find_max()
{
struct node *new1 = start;
int max, c;
if(start == NULL) {
printf("List is empty\n");
return;
}
else {
max = start->total;
while(new1 != NULL) {
if(new1->total > max)
{
max = new1->total;
}
new1 = new1->right;
}
}
printf("The maximum spending was: %d",max);
}
在这里,当我尝试打印 new1->day
(我不确定这叫什么。这是一个分支吗?),它向我显示一个垃圾值或停止运行。
如何正确显示?
编辑(代码):
#include<stdio.h>
#include<stdlib.h>
struct node{
int day;
int movies;
int groceries;
int travel;
int total;
struct node* left;
struct node* right;
};
void maximumNode();
//Main goes here, where I choose the option using switch case. Say the example is case 3
case 3:
{
maximumNode();
break;
}
//End of main
void maximumNode() {
struct node *new1 = start;
struct node *max;
if(start == NULL) {
printf("List is empty\n");
return;
}
else {
max->total = start->total;
while(new1 != NULL) {
if(new1->total > max->total)
{
max->total = new1->total;
}
new1 = new1->right;
}
}
printf("The maximum spending was: %d and the day was: %d\n\n",max->total, max->day);
}
在这里,当我将情况 3 添加到列表后,一旦输入它,程序就不会运行。 (当我将 max 设为 int 值时,它就运行了)。
编辑2:我刚刚重新运行了我的代码,显然即使在插入过程中我也犯了错误。很抱歉浪费了大家的时间,感谢大家的支持。
我的插入代码,以防万一:
void Insert(int a, int b, int c, int d)
{
struct node *temp,*t;
int total1=b+c+d;
temp=(struct node*)malloc(sizeof(struct node));
if(start==NULL)
{
start=temp;printf("%d", total1);
start->day=a;
start->movies=b;
start->groceries=c;
start->travel=d;
start->total=total1;
start->left=NULL;
start->right=NULL;
}
else
{
temp=start;
while(temp->right!=NULL)
{
temp=temp->right;
}
t=(struct node*)malloc(sizeof(struct node));
start->day=a;
start->movies=b;
start->groceries=c;
start->travel=d;
start->total=total1;
t->right=NULL;
t->left=temp;
temp->right=t;
}
printf("\n\nYour expense has been saved successfully!\n\n");
}
最佳答案
在您发布的代码的第一个版本中,您只是将最大值保留为整数。如果您想找到该值,那很好,但是它所在的节点的信息丢失了。
在评论中,我建议您将 max
设为一个节点。您这样做了,但犯了几个错误:
max
未初始化,这意味着会发生不好的事情。 (C 语言的意思是“未定义的行为”。)初始化 max = start
。 (看到没有初始化的指针定义应该引起警惕。如果您不知道要初始化什么,至少将其设为 NULL
,这样您就可以检查 NULL
> 稍后。只需编写 struct node *max;
就意味着 max
有一个不确定的值,您甚至无法检查!然后,当你找到更好的节点时,不要设置max->total
。这意味着您只需使用第一个节点作为最大值的存储,从而更改列表数据,这是您不想要的。设置新节点:
if (new1->total > max->total) max = new1;
(如果您仔细阅读我的评论,这就是我的建议。)
让我们实现它并修复代码的一些语义问题,请参阅下面的注释:
const struct *node maximumNode()
{
const struct node *node = start;
const struct node *max = start;
while (node != NULL) {
if(node->total > max->total) {
max = node;
}
node = node->right;
}
return max;
}
注意事项:
该函数现在返回对具有最大 total
的节点的引用。然后,调用代码可以打印信息或以其他方式使用该节点,例如:
const struct node *max = maximumNode();
if (node) {
printf("Max. total of %d was on day %d.\n",
node->totel, node->day;
}
这比在正确的函数中进行打印更干净。这还允许您在需要最大值的其他上下文中使用相同的函数。节点。
const struct node *
。这意味着您无法修改结构的内容。仅仅找到最大值意味着您只需检查列表,但不要更改它。通过此声明,编译器会提示尝试设置 max->total
并且您会看到错误。NULL
。当start
== NULL时,那么
node == NULL并且
max == NULL。这不会改变,因为没有进入循环并且我们 terurn
NULL`,这是在这种情况下我们能做的最好的事情。new1
更改为 node
。这是一个表面上的改变,但对我来说 new 表明正在创建一个节点,但由于我们只是检查,该名称可能会产生误导。小事情很重要。 (而且,我是个吹毛求疵的人。)关于c - 具有多个元素的链表并找到最大的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58463251/
这个问题在这里已经有了答案: Different ways of loading a file as an InputStream (6 个答案) 关闭 8 年前。 在我的 gradle java
给定一个 User 类: class User end 我想使用 .class_eval 定义一个新常量.所以: User.class_eval { AVOCADO = 'fruit' } 如果我尝试
这可能听起来很奇怪,但我正在开发一个需要查找 div 内的元素或 div 本身的插件。 脚本根据用户选择查找元素,但内容(包括标记)是可变的。因此脚本将按如下方式查找元素: $('.block').f
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 Improve th
我需要在按我自己的函数排序的对的多集中查找并删除一个值。显然, .find 总是将迭代器返回到末尾,而不是返回到搜索到的值。有小费吗?这是函数: struct cmp { bool operato
求助!我将如何通过遍历查看字符并计算有效字符出现之前的下划线数量来查找和删除前导下划线。以及从字符串末尾向后迭代以查找任何尾随下划线。 我可以使用下面的方法来删除下划线,但是如何迭代才能找到下划线。
如果你在 $(xml) 中有下面的 xml,你会变得懒惰: $(xml).find("animal").find("dog").find("beagle").text() 在 jQuery 中是否有类
你如何找到4个文件的交集? 我用了grep -Fx -f 1.txt 2.txt 3.txt 4.txt ,但它似乎只适用于 2 个文件。同样comm -12 1.txt 2.txt无法扩展为 4 个
我已经完成了标记的姿势估计并获得了 rvec 和 tvec 值。我不知道如何找到它的中心,因为我需要绘制一个需要中心值的圆柱体。 我该怎么做? 最佳答案 标记的 tvec 是标记从原点的平移 (x,y
我有一个任务,我需要找到 2 个单链接(单对单)列表的交集。我还必须为 2 个双向链接(双重 vs 双重)列表执行此操作: 对于单链表,我使用 mergeSort() 对两个列表进行排序,然后逐项比较
我是 R 的新手,我有一个 100x100 的方阵。我想找到这个矩阵的最大特征值。我试过了 is.indefinite(x) 但是它写 is.indefinite(x) : argument x is
您好,我是 svg 和 JavaScript 的新手,当鼠标位于 svg 上方时,我试图使一些 svg 元素弹出(通过缩放),反之亦然,当鼠标离开 svg 元素时。 我已经能够通过使用转换使 svg
我正在尝试为 scala 项目编写一个类,但在多个地方使用 class、def、while 等关键字出现此错误。 它发生在这样的地方: var continue = true while (conti
我有两个 pandas 数据框,它们只取自一列并将日期列设置为索引,所以现在我有两个 Series。我需要找到这些系列的相关性。 这里有几行来自dfd: index change 2018-
我正在尝试调整我的 Vagrantfile,因此如果它丢失,它会自动在项目根目录中创建一个文件夹。创建文件夹没问题,但我无法找到创建该文件夹的位置。 我发现此信息可在 Vagrant::Environ
我正在尝试在 jquery 中找到 Test3 的位置,请有人引导我走上正确的道路。 我需要jquery来显示5 Test7 Test2 Test6 Test5 Test3 Test8 谢谢 最佳
大家早上好 我有一个像这样的图像列表: 使用 jQuery 如何查找 ul#preload 中包含特定字符串(例如“green”)的所有图像 src 类似... var new_src = j
我正在开发一个修改 Excel 文件的应用程序。 如何找到任意行中最后使用的单元格? 示例:行号 => 5 中最后使用的单元格 最佳答案 要找到一行中的最后一个单元格,您需要 Range 的 End
我刚刚陷入 react native ,需要一些帮助才能在找到 token 时导航到 protected 屏幕。我应该在哪里寻找应用程序加载时的 token ?如何在不多次调用导航的情况下导航用户一次
非常奇怪...此页面是 protected 内容还是我不知道的内容?我尝试单击下一页 anchor 。 参见this page first. 我试图用这个来抓取元素 var buttonNext =
我是一名优秀的程序员,十分优秀!