接受一个句子并打印具有相同连续字符的单词

时间:2015-08-02 07:29:48

标签: java string character bluej

这是我的作业:

  

接受一个句子并打印连续字符相等的单词

     

INPUT:每天一个苹果保持

     

输出:苹果保持

以下是我的工作内容:

import java.util.*;

public class Program1
{
    public static void main(String args[]) 
    {
        Scanner sc=new Scanner(System.in);
        System.out.println("Enter a sentence");
        String s=sc.nextLine();
        String str=s.toLowerCase(); 
        int l,i=0; char c,d;int a,b,m=0;int n=0; String r=""; String res="";
        l=s.length();
        str=" "+str+" ";
        for(i=0;i<(l-1);i++)
        {
            c=str.charAt(i);
            d=str.charAt(i+1);
            a=c;
            b=d;
            m=str.indexOf(' ');
            n=str.indexOf(' ',(i+1)); 
             if(d==' ')
              { 
               m=str.indexOf(' ',(i-1));
               n=str.indexOf(' ',(i+1));
            }  
            if(a==b)
             {
               r=str.substring(m,n);
               res=res +" "+ r;
              }

         }
         System.out.println(res);
     }
}

它被编译,但它没有给出正确的输出。

如果我输入上面的例子,它会返回:

an apple   an apple a day keeps

我需要做什么?

3 个答案:

答案 0 :(得分:1)

你可以做这样的事情来实现结果,

Scanner sc = new Scanner(System.in);
System.out.println("Enter a sentence");
String s = sc.nextLine();
String str = s.toLowerCase();
String[] words = str.split(" ");   // Split the sentence into an array of words.

for(String ss : words){
    char previousChar = '\u0000';
    for (char c : ss.toCharArray()) {
        if (previousChar == c) {    // Same character has occurred
            System.out.println(ss);
            break;
        }
        previousChar = c;
    }
}

答案 1 :(得分:0)

问题在于:

 m=str.indexOf(' ');

你每次都会在句子的开头开始,所以你将句子从头开始打印到你想要的单词。

答案 2 :(得分:0)

这是我的建议。 :-D

输入: mi aasas es mass pp

输出: aasas mass pp

import java.util.*;

public class code10
{
    public static void main(String args[]) 
    {
        Scanner sc=new Scanner(System.in);
        System.out.println("Enter a sentence");
        String s=sc.nextLine();
        String str=s.toLowerCase(); 

        String cadena = str;
        String delimitadores= "[ .,;?!¡¿\'\"\\[\\]]+";
        String[] palabrasSeparadas = cadena.split(delimitadores);

        for(int x=0; x<palabrasSeparadas.length; x++)
        {
          char[] tmpstr = palabrasSeparadas[x].toCharArray();
          for(int y=0; y<tmpstr.length; y++)
          {
            if((y+1) < tmpstr.length)
            {
              if(tmpstr[y] == tmpstr[y+1])
              {
                System.out.print(palabrasSeparadas[x] + " ");
              }
            }
          }
        }

        System.out.println("");
     }
}