牛客题目
#include <bits/stdc++.h>using namespace std;
int main()
{
int t;
cin>>t;
while(t--)
{
int n;
cin>>n;
string s;
int ans=0;
for(int i=0;i<n;i++)
{
cin>>s;
if(s.find("bnu")!=-1)
{
ans++;
}
}
cout<<ans<<endl;
}
}
我感觉我写的逻辑上没有问题,开始却过不了,求修改
题目链接:https://ac.nowcoder.com/acm/contest/19306/1044 这段代码的问题在于s.find("bnu")返回的是string::npos ,而不是-1 。 string::npos是一个常量,代表未找到匹配的位置。因此,应该将if(s.find("bnu")!=-1)改为if(s.find("bnu")!=string::npos) 。
修改后的代码如下:
#include <bits/stdc++.h>
using namespace std;
int main()
{
int t;
cin>>t;
while(t--)
{
int n;
cin>>n;
string s;
int ans=0;
for(int i=0;i<n;i++)
{
cin>>s;
if(s.find("bnu")!=string::npos)
{
ans++;
}
}
cout<<ans<<endl;
}
return 0;
}
问题分析:
根据您提供的代码,需要统计输入的字符串中包含子串 "bnu" 的个数。从代码逻辑上看,没有明显的错误。
解决方案:
为了定位问题所在,可以进行以下步骤的检查和调试:
1. 检查输入数据是否符合题目要求。根据题目链接,输入的第一行为一个整数 t,表示测试用例的数量,后面是 t 组测试用例。每组测试用例的第一行为一个整数 n,表示接下来有 n 个字符串。确保输入数据格式正确且符合题意。
2. 进行边界条件的检查。例如,查看当输入的 n 为 0 或负数时,程序是否能正常处理。
3. 检查字符串比较的逻辑。代码中使用了 s.find("bnu") 来查找字符串中是否包含子串 "bnu",在找到该子串时,应该返回子串第一次出现的索引位置,如果没有找到,则返回字符串的末尾 npos。可以使用 cout 打印 s.find("bnu") 的结果,查看是否符合预期。
4. 检查循环条件和循环变量的更新。确保循环变量 t 和 n 在每一次循环迭代后正确更新。
5. 完整代码如下:
#include <bits/stdc++.h>
using namespace std;
int main() {
int t;
cin >> t;
while (t--) {
int n;
cin >> n;
int ans = 0;
for (int i = 0; i < n; i++) {
string s;
cin >> s;
if (s.find("bnu") != string::npos) { // 检查子串是否存在
ans++;
}
}
cout << ans << endl;
}
return 0;
}
希望以上解决方案能够帮助您解决问题。如果您还有其他问题,请随时提问。
球一个最佳答案谢谢啦!这对我非常重要!{:10_254:}{:10_254:}{:10_254:}
页:
[1]