精选问答
c语言编程问题,请高手解答!!问题是这样的—— 给出一个字符串和多行文字,在这些文字中找到字符串出现的那些行。你的程序还需支持大小写敏感选项:当选项打开时,表示同一个字母的大写和小写看作不同的字符;当选项关闭时,表示同一个字母的大写和小写看作相同的字符。要求输入格式—— 输入的第一行包含一个字符串S,由大小写英文字母组成。   第二行包含一个数字,表示大小写敏感的选项,当数字为0时表示大小写不敏感,当数字为1时表示大小写敏感。   第三行包含一个整数n,表示给出的文字的行数。

2019-04-13

c语言编程问题,请高手解答!!
问题是这样的——
给出一个字符串和多行文字,在这些文字中找到字符串出现的那些行。你的程序还需支持大小写敏感选项:当选项打开时,表示同一个字母的大写和小写看作不同的字符;当选项关闭时,表示同一个字母的大写和小写看作相同的字符。
要求输入格式——
输入的第一行包含一个字符串S,由大小写英文字母组成。
  第二行包含一个数字,表示大小写敏感的选项,当数字为0时表示大小写不敏感,当数字为1时表示大小写敏感。
  第三行包含一个整数n,表示给出的文字的行数。
  接下来n行,每行包含一个字符串,字符串由大小写英文字母组成,不含空格和其他字符。
要求输出格式——
输出多行,每行包含一个字符串,按出现的顺序依次给出那些包含了字符串S的行。
评测用例规模与约定——  1<=n<=100,每个字符串的长度不超过100。
【问题描述】
给出一个字符串和多行文字,在这些文字中找到字符串出现的那些行。你的程序还需支持大小写敏感选项:当选项打开时,表示同一个字母的大写和小写看作不同的字符;当选项关闭时,表示同一个字母的大写和小写看作相同的字符。
【输入格式】
输入的第一行包含一个字符串S,由大小写英文字母组成。
第二行包含一个数字,表示大小写敏感的选项,当数字为0时表示大小写不敏感,当数字为1时表示大小写敏感。
第三行包含一个整数n,表示给出的文字的行数。
接下来n行,每行包含一个字符串,字符串由大小写英文字母组成,不含空格和其他字符。
【输出格式】
输出多行,每行包含一个字符串,按出现的顺序依次给出那些包含了字符串S的行。
【样例输入】
Hello
1
5
HelloWorld
HiHiHelloHiHi
GrepIsAGreatTool
HELLO
HELLOisNOTHello
【样例输出】
HelloWorld
HiHiHelloHiHi
HELLOisNOTHello
【样例说明】
在上面的样例中,第四个字符串虽然也是Hello,但是大小写不正确。如果将输入的第二行改为0,则第四个字符串应该输出。
【评测用例规模与约定】
1<=n<=100,每个字符串的长度不超过100。
优质解答
#include <stdio.h>

//转小写
char tolower( char c)
{
if( c >='A'&& c<='Z')
return c-'A'+'a';
}
//大小写敏感
bool findstr( char * instr, char * findstr)
{
char *s = instr;
char *t ;
while(1)
{
t = findstr;
while( *s != *t && *s != '\0')
s++;
if( *s == '\0')
return false;
while( *t == *s && *t != '\0' && *s !='\0')
s++,t++;
if(*t == '\0')
return true;
}
}
//大小写不敏感
bool findstr_i( char * instr, char * findstr)
{
char *s = instr;
char *t ;
while(1)
{
t = findstr;
while( tolower(*s) != tolower(*t) && *s != '\0')
s++;
if( *s == '\0')
return false;
while( tolower(*s) == tolower(*t) && *t != '\0' && *s !='\0')
s++,t++;
if(*t == '\0')
return true;
}
}

//主函数
int main()
{
char str[100];
char tarstr[100];
int  count;
int  flag;
int  i;

scanf("%s",str);
scanf("%d",&flag);
scanf("%d",&count);
for( i = 0;i< count;i++)
{
scanf("%s",tarstr);
if( 1 == flag && findstr( tarstr, str))
printf("%s",tarstr);
if( 0 == flag && findstr_i( tarstr, str))
printf("%s",tarstr);
}
::fflush(stdin);
getchar();
return 0;
}
#include <stdio.h>

//转小写
char tolower( char c)
{
if( c >='A'&& c<='Z')
return c-'A'+'a';
}
//大小写敏感
bool findstr( char * instr, char * findstr)
{
char *s = instr;
char *t ;
while(1)
{
t = findstr;
while( *s != *t && *s != '\0')
s++;
if( *s == '\0')
return false;
while( *t == *s && *t != '\0' && *s !='\0')
s++,t++;
if(*t == '\0')
return true;
}
}
//大小写不敏感
bool findstr_i( char * instr, char * findstr)
{
char *s = instr;
char *t ;
while(1)
{
t = findstr;
while( tolower(*s) != tolower(*t) && *s != '\0')
s++;
if( *s == '\0')
return false;
while( tolower(*s) == tolower(*t) && *t != '\0' && *s !='\0')
s++,t++;
if(*t == '\0')
return true;
}
}

//主函数
int main()
{
char str[100];
char tarstr[100];
int  count;
int  flag;
int  i;

scanf("%s",str);
scanf("%d",&flag);
scanf("%d",&count);
for( i = 0;i< count;i++)
{
scanf("%s",tarstr);
if( 1 == flag && findstr( tarstr, str))
printf("%s",tarstr);
if( 0 == flag && findstr_i( tarstr, str))
printf("%s",tarstr);
}
::fflush(stdin);
getchar();
return 0;
}
相关标签: 语言 高手 给出 文字 找到 出现 程序 支持
相关问答