「已注销」 2022-03-12 10:48 采纳率: 50%
浏览 1125
已结题

查找指定字符。输入一个字符,再输入一个以回车符结束的字符串(少于80个字符),在字符串中查找该字符。如果找到,则输出该字符在字符串中所对应的最大下标,从下标0开始;否则输出"Not Found"。

//查找指定字符。输入一个字符,再输入一个以回车符结束的字符串(少于80个字符),在字符串中查找该字符。
//如果找到,则输出该字符在字符串中所对应的最大下标,从下标0开始;否则输出"Not Found"。
请问哪里错了?编译不出来
#include<stdio.h>
int main()
{
char t,k;
char a[80];
int i=0,j;
scanf("%c",&k);
t=getchar();
while((a[i]=getchar())!='\n')
{
i++;
}
a[i]='\0';
j=i-1;
while(j>=0)
{
if(a[j]==k){printf("%d",k);break;}
else{j--;}
}
if(j==-1){printf("Not Found");}
return 0;
}

  • 写回答

3条回答 默认 最新

  • 关注

    if(a[j]==k){printf("%d",k);break;}这一句中,printf显示的应该是j,不是k,改成
    if(a[j]==k){printf("%d",j);break;}

    修改后运行结果如下:

    img

    完整代码:

    #include<stdio.h>
    int main()
    {
        char t,k;
        char a[80];
        int i=0,j;
        scanf("%c",&k);
        t=getchar();
        while((a[i]=getchar())!='\n')
        {
            i++;
        }
        a[i]='\0';
        j=i-1;
        while(j>=0)
        {
            if(a[j]==k){printf("%d",j);break;}
            else{j--;}
        }
        if(j==-1){printf("Not Found");}
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月21日
  • 已采纳回答 3月13日
  • 修改了问题 3月12日
  • 创建了问题 3月12日

悬赏问题

  • ¥15 ssh登录页面的问题
  • ¥60 渗透一个指定银行app,拿到客户信息,需要什么级别
  • ¥50 关于在matlab上对曲柄摇杆机构上一点的运动学仿真
  • ¥15 jetson nano
  • ¥15 :app:debugCompileClasspath'.
  • ¥15 windows c++内嵌qt出现数据转换问题。
  • ¥20 公众号如何实现点击超链接后自动发送文字
  • ¥15 用php隐藏类名和增加类名
  • ¥15 算法设计与分析课程的提问
  • ¥15 用MATLAB汇总拟合图