N1k000000 2022-12-22 13:57 采纳率: 84.4%
浏览 58
已结题

输入一个单词,查询书名中含有指定单词的书的书名及价格

输出结果不对求修改

#include "stdio.h"
#include "string.h"
#define N 10
struct Book
{   char name[100];
    float price;
};
int instring(char *s1,char *s2); //s1若属于s2的字串,则返回1,否则返回0
int main()
{   struct Book books[N]={{"Fling in sky",23.0},{"I love my mother",15.5},{"My love",25.6},{"Color is red",34.9},{"Black and red",20.5},{"Let me love you",16.0}, {"Sun is red",45.0},{"Flower sunshine",23.8},{"Say love not easy",45.9},{"Friday black",34.0}};
    int i;
    char name[20];
    gets(name);
    for(i=0;i<N;i++)
        if(instring(name,books[i].name))
           printf("%30s,%6.2f\n",books[i].name,books[i].price);
    return 0;
}
int instring(char *s1,char *s2)
{  
int i=0,j=0,flag=0;
for(i=0;i<strlen(s2);i++,s2++)
{
if(*s2==*s1)
{
flag=1;
for(j=0;j<strlen(s1);j++,s1++,s2++)
if(*s1!=*s2)
flag=0;
break;
}
}
return flag;
}

  • 写回答

2条回答 默认 最新

  • 於黾 2022-12-22 14:02
    关注

    你要先将书名的单词分解,然后单词跟单词去比对
    你这是在查询子串,那输入一个e,书名里含有red,也会认为有这个单词,但是其实根本没有e这个单词
    此外,s2++在内层和外层同时进行,很快字符串2就被遍历到头了,它一直不回到开头,所以你的代码连查询子串也做不到

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

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