Создание счетчика для пузырьковой сортировки - PullRequest
0 голосов
/ 25 октября 2018

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

Его нужно поместить в метод bubblesort().Я считаю, что вам придется добавлять swapItems в +1, чтобы противостоять каждый раз, когда он делает ход.Если бы кто-то мог помочь мне здесь, это было бы очень ценно.

Код, который имеет ">" на левой стороне, является противоположной частью кода.

// Sorting Application

import java.awt.*;
import java.awt.event.*;
import javax.swing.*;

public class Sort2 extends JFrame implements ActionListener{

   private TextField[] items = new TextField[6];
   private JButton btnSort, btnClear, btnReset;
   private TextField tmp;
   private Label status;

   private int pauseInterval = 100; // ms
    
   public static void main(String[] args) {
      new Sort2().setVisible(true);
   }
   
   public Sort2() {
      init();
   }

   public void init() {
      setTitle("Sorting Algorithms");
      setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
      setSize(440, 200);
      JPanel jp = new JPanel(new BorderLayout());
      jp.setPreferredSize(new Dimension(440, 200));
      jp.setBackground(Color.white);
      
      JPanel itemPanel = new JPanel();
      itemPanel.setBackground(Color.white);
      for (int i = 0; i < items.length; i++) {
         items[i] = new TextField(3); 
         items[i].setPreferredSize(new Dimension(30,40));
         itemPanel.add(items[i]);
      }
      initItems();
      itemPanel.add(new Label("Temp:"));
      tmp = new TextField(4);
      tmp.setPreferredSize(new Dimension(30,40));
      tmp.setEditable(false);
      itemPanel.add(tmp);
      itemPanel.add(new Label(""))
         .setPreferredSize(new Dimension(380, 65));
   
      JPanel buttonPanel = new JPanel();
      buttonPanel.setBackground(Color.white);
      btnSort = new JButton("Sort");
      btnReset = new JButton("Reset");
      btnClear = new JButton("Clear");
      btnSort.addActionListener(this);
      btnClear.addActionListener(this);
      btnReset.addActionListener(this);
      buttonPanel.add(btnSort); 
      buttonPanel.add(btnClear); 
      buttonPanel.add(btnReset);
      
      status = new Label("Wating ... ");
      status.setPreferredSize(new Dimension(380, 40));
      JPanel statusPanel = new JPanel();
      statusPanel.setBackground(Color.white);
      statusPanel.add(status, BorderLayout.SOUTH);
      
      jp.add(itemPanel, BorderLayout.NORTH);
      jp.add(buttonPanel, BorderLayout.CENTER);
      jp.add(statusPanel, BorderLayout.SOUTH);
      
      getContentPane().add(jp);
   }

   private void initItems() {
      for (int i = 0; i < items.length; i++) {
         items[i].setText((
            String.valueOf((int)(Math.random()*100))));
      }
   }

   private void pause(int ms) {
      try {
         Thread.sleep(ms);
      } 
      catch (InterruptedException e) {
         showStatus(e.toString());
      }
   }

   private void assign(TextField to, TextField from) {
      Color tobg = to.getBackground();
      to.setBackground(Color.green);
      pause(pauseInterval);
      to.setText(from.getText());
      pause(pauseInterval);
      to.setBackground(tobg);
   }

   private void swapItems(TextField t1, TextField t2) {
      assign(tmp,t1);
      assign(t1,t2);
      assign(t2,tmp);
   }
   
   private boolean greaterThan(TextField t1, TextField t2) {
      boolean greater;
      Color t1bg = t1.getBackground();
      Color t2bg = t2.getBackground(); 
      t1.setBackground(Color.cyan); 
      t2.setBackground(Color.cyan); 
      pause(pauseInterval);
      greater = Integer.parseInt(t1.getText()) < 
              Integer.parseInt(t2.getText());
      pause(pauseInterval);
      t1.setBackground(t1bg);
      t2.setBackground(t2bg);  
      return greater;
   }

>        private void bubbleSort() {
>         int currentCount = 0;
>           showStatus("Sorting ...");
>           boolean swap = true;
>           while (swap) {
>              swap=false;
>              for (int i = 0; i < items.length-1; i++) {
>                 if (greaterThan(items[i],items[i+1])) {
>                    swapItems(items[i],items[i+1]);
>                    swap=true;
>                    for (int step = 1; step <= items.length+1; step++) {
>                        currentCount = currentCount + 1;
>                    }
>                 }
>              } //for
>           } // while
>           showStatus("Sort complete" + " number of swaps = " + currentCount);
>        } // bubbleSort

   public void actionPerformed(ActionEvent e) {
      String command = e.getActionCommand();
      switch (command) {
         case "Clear":
            for (int i = 0; i < items.length; i++) {
               items[i].setText("");
            }
            break;
         case "Sort":
            bubbleSort();
            break;
         case "Reset":
            initItems();
            break;
         default:
            showStatus("Unrecognised button: " + e.toString());
      }
   }

   private void showStatus(String s) {
      status.setText(s);
   }
      
}

Ответы [ 2 ]

0 голосов
/ 25 октября 2018

Пожалуйста, найдите обновленный рабочий код, который считает обмен.

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.Label;
import java.awt.TextField;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;

public class Counter extends JFrame implements ActionListener {

