- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试从 C 中的二进制文件写入和读取链表。
我的目标是保存和加载疗养院的居民数据(实际上,我是一名护士),以便通过资源利用组对每个居民进行分类。我已经使用一系列结构为固定数量的居民(32,这是设施的容量)完成了它,但现在我需要为一组可变的居民这样做,以便进行统计研究.
显然,对于第一次尝试,我将结构简化到最小,因为实际结构包含 109 个数据。
我非常接近解决方案但有些东西不起作用,也就是说,保存列表的每个元素都与一个空元素交替。这段代码应该从二进制文件中读取列表,在终端上显示,添加一个新元素,保存列表。当然,每个过程都应该放在一个函数中。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ncurses.h>
struct pat
{
char surn [16];
char name [16];
struct pat *next;
};
static FILE *h;
static struct pat *osp;
static struct pat *first;
struct pat *make_structure (void);
int main()
{
initscr();
raw();
keypad (stdscr, TRUE);
noecho();
clear();
osp=make_structure();
first=osp;
h=fopen ("archivio","r");
if (h==NULL)
printw ("Archivio inesistente\n");
else
{
while (!feof(h))
{
printw ("Lungh. nome = %d\n",sizeof osp->name);
fread (osp->surn,sizeof osp->surn,1,h);
fread (osp->name,sizeof osp->name,1,h);
printw ("Cognome: %s\tNome: %s\n",osp->surn,osp->name);
osp->next=make_structure();
osp=osp->next;
}
}
getch();
echo();
printw ("Surname: ");
scanw ("%s",osp->surn);
printw ("\nName: ");
scanw ("%s",osp->name);
noecho();
osp=first;
h=fopen ("archivio","w");
while (osp != NULL)
{
fwrite (osp->surn,sizeof osp->surn,1,h);
fwrite (osp->name,sizeof osp->name,1,h);
osp=osp->next;
}
return 0;
}
struct pat *make_structure(void)
{
struct pat *a;
a = (struct pat *)malloc(sizeof(struct pat));
return (a);
}
最佳答案
你太接近了,我什至不确定失败的真正原因是什么,因为对于第一次剪辑,我只是应用了[大部分]其他人建议的修复程序并得到了一个有效的程序。
虽然它有效,但我发现你做“领先”的方式make_structure
当您扩展程序以执行其他操作时,调用不那么灵活。
例如,如果您决定不添加新记录,而是对现有记录进行一些统计或操作,而不是添加新记录,那么您将拥有一条挂起的“幽灵”记录。
因此,我创建了该程序的第二个版本,它具有更多的隔离性和通用性。
这是更改最少的版本[请原谅无偿的样式清理]:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ncurses.h>
struct pat {
char surn[16];
char name[16];
struct pat *next;
};
static FILE *h;
static struct pat *osp;
static struct pat *first;
struct pat *make_structure(void);
int
main()
{
int rlen;
initscr();
raw();
keypad(stdscr, TRUE);
noecho();
clear();
osp = make_structure();
first = osp;
h = fopen("archivio", "r");
if (h == NULL)
printw("Archivio inesistente\n");
else {
while (1) {
printw("Lungh. nome = %d\n", sizeof osp->name);
// leave early on EOF or badly formed entry
rlen = fread(osp->surn, sizeof osp->surn, 1, h);
if (rlen != 1)
break;
// leave early on EOF or badly formed entry
fread(osp->name, sizeof osp->name, 1, h);
if (rlen != 1)
break;
printw("Cognome: %s\tNome: %s\n", osp->surn, osp->name);
osp->next = make_structure();
osp = osp->next;
}
fclose(h);
}
// NOTE: this just chews the first character (debug, I suppose?)
#if 0
getch();
#endif
// add new element
echo();
printw("Surname: ");
scanw("%15s", osp->surn);
printw("Name: ");
scanw("%15s", osp->name);
noecho();
h = fopen("archivio", "w");
osp = first;
while (osp != NULL) {
fwrite(osp->surn, sizeof osp->surn, 1, h);
fwrite(osp->name, sizeof osp->name, 1, h);
osp = osp->next;
}
fclose(h);
return 0;
}
struct pat *
make_structure(void)
{
struct pat *a;
a = malloc(sizeof(struct pat));
// NOTE: do this for good measure
a->next = NULL;
return (a);
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ncurses.h>
struct pat {
char surn[16];
char name[16];
struct pat *next;
};
static FILE *h;
static struct pat *osp;
static struct pat *first;
static struct pat *prev;
void read_archive(const char *file);
void add_new_elements(void);
void write_archive(const char *file);
struct pat *make_structure(void);
void add_to_list(struct pat *pat);
int
main()
{
initscr();
raw();
keypad(stdscr, TRUE);
noecho();
clear();
read_archive("archivio");
// NOTE: this just chews the first character (debug, I suppose?)
#if 0
getch();
#endif
// NOTE: instead of just automatically adding new elements, this might
// be replaced with a menu, such as:
// Enter Operation:
// (1) Add new names
// (2) Calculate statistics
// (3) Backup database
add_new_elements();
write_archive("archivio");
return 0;
}
// read_archive -- read in archive
void
read_archive(const char *file)
{
int rlen;
h = fopen(file, "r");
if (h == NULL)
printw("Archivio inesistente\n");
else {
while (1) {
osp = make_structure();
// leave early on EOF or badly formed entry
rlen = fread(osp->surn, sizeof osp->surn, 1, h);
if (rlen != 1)
break;
// leave early on EOF or badly formed entry
fread(osp->name, sizeof osp->name, 1, h);
if (rlen != 1)
break;
printw("Cognome: %s\tNome: %s\n", osp->surn, osp->name);
add_to_list(osp);
}
// NOTE: this is _always_ for EOF or bad entry, so free it
free(osp);
fclose(h);
}
}
// add_new_elements -- prompt for new elements
void
add_new_elements(void)
{
echo();
while (1) {
osp = make_structure();
printw("Surname: ");
osp->surn[0] = 0;
scanw("%15s", osp->surn);
if (osp->surn[0] == 0)
break;
printw("Name: ");
osp->name[0] = 0;
scanw("%15s", osp->name);
if (osp->name[0] == 0)
break;
add_to_list(osp);
}
noecho();
free(osp);
}
// write_archive -- write out archive
void
write_archive(const char *file)
{
h = fopen(file, "w");
for (osp = first; osp != NULL; osp = osp->next) {
fwrite(osp->surn, sizeof osp->surn, 1, h);
fwrite(osp->name, sizeof osp->name, 1, h);
}
fclose(h);
}
struct pat *
make_structure(void)
{
struct pat *a;
a = malloc(sizeof(struct pat));
// NOTE: do this for good measure
a->next = NULL;
return (a);
}
void
add_to_list(struct pat *pat)
{
if (first == NULL)
first = pat;
else
prev->next = pat;
prev = pat;
}
I was still trying to figure out the reason of my failure
feof
我已经更改为长度检查
fread
.
Of course I was going to organize better the program using functions
osp
为空但已链接到列表中。松散地,一个“僵尸”记录,如果你愿意的话。
add_to_list
总是最后完成[仅针对整个/完整记录]。
read_archive
和
add_new_entries
,当它们被调用时,它们都会得到一个完整/完整的列表,其中只有有效的、完全形成的记录。这就是他们的“契约(Contract)”。
excuse me for the OT, but could you suggest to me a good IDE for C - C++ that works well with Debian/GNU Linux ?
I'm at home with Code::Blocks, but unfortunately the so called nightly build is buggy and crashes very often
(the code completion utility is very useful but I must not type str..., otherwise it freezes), and that's very frustrating!
codeblocks
.它看起来干净简单。我也安装了
eclipse
并查看了
kdevelop
.从几个网页来看,eclipse 获得高分,
netbeans
紧接着
eclipse
得到我的投票,因为它似乎有足够的功能来控制我将在下面提示的所有内容;-)
hjkl
箭头键的别名,如
vi
做。必须将右手移到箭头键上并返回会减慢速度,以至于无法启动。
gvim
[图形
vim
],所以这是一个加号。
vim
只需键入
/
即可允许正则表达式搜索,所以再一次,最常见的操作是“触手可及”
ddd
是围绕 [非常强大]
gdb
的图形包装器.
ddd
为常见事物提供图形包装器和窗口,但仍然允许
gdb
的直接文本窗口提示,因此您可以手动输入更高级的命令(例如
watch symbol
)。
git
上出售了。 .因此,如果 IDE 不支持
git
,这是一个非启动器。
git
具有如此多的功能,以至于它们无法包含在 GUI 中。所以,真正强大的东西在终端窗口中使用命令行工具。
xterm
window ,
vi
,
git
,以及我的工具套件 [目前有 250,000 行
perl
脚本 ;-)]
关于c - 将链表保存并加载到二进制文件 (C),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37821720/
前言:笔记是参考B站up主尚硅谷,图片、代码都是哦。在blog写笔记~(图片、代码来源尚硅谷,侵权必删!) 尚硅谷数据结构学习路线B站网站:https://www.bilibili.com/video
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我想创建一个没有全局变量的单个链表。我用 NULL 初始化了第一个元素,然后想将第一个元素 node 复制到 list_。它被复制到函数中,但副作用不起作用。在我的主函数中,该值仍然是NULL。如果我
我正在尝试使链表与此处的链表相似: linked list in C 那就是在另一个结构中有“头”,我首先称它为“头”。但是我发现做那个改变。很难向 list_item 结构添加值。我已经尝试了一些东
我正在尝试理解链表的代码。我明白他们是如何工作的。我正在查看一些与动态内存和链表有关的代码,我在此处对其进行了简化: #include #include typedef struct nod
有人可以解释下面的代码吗?我是 C 的新手,正在努力弄清楚。为什么我们最后有 queueNodeT? typedef char queueElementT; typedef struct queueN
场景如下:- 我想反转单链表的方向,换句话说,反转后所有指针现在应该指向后.. 这个算法应该需要线性时间。 我想到的解决方案是使用另一个数据结构 A Stack.. 借助它可以轻松反转单向链表,所有指
在 python 中使用链表最简单的方法是什么?在 scheme 中,链表由 '(1 2 3 4 5) 定义。 Python 的列表 [1, 2, 3, 4, 5] 和元组 (1, 2, 3, 4,
本文首发公众号:小码A梦 一般数据主要存储的形式主要有两种,一种是数组,一种是链表。数组是用来存储固定大小的同类型元素,存储在内存中是 一片连续 的空间。而链表就不同于数组。链表
虽然之前有人问过关于链表与数组的问题,但答案大多归结为我们大多数人在某个时候可能已经学到的东西: 列表擅长插入和删除 数组擅长随机访问 现在像 Bjarne Stroustrup 这样受人尊敬的人有
位置 在堆中,碎片化(每个节点的 malloc) - 在几种不同的方式(缓慢分配,缓慢访问,内存碎片)方面效率低下 在堆中,在一个大块中 - 当需要重新分配 时,数据结构获得的所有灵活性都将丢失 在堆
我完成了泛型的学习,但并不容易。不过,我确实明白了。这是我的理解。我希望您纠正我的错误并回答几个问题:)。 public class LinkedList { //class definition }
我将如何创建一个链接列表来在 OCaml 中保存我的数据?我正在尝试制作一个单链表,但是我遇到了语法问题。我只想制作一个模块来简单地从链表中获取'a,插入'a或删除'a。 有人知道吗? 最佳答案 正如
我在使用这段代码时遇到了问题,我不确定我做错了什么 #include #include #include #include typedef struct flight_struct{
我正在创建一个函数来删除给定列表的最后一个节点(作为参数输入)。该函数本身非常简单,如下所示。 function popBack(list) { var current = list.head
我正在尝试开发一种方法,该方法将在链接列表中的当前节点之前插入传递给它的节点。它有3个条件。对于此实现,不能有任何头节点(仅对列表中第一个节点的引用),并且我无法添加更多变量。 如果列表为空,则将传递
使用 scala,我已将大约 100000 个节点添加到链表中。当我使用函数 length 时,例如 mylist.length。我收到“java.lang.StackOverflowError”错误
所以我正在学习处理链表。我将如何递归地添加节点内的项目。我可以通过执行 sum = h.item +h.next.item+h.next.next.item 添加它们,但这只有在我有小的链接列表时才有
所以我一直在努力理解链表的概念(一直在看一些示例代码,我在互联网上找到了这个。现在如果我能请别人确认我是否正确掌握了一些概念。我将绘制图表,说明我认为每个代码链接的作用。 #include #inc
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我是一名优秀的程序员,十分优秀!