Sorting a deque using limited operations?

后端 未结 3 702
庸人自扰
庸人自扰 2021-01-13 02:46

Hi I came across a question in the Algorithms 4th Edition by Robert Sedgewick.

Dequeue sort. Explain how you would sort a deck of cards, with the res

3条回答
  •  再見小時候
    2021-01-13 03:18

    A very simple solution is here using java. Just keep shifting the top element by comparing and keep track of the number of sorted elements. On every iteration, it will give us one smallest element based on the position. We will do this based on n and k values. For n values, we will keep shifting based on bigger elements and for k values, we will just keep shifting based on smaller values and eventually, the solution will come. You can try this.

    private void sort(Integer[] a) {
            int n = a.length-1,k=1;
            while (n>0){
                for (int i = 0; i < n; i++) {
                    if (a[1]>a[0]){
                        int temp = a[0];
                        a[0] = a[1];
                        a[1] = temp;
                    }
                    pushToBackAndShift(a);
                }
                for (int i = 0; i < k; i++) {
                    if (a[1]

提交回复
热议问题