- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是编程初学者。我写了一个程序来显示一个数字出现了(N/2 + 1)次。但每次我运行它时,我的cmd都会崩溃。我想我的数组可能有错误。
我的文本文件 - values3.txt
包含数字 {2, 3, 2, 2, 2, 3, 2, 1}
#include <stdio.h>
#define range_of_nums 3
int main(void)
{
int i;
int num_of_values = 8;
int a[num_of_values];
int freq[range_of_nums];
int current = 0;
int found_number = 0;
FILE *fp;
fp = fopen("values3.txt", "r");
for (i=0;i<num_of_values;i++)
{
fscanf(fp, "%d", &a[i]);
}
fclose(fp);
for (i=0;i<num_of_values;i++)
{
current = a[i] - 1;
freq[current] += 1;
}
num_of_values = num_of_values / 2;
for(i=0;i<range_of_nums;i++)
{
if (freq[i] > num_of_values)
{
found_number = i+1;
}
}
if (found_number != 0)
{
printf("The number %d occurs more than N/2 %d times \n", found_number, num_of_values);
}
else
{
printf("No number occurs more than N/2 times\n");
}
return 0;
}
最佳答案
您实际上走在正确的道路上,只是由于未能验证文件是否打开以及最后在循环逻辑中而失败。您还存在一个问题,即无法验证您是否确实获得了 num_of_values
文件中的值。
我们首先删除“values3.txt
文件在哪里?”问题。 main()
为您提供传递参数(例如文件名)的能力,并使用它。 main
的声明接受参数是:
int main (int argc, char *argv[]) /* where argc arguments are passed in argv */
这消除了 values3.txt
的硬编码在你的程序中。只需将文件名作为第一个参数传递,然后
FILE *fp = fopen (argv[1], "r");
或者,更好一点,使用三元运算符打开 argv[1]
中的文件如果给出,否则从 stdin
读取(默认):
FILE *fp = argc > 1 ? fopen (argv[1], "r") : stdin;
始终验证您的文件是否打开以供读取,如果没有打开则处理错误,例如
if (!fp) { /* validate file open for reading */
fprintf (stderr, "error: file open failed '%s'.\n", argv[1]);
return 1;
}
您遇到的另一个重大问题是初始化失败 freq
为零。当你开始freq[current] += 1;
在您的代码中,freq[current]
必须事先设置为零才能使其有意义。您只需要简单的初始化即可:
freq[range_of_nums] = {0}, /* you must initialize freq */
关于逻辑问题。您想要读取的最大为 num_of_values
整数值转换为a
,但仅此而已。再读 1 个就会调用未定义的行为。不能保证永远有8
文件中的整数。如果有6
怎么办? ?如果有26
怎么办? ?您必须处理所有案件。因此,不要使用 for (i = 0; i < num_of_values; i++)
循环为什么不直接读取所有值并确保您读取的内容不超过 num_of_values
?像这样的东西:
/* read each value up to num_of_values */
while (i < num_of_values && fscanf (fp, "%d", &a[i]) == 1)
i++;
如果你只读6
,你该如何调整?值(value)观?也许:
if (i != num_of_values) /* validate 8 values read */
num_of_values = i; /* if not adjust number */
(注意:您已经知道它不可能更多来自您在 fscanf
前面的测试)
您不一定要更改保存数组中元素数量的变量(保留这一点很重要)。为什么我们不使用一个新变量来保存 N/2
(比如 num_by_2
。然后你可以这样做:
num_by_2 = num_of_values / 2; /* you need another var */
同时仍然保留num_of_values
以便稍后在您的代码中使用。
最后,如果我理解正确的话,您想要识别出现超过 N/2
的所有数字。时间。您的循环布局存在逻辑问题。查找所有大于 N/2
的值次,printf
需要处于该循环中,例如
for (i = 0; i < range_of_nums; i++)
{
if (freq[i] > num_by_2)
{
found_number = i + 1;
printf ("The number %d occurs more than N/2 %d times \n",
found_number, num_by_2);
}
}
现在你知道是否 found_number
有一个值,找到一个值。所以你的最后一个测试可能只是:
if (found_number == 0)
printf("No number occurs more than N/2 times\n");
总而言之,您可以使用类似于以下内容的内容来清理逻辑:
#include <stdio.h>
#define range_of_nums 3
int main (int argc, char **argv)
{
int i = 0,
num_of_values = 8, /* you have 8 values */
a[num_of_values], /* otherwise your VLA is wrong */
freq[range_of_nums] = {0}, /* you must initialize freq */
num_by_2 = 0,
found_number = 0;
FILE *fp = argc > 1 ? fopen (argv[1], "r") : stdin;
if (!fp) { /* validate file open for reading */
fprintf (stderr, "error: file open failed '%s'.\n", argv[1]);
return 1;
}
/* read each value up to num_of_values */
while (i < num_of_values && fscanf (fp, "%d", &a[i]) == 1)
i++;
if (fp != stdin) fclose (fp); /* close file if not stdin */
if (i != num_of_values) /* validate 8 values read */
num_of_values = i; /* if not adjust number */
for (i = 0; i < num_of_values; i++) /* set frequency array vals */
freq[a[i] - 1] += 1;
num_by_2 = num_of_values / 2; /* you need another var */
for (i = 0; i < range_of_nums; i++)
{
if (freq[i] > num_by_2)
{
found_number = i + 1;
printf ("The number %d occurs more than N/2 %d times \n",
found_number, num_by_2);
}
}
if (found_number == 0)
printf("No number occurs more than N/2 times\n");
return 0;
}
示例使用/输出
$ echo "2 3 2 2 2 3 2 1" | ./bin/numby2freq
The number 2 occurs more than N/2 4 times
仔细检查一下,如果您还有其他问题,请告诉我。
关于c - 程序显示一个数字出现 (N/2 + 1) 次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46753254/
我的Angular-Component位于一个flexbox(id =“log”)中。可以显示或隐藏flexbox。 我的组件内部有一个可滚动区域,用于显示日志消息。 (id =“message-li
我真的很困惑 有一个 phpinfo() 输出: MySQL 支持 启用 客户端 API 版本 5.5.40 MYSQL_MODULE_TYPE 外部 phpMyAdmin 显示: 服务器类型:Mar
我正在研究这个 fiddle : http://jsfiddle.net/cED6c/7/我想让按钮文本在单击时发生变化,我尝试使用以下代码: 但是,它不起作用。我应该如何实现这个?任何帮助都会很棒
我应该在“dogs_cats”中保存表“dogs”和“cats”各自的ID,当看到数据时显示狗和猫的名字。 我有这三个表: CREATE TABLE IF NOT EXISTS cats ( id
我有一个字符串返回到我的 View 之一,如下所示: $text = 'Lorem ipsum dolor ' 我正在尝试用 Blade 显示它: {{$text}} 但是,输出是原始字符串而不是渲染
我无法让我的链接(由图像表示,位于页面左侧)真正有效地显示一个 div(包含一个句子,位于中间)/单击链接时隐藏。 这是我的代码: Practice
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
最初我使用 Listview 来显示 oracle 结果,但是最近我不得不切换到 datagridview 来处理比 Listview 允许的更多的结果。然而,自从切换到数据网格后,我得到的结果越来越
我一直在尝试插入一个 Unicode 字符 ∇ 或 ▽,所以它显示在 Apache FOP 生成的 PDF 中。 这是我到目前为止所做的: 根据这个基本帮助 Apache XSL-FO Input,您
我正在使用 node v0.12.7 编写一个 nodeJS 应用程序。 我正在使用 pm2 v0.14.7 运行我的 nodejs 应用程序。 我的应用程序似乎有内存泄漏,因为它从我启动时的大约 1
好的,所以我有一些 jQuery 代码,如果从下拉菜单中选择了带有前缀 Blue 的项目,它会显示一个输入框。 代码: $(function() { $('#text1').hide();
当我试图检查 Chrome 中的 html 元素时,它显示的是 LESS 文件,而 Firefox 显示的是 CSS 文件。 (我正在使用 Bootstrap 框架) 如何在 Chrome 中查看 c
我是 Microsoft Bot Framework 的新手,我正在通过 youtube 视频 https://youtu.be/ynG6Muox81o 学习它并在 Ubuntu 上使用 python
我正在尝试转换从 mssql 生成的文件到 utf-8。当我打开他的输出 mssql在 Windows Server 2003 中使用 notepad++ 将文件识别为 UCS-2LE我使用 file
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在尝试执行单击以打开/关闭一个 div 的功能。 这是基本的,但是,点击只显示 div,当我点击“关闭”时,没有任何反应。 $(".inscricao-email").click(function
假设我有 2 张卡片,屏幕上一次显示一张。我有一个按钮可以用其他卡片替换当前卡片。现在假设卡 1 上有一些数据,卡 2 上有一些数据,我不想破坏它们每个上的数据,或者我不想再次重建它们中的任何一个。
我正在使用 Eloquent Javascript 学习 Javascript。 我在 Firefox 控制台上编写了以下代码,但它返回:“ReferenceError:show() 未定义”为什么?
我正在使用 Symfony2 开发一个 web 项目,我使用 Sonata Admin 作为管理面板,一切正常,但我想要做的是,在 Sonata Admin 的仪表板菜单上,我需要显示隐藏一些菜单取决
我试图显示一个div,具体取决于从下拉列表中选择的内容。例如,如果用户从列表中选择“现金”显示现金div或用户从列表中选择“检查”显示现金div 我整理了样本,但样本不完整,需要接线 http://j
我是一名优秀的程序员,十分优秀!