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

Accept a sentence and print the words that have same consecutive characters

这是我的作业:

accept a sentence and print the words that have consecutive characters equal

INPUT: an apple a day keeps

OUTPUT: apple keeps

这是我正在做的事情:

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);
     }
}

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

如果我输入上面的例子,它returns:

an apple   an apple a day keeps

我需要做什么?

问题在行:

 m=str.indexOf(' ');

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

你可以这样做来获得结果,

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;
    }
}

这是我的提议。 :-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("");
     }
}