    private TextField[] items = new TextField[6];
    private JButton btnSort, btnClear, btnReset;
    private TextField tmp;
    private Label status;
    private JLabel cntLabel;

    private int pauseInterval = 100;

    public static void main(String[] args) {
        javax.swing.SwingUtilities.invokeLater(new Runnable() {
            public void run() {
                createAndShowGUI();
            }
        });
    }

    private static void createAndShowGUI() {
        Counter f = new Counter();
        f.init();
        f.setVisible(true);
        f.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
    }

    public Counter() {
//      init();
    }

    public void init() {
        setTitle("Sorting Algorithms");
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        setSize(440, 200);
        JPanel jp = new JPanel(new BorderLayout());
        jp.setPreferredSize(new Dimension(440, 200));
        jp.setBackground(Color.white);

        JPanel itemPanel = new JPanel(new FlowLayout());
        itemPanel.setBackground(Color.white);
        for (int i = 0; i < items.length; i++) {
            items[i] = new TextField(3);
            items[i].setPreferredSize(new Dimension(30, 40));
            itemPanel.add(items[i]);
        }

        initItems();

        itemPanel.add(new Label("Temp:"));
        tmp = new TextField(4);
        tmp.setPreferredSize(new Dimension(30, 40));
        tmp.setEditable(false);
        itemPanel.add(tmp);
        itemPanel.add(cntLabel).setPreferredSize(new Dimension(100, 65));


        JPanel buttonPanel = new JPanel();
        buttonPanel.setBackground(Color.white);
        btnSort = new JButton("Sort");
        btnReset = new JButton("Reset");
        btnClear = new JButton("Clear");
        btnSort.addActionListener(this);
        btnClear.addActionListener(this);
        btnReset.addActionListener(this);
        buttonPanel.add(btnSort);
        buttonPanel.add(btnClear);
        buttonPanel.add(btnReset);

        status = new Label("Wating ... ");
        status.setPreferredSize(new Dimension(380, 40));
        JPanel statusPanel = new JPanel();
        statusPanel.setBackground(Color.white);
        statusPanel.add(status, BorderLayout.SOUTH);

        jp.add(itemPanel, BorderLayout.NORTH);
        jp.add(buttonPanel, BorderLayout.CENTER);
        jp.add(statusPanel, BorderLayout.SOUTH);

        getContentPane().add(jp);
    }

    private void initItems() {
        for (int i = 0; i < items.length; i++) {
            items[i].setText((String.valueOf((int) (Math.random() * 100))));
        }
//      if(null!=swapLabel)
//          swapLabel.setText("");
        cntLabel = new JLabel("0");
    }

    private void pause(int ms) {
        try {
            Thread.sleep(ms);
        } catch (InterruptedException e) {
            showStatus(e.toString());
        }
    }

    private void assign(TextField to, TextField from) {
        Color tobg = to.getBackground();
        to.setBackground(Color.green);
        pause(pauseInterval);
        to.setText(from.getText());
        pause(pauseInterval);
        to.setBackground(tobg);
    }

    private void swapItems(TextField t1, TextField t2) {
        assign(tmp, t1);
        assign(t1, t2);
        assign(t2, tmp);
    }

    private boolean greaterThan(TextField t1, TextField t2) {
        boolean greater;
        Color t1bg = t1.getBackground();
        Color t2bg = t2.getBackground();
        t1.setBackground(Color.cyan);
        t2.setBackground(Color.cyan);
        pause(pauseInterval);
        greater = Integer.parseInt(t1.getText()) < Integer.parseInt(t2.getText());
        pause(pauseInterval);
        t1.setBackground(t1bg);
        t2.setBackground(t2bg);
        return greater;
    }

    private void bubbleSort() {
        int currentCount = 0;
        int n = 0;
        showStatus("Sorting ...");
        boolean swap = true;
        while (swap) {
            swap = false;
            for (int i = 0; i < items.length - 1; i++) {
                if (greaterThan(items[i], items[i + 1])) {
                    swapItems(items[i], items[i + 1]);
                    swap = true;
                    currentCount++;
                }
            } // for
        } // while
        showStatus("Sort complete : Swap count = " + currentCount);
    } // bubbleSort

    public void actionPerformed(ActionEvent e) {
        String command = e.getActionCommand();
        switch (command) {
        case "Clear":
            for (int i = 0; i < items.length; i++) {
                items[i].setText("");
            }
            cntLabel = new JLabel("0");
            break;
        case "Sort":
            bubbleSort();
            break;
        case "Reset":
            initItems();
            break;
        default:
            showStatus("Unrecognised button: " + e.toString());
        }
    }

    private void showStatus(String s) {
        status.setText(s);
    }

}
0 голосов
/ 25 октября 2018

Если я правильно понимаю, я думаю, что проблема в том, что у вас есть ненужный цикл for (тот, что с переменной step).Все, что вам нужно сделать, это удалить этот цикл и просто получить следующее:

currentCount += 1; 
// Alternatively, you could also do 'currentCount = currentCount + 1;' or 'currentCount++;'

Таким образом, в общем случае оператор if в вашем методе bubbleSort() должен выглядеть примерно так:

if (greaterThan(items[i], items[i + 1])) {
    swapItems(items[i], items[i + 1]);
    swap = true;
    currentCount += 1;
}
...