Substrings

Substrings

Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other)
Total Submission(s) : 10   Accepted Submission(s) : 4
Font: Times New Roman | Verdana | Georgia
Font Size:  

Problem Description

You are given a number of case-sensitive strings of alphabetic characters, find the largest string X, such that either X, or its inverse can be found as a substring of any of the given strings.

Input

The first line of the input file contains a single integer t (1 <= t <= 10), the number of test cases, followed by the input data for each test case. The first line of each test case contains a single integer n (1 <= n <= 100), the number of given strings, followed by n lines, each representing one string of minimum length 1 and maximum length 100. There is no extra white space before and after a string. 

Output

There should be one line per test case containing the length of the largest string found.

Sample Input

2
3
ABCD
BCDFF
BRCD
2
rose
orchid

Sample Output

2
2

Author

Asia 2002, Tehran (Iran), Preliminary

#include<iostream>
#include<algorithm>
#include<string>
using namespace std;
bool comp(string str1,string str2){
    return str1.length()<str2.length();
}


string str[112];
int main(){
        int t;
            cin>>t;
        while(t--){
            int n;
                cin>>n;
            int i=0;
            for(i=0;i<n;i++)
                cin>>str[i];
            sort(str,str+n,comp);
            string::iterator p1;
            string::iterator p2;
            string::iterator p0;
            int ans=0,max=0;
            for(p1=str[0].begin();p1<str[0].end();p1++)
                for(p2=str[0].end()-1;p2>=p1;p2--){
                    string ss1=str[0].substr(p1-str[0].begin(),p2-p1+1);
                    string ss2;
                    for(string::iterator it=p2;it>=p1;it--){
                        ss2+=*it;
                    }
                ans=ss1.length();
                int flag=1;
                for(i=1;i<n;i++){
                int x=str[i].find(ss1);
                int y=str[i].find(ss2);
                    if(x==-1&&y==-1){
                    flag=0;
                    break;
                    }
                }
            if(flag==1&&max<=ans)
                max=ans;
            }
          cout<<max<<endl;
        }
    return 0;
}

<think>嗯,用户给了一段Java代码,看起来有问题。他们想了解这段代码或者得到解释。首先,我需要仔细看一下代码的结构。 代码是: for(String substring:substrings){ System.out.println(substrings); } 用户可能在这里犯了常见的错误。首先,这里使用的是增强型for循环,变量名是substring,但循环体内打印的是substrings,也就是集合本身,而不是每次迭代的substring。这会导致循环每次输出整个集合,而不是每个元素。这应该是个笔误,正确应该是System.out.println(substring);。 接下来,我需要确认substrings这个集合是否存在,是否已经正确初始化。如果substrings没有被定义或者为null,这段代码会抛出空指针异常。这也是需要注意的地方。 然后,我应该考虑可能的场景,用户可能在遍历一个字符串数组或列表,想逐个打印每个子字符串,但因为变量名打错,导致结果不符合预期。这时候需要指出变量名的正确使用,并给出修正后的代码示例。 另外,还要解释增强型for循环的工作原理,确保用户理解循环变量和集合的关系。可能还需要提到常见的错误类型,比如并发修改异常,如果在遍历过程中修改集合的话,但这里的问题更基础,是变量名错误。 总结用户的代码问题,主要是打印了集合对象而不是元素,需要修正变量名,并检查集合是否正确初始化。然后给出正确的代码示例,说明每个部分的作用,帮助用户理解哪里出错了,以及如何修复。</think>你提供的Java代码片段中存在一个常见的逻辑错误,具体分析如下: ### 原代码分析 ```java for(String substring:substrings){ System.out.println(substrings); } ``` #### 问题说明: 1. **变量误用**:循环变量声明为 `substring`(单数),但输出语句中错误地使用了集合变量 `substrings`(复数) 2. **预期行为偏离**:此代码会重复打印整个集合对象(如数组或列表)的地址/哈希值,而非逐个输出元素内容 ### 修正后的代码 ```java for(String substring:substrings){ System.out.println(substring); // 注意变量名改为单数 } ``` ### 关键知识点 1. **增强for循环结构**: ```java for(元素类型 变量名 : 集合/数组){ // 使用当前元素(变量名) } ``` 2. **正确执行条件**: - `substrings` 必须是已初始化的可迭代对象(如数组、List集合) - 如果 `substrings` 为null会抛出 `NullPointerException` ### 完整示例 ```java import java.util.Arrays; import java.util.List; public class Main { public static void main(String[] args) { List<String> substrings = Arrays.asList("A", "B", "C"); for(String substring : substrings){ System.out.println(substring); // 正确输出每个元素 } } } ``` ### 输出结果 ``` A B C ``` 建议检查代码中的变量命名一致性,这种错误通常是由于拼写疏忽造成的。在实际开发中,使用IDE的语法高亮功能可以快速识别此类问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值