私は本「TheCProgrammingLanguage」の演習の1つに従っていました:http://users.powernet.co.uk/eton/kandr2/krx116.html
以下のプログラムでは、たとえば、入力ファイルに行 'h \ n'が含まれている場合、getline関数はiとjを0に初期化します。'h 'はEOFまたは' \ n 'ではないため、ループ内のブロックは次のように実行されます。 jが0であるため、cはs配列ポインタの0インデックスに割り当てられます。次にjが1にインクリメントします。次にブロックが終了し、iカウンタが1にインクリメントします。ループは次の文字が '\ nかどうかをチェックします。 '、そしてそうなので、ブロックは終了します。この時点で、iとjは両方とも1に等しくなります。cは '\ n'に等しいため、jは1であるため、cはsポインタのインデックス1に挿入されます。次にjは2にインクリメントされます。次にiはインクリメントされます。次に、jが2であるため、ヌルターミネータ '\ 0'がsポインタのインデックス2に挿入されます。iも2であるため、関数は2を返します。
j変数のポイントがわかりません。それが増加するとき、私もそうするからです。誰かが私が間違っていたと言った:
「異なるレートでインクリメントされるため。iカウンターは文字列の長さを追跡するために使用されます。j変数は、処理の最後に、ヌルターミネータが文字列内に入る必要があるポイントを格納します。 「」
ただし、iとjは同じ値であるため(一方は次々にインクリメントされる)、上記の例ではiも2に等しいため、ヌルターミネータを配置する必要があるポイントまでiを使用できます。
#include <stdio.h>
#define MAXLINE 1000 /* maximum input line size */
int getline(char line[], int maxline);
void copy(char to[], char from[]);
/* print longest input line */
int main(void)
{
int len; /* current line length */
int max; /* maximum length seen so far */
char line[MAXLINE]; /* current input line */
char longest[MAXLINE]; /* longest line saved here */
max = 0;
while((len = getline(line, MAXLINE)) > 0)
{
printf("%d: %s", len, line);
if(len > max)
{
max = len;
copy(longest, line);
}
}
if(max > 0)
{
printf("Longest is %d characters:\n%s", max, longest);
}
printf("\n");
return 0;
}
/* getline: read a line into s, return length */
int getline(char s[], int lim)
{
int c, i, j;
for(i = 0, j = 0; (c = getchar())!=EOF && c != '\n'; ++i)
{
if(i < lim - 1)
{
s[j++] = c;
}
}
if(c == '\n')
{
if(i <= lim - 1)
{
s[j++] = c;
}
++i;
}
s[j] = '\0';
return i;
}
/* copy: copy 'from' into 'to'; assume 'to' is big enough */
void copy(char to[], char from[])
{
int i;
i = 0;
while((to[i] = from[i]) != '\0')
{
++i;
}
}
私は正しいですか、それとも間違っていますか?
あなたは完全に正しくありません。入力文字列が制限よりも長い場合、ループは、結果文字列に入力されていなくても、入力文字をカウントするためにiをインクリメントし続けます。
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加