本题要求编写程序,从给定字符串中查找某指定的字符。
输入格式:
输入的第一行是一个待查找的字符。第二行是一个以回车结束的非空字符串(不超过80个字符)。
输出格式:
如果找到,在一行内按照格式“index = 下标”输出该字符在字符串中所对应的最大下标(下标从0开始);否则输出"Not Found"。
输入样例1:
m programming
结尾无空行
输出样例1:
index = 7
结尾无空行
输入样例2:
a 1234
输出样例2:
Not Found
输入一个字符串时可能在最后有多个空格才打回车,但是scanf是默认到空格就结束读取,空格后就被放进输入缓冲区了被后面的来读取 ,那么我们可以使用%[^\n]就是遇到回车才会停止输入
我们知道 :scanf() 遇到空格结束输入
可以用 scanf("%[^\n], str") 输入一行数据包括空格,直到遇到换行符 ’ \n ’
scanf("%*[^\n]");//清理输入缓冲区中第一个\n之前的所有字符
scanf("%*c"); //清理输入缓冲区中第一个字符,也就是上次遗留下的\n
scanf("%*[^\n]%*c")是把这两句放在一起
思路:使用m对数组进行遍历
#include<stdio.h>
#include<string.h>
int main()
{
char c;
scanf("%c",&c);
//清空输入缓冲区
getchar();
char str[81]={0};
scanf(" %[^\n]s",str);//输入空格也会继续读取
int index=-1;//先将index赋值为-1
int len=strlen(str);
int i=0;
for(i=0;i<len;i++)
{
if(str[i]==c)//找到了,接收的最大的i
{
index=i;
}
}
if(index>=0)//因为肯在第一个元素就找到了,所以index要大于等于0
{
printf("index = %d",index);
}
else if(index==-1)//-1就是没有找到
{
printf("Not Found");
}
return 0;
}