我正在阅读K&R C编程语言书籍,并尝试解决所有练习。
有一个示例程序可以在输入中找到最长的字符串。它基本上从输入中一一读取字符串,并将最长的字符串存储在具有预定义长度的数组中。换句话说,它假定最长字符串的长度为上限。
在此程序之后,有一个练习要求更改程序,使其不承担长度上的限制。我不知道在不使用动态内存分配的情况下如何实现这一点(本书的后续章节对此进行了讨论)。
如果我是对的,那么在编译过程中会在C中定义数组,因此除非我们动态分配内存,否则它们的长度是静态的。
答案 0 :(得分:2)
我假设您是指第30页的练习1.16。 完整的声明是
练习1-16。修改最长一行程序的主例程,以便它将 正确打印尽可能长的输入行的长度,并尽可能打印 文字。
如果字符串的长度是任意的,则不可能返回整个字符串,因为您必须将其存储,这将需要动态内存分配。但是,您可以稍微修改主例程,以便它可以正确计算字符串的长度,并输出“尽可能多”的文本,即最大固定长度。
这是一个可能的答案:
#define MAXLINE 1000 /* maximum input line size */
main() {
int buf_len; /* current buffer length (<= MAXLINE) */
int len = 0; /* current full line length */
int max = 0; /* maximum length seen so far */
char buffer[MAXLINE]; /* current input line */
char line[MAXLINE]; /* prefix of longest-line candidate */
char longest[MAXLINE]; /* longest line saved here */
while ((buf_len = getline(buffer, MAXLINE)) > 0) {
if (len == 0) /* this is the first chunk of the string */
copy(line, buffer);
len += buf_len;
if (buf_len < MAXLINE || buffer[MAXLINE-2] == '\n') {
/* the string was terminated */
if (len > max) {
max = len;
copy(longest, line);
}
/* this line was fully processed */
/* now reset len to 0 and process the next string */
len = 0;
}
}
if (max > 0)
printf("%s", longest);
return 0;
}