как узнать, сколько раз один и тот же элемент в массиве появлялся после друг друга? - PullRequest
0 голосов
/ 10 апреля 2019

Я пытаюсь выяснить, как считать время, когда определенный элемент в массиве появлялся после друг друга . Это похоже на бросание игральных костей, сколько раз число 6 появлялось один за другим.

Например: Если это был результат броска 56611166626634416, то результат будет 2 раза !!

Я уже пытался использовать цикл for и сравнивать элементы, но он продолжает считать, если 6 появлялись более двух раз рядом друг с другом.

package dice;
import java.util.Scanner;
public class dice2 {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int k=0;
         Scanner input1 =new Scanner(System.in);
          Scanner input2 =new Scanner(System.in);
          System.out.println("please enter the number of throws!"); 
          int N=input1.nextInt();
          int count=0;
          String faces[]=new String[N];
          System.out.println("enter the faces of the dice !");
         while((N>=1) && (N<= 100) && (N!=count))
         {
            String x=input2.next();
             switch(x) {

             case "1":
                 faces[count]=x;
                 break;

             case "2":
                 faces[count]=x;
                 break;
             case "3":
                 faces[count]=x;
                 break;
             case "4":
                 faces[count]=x;
                 break;
             case "5":
                 faces[count]=x;
                 break;
             case "6":
                 faces[count]=x;
                 break;

                 default : System.out.println(" enter 1-6");
             }
             count++;    
         }

         for(int i=0;i<faces.length;i++) {
              for(int j=i+1;j<faces.length;j++) {     
                  if((faces[i].equals("6")) && (faces[j].equals("6")) )
                  { 
                      k++; i=j; 
                  }
                  else 
                      break;
              }
         System.out.println("k is "+k);
    }
}

1 Ответ

0 голосов
/ 10 апреля 2019

Ниже приведен рабочий код, который печатает только те числа, которые произошли последовательно:

public class dice
{
    public static void main(String[] args)
    {
        String input = "11555677666551189988777"; //suppose you saved input using Scanner.Next() in 'input'
        char[] number = new char[input.length()];  // will hold each distintive number
        int[] occurence = new int[input.length()]; //will hold the occurence of that number
        int j=0, distinct = 0, visited = -1;

        for (int i = 0; i < input.length() - 1; i++) 
        { 
        // Counting occurrences of input[i] 
            while (input.charAt(i) == input.charAt(i + 1)) 
            {
                if(i!=0)
                {   
                    if (input.charAt(i) != input.charAt(i - 1))
                    {
                        number[j] = input.charAt(i);
                        distinct++;
                        j++;
                    }
                }
                else    
                {
                    number[j] = input.charAt(i);
                    distinct++;
                    j++;
                }
                i++; 
                if(i + 1 == input.length()) 
                    break; 

            } 

        }

        for(int i = 0; i < distinct; i++)
        {  
            int count = 1;  
            for(j = i+1; j < distinct; j++)
            {  
                if(number[i] == number[j])
                {  
                    count++;  
                    //To avoid counting same element again  
                    occurence[j] = visited;  
                }  
            }  
            if(occurence[i] != visited)  
                occurence[i] = count;  
        }  


        System.out.println("----------------------------------------------");  
        System.out.println("         Element    |   Consecutive Occurence");  
        System.out.println("----------------------------------------------");  
        for(int i = 0; i < distinct; i++)
        {  
            if(occurence[i] != visited)  
                System.out.println("                " + number[i] + "   |   " + occurence[i]);  
        }  
        System.out.printf("\nAll other numbers doesn't Occured Consecutively !!"); 
    }
}

Вывод:

----------------------------------------------
         Element    |   Consecutive Occurence
----------------------------------------------
             6      |      3
             1      |      1
             4      |      1

All other numbers doesn't Occurred Consecutively !!!

Надеюсь, это то, что вы хотите,скажи мне, если тебе нужно что-то еще с этим сделать.

...