鱼C论坛

 找回密码
 立即注册
查看: 1763|回复: 2

[已解决]牛客题目

[复制链接]
发表于 2023-10-12 23:46:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. int main()
  4. {
  5.     int t;
  6.     cin>>t;
  7.     while(t--)
  8.     {
  9.         int n;
  10.         cin>>n;
  11.         string s;
  12.         int ans=0;
  13.         for(int i=0;i<n;i++)
  14.         {
  15.             cin>>s;
  16.             if(s.find("bnu")!=-1)
  17.             {
  18.                 ans++;
  19.             }
  20.         }
  21.         cout<<ans<<endl;
  22.     }
  23.    
  24. }
复制代码

我感觉我写的逻辑上没有问题,开始却过不了,求修改
题目链接:https://ac.nowcoder.com/acm/contest/19306/1044
最佳答案
2023-10-12 23:46:30
这段代码的问题在于  s.find("bnu")  返回的是  string::npos ,而不是  -1 。 string::npos  是一个常量,代表未找到匹配的位置。因此,应该将  if(s.find("bnu")!=-1)  改为  if(s.find("bnu")!=string::npos) 。

修改后的代码如下:

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. int main()
  4. {
  5.     int t;
  6.     cin>>t;
  7.     while(t--)
  8.     {
  9.         int n;
  10.         cin>>n;
  11.         string s;
  12.         int ans=0;
  13.         for(int i=0;i<n;i++)
  14.         {
  15.             cin>>s;
  16.             if(s.find("bnu")!=string::npos)
  17.             {
  18.                 ans++;
  19.             }
  20.         }
  21.         cout<<ans<<endl;
  22.     }
  23.     return 0;
  24. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-10-12 23:46:30 | 显示全部楼层    本楼为最佳答案   
这段代码的问题在于  s.find("bnu")  返回的是  string::npos ,而不是  -1 。 string::npos  是一个常量,代表未找到匹配的位置。因此,应该将  if(s.find("bnu")!=-1)  改为  if(s.find("bnu")!=string::npos) 。

修改后的代码如下:

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. int main()
  4. {
  5.     int t;
  6.     cin>>t;
  7.     while(t--)
  8.     {
  9.         int n;
  10.         cin>>n;
  11.         string s;
  12.         int ans=0;
  13.         for(int i=0;i<n;i++)
  14.         {
  15.             cin>>s;
  16.             if(s.find("bnu")!=string::npos)
  17.             {
  18.                 ans++;
  19.             }
  20.         }
  21.         cout<<ans<<endl;
  22.     }
  23.     return 0;
  24. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-12 23:47:29 | 显示全部楼层
问题分析:
根据您提供的代码,需要统计输入的字符串中包含子串 "bnu" 的个数。从代码逻辑上看,没有明显的错误。

解决方案:
为了定位问题所在,可以进行以下步骤的检查和调试:

1. 检查输入数据是否符合题目要求。根据题目链接,输入的第一行为一个整数 t,表示测试用例的数量,后面是 t 组测试用例。每组测试用例的第一行为一个整数 n,表示接下来有 n 个字符串。确保输入数据格式正确且符合题意。

2. 进行边界条件的检查。例如,查看当输入的 n 为 0 或负数时,程序是否能正常处理。

3. 检查字符串比较的逻辑。代码中使用了 s.find("bnu") 来查找字符串中是否包含子串 "bnu",在找到该子串时,应该返回子串第一次出现的索引位置,如果没有找到,则返回字符串的末尾 npos。可以使用 cout 打印 s.find("bnu") 的结果,查看是否符合预期。

4. 检查循环条件和循环变量的更新。确保循环变量 tn 在每一次循环迭代后正确更新。

5. 完整代码如下:
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. int main() {
  4.     int t;
  5.     cin >> t;
  6.     while (t--) {
  7.         int n;
  8.         cin >> n;
  9.         int ans = 0;
  10.         for (int i = 0; i < n; i++) {
  11.             string s;
  12.             cin >> s;
  13.             if (s.find("bnu") != string::npos) { // 检查子串是否存在
  14.                 ans++;
  15.             }
  16.         }
  17.         cout << ans << endl;
  18.     }
  19.     return 0;
  20. }
复制代码

希望以上解决方案能够帮助您解决问题。如果您还有其他问题,请随时提问。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-9 12:53

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表