C - 文字列 - 文字列理論 - stringヘッダー, strstr関数, 部分文字列の検索
Head First C ―頭とからだで覚えるCの基本、 David Griffiths(著)、 Dawn Griffiths(著)、 中田 秀基(監修)、 木下 哲也(翻訳)、 O’Reilly Media)の 2.5章(文字列 - 文字列理論)、p.90(プールパズル)の解答を求めてみる。
コード
main.c
#include <stdio.h>
#include <string.h>
char tracks[][80] = {
"I left my heart in Harvard Med School",
"Newark, newark - a wonderful town",
"Dancing with a Dork",
"From here to maternity",
"The girl from Iwo Jima"};
void find_track(char search_for[])
{
puts(search_for);
for (int i = 0; i < 5; i++)
{
if (strstr(tracks[i], search_for))
{
printf("曲番号%i: '%s'\n", i, tracks[i]);
}
}
}
int main()
{
find_track("he");
find_track("ne");
}
入出力結果(Terminal, Zsh)
% cc main.c && ./a.out
he
曲番号0: 'I left my heart in Harvard Med School'
曲番号3: 'From here to maternity'
曲番号4: 'The girl from Iwo Jima'
ne
曲番号1: 'Newark, newark - a wonderful town'
%