题解|翻煎饼Stacks of Flapjacks

简介: 题解|翻煎饼Stacks of Flapjacks

翻煎饼

PC/UVa IDs: 110402/120,

Popularity: B, Success rate:high Level: 2

测试地址:

https://vjudge.net/problem/UVA-120

[问题描述](老师已经为宝宝们翻译好啦)

Stacks and Queues are often considered the bread andbutter of data  structures and find use in architecture, parsing,operating systems, and  discrete event simulation.Stacks are also important in thetheory of  formal languages.

堆栈和队列通常被认为是数据结构的面包和黄油,可用于体系结构、解析,操作系统和离散事件模拟。堆栈在形式语言理论中也很重要。

This problem involves both butter and sustenance inthe form of  pancakes rather than bread in addition to a finicky server who flips  pancakesaccording to a unique, but complete set of rules.

现在的问题涉及黄油和煎饼(而不是面包),同时还有一个根据唯一但完整的规则来翻煎饼的服务器。

Given a stack of pancakes, you are to write a programthat indicates  how the stack can be sorted so that the largest pancake is on the bottom  and thesmallest pancake is on the top.

给你一栈的煎饼,请你编写一个程序用于指示这个栈如何被排序以使得最大的煎饼在最下面而最小的煎饼在最上面。

The size of a pancake is given by the pancake’sdiameter.

煎饼的直径将被给出。

All pancakes in a stack have different diameters.

栈中的所有煎饼的直径都不一样。

Sorting a stack is done by a sequence of pancake“flips”.

对栈排序是通过一系列"翻转"来完成的。

A flip consists of inserting a spatula between twopancakes in a stack  and flipping (reversing) all the pancakes on thespatula (reversing the  sub-stack).

一次翻转的意思是:在两个煎饼之间插入铲子,然后将铲子上面的一堆煎饼整体翻过来。也就是指定一个位置,其上的子栈整体翻转。

A flip is specified by giving the position of thepancake on the  bottom of the sub-stack to be flipped (relative to the whole stack).

翻转的位置将会被给出。

The pancake on the bottom of the whole stack hasposition 1

and the pancake on the top of a stack of n pancakeshas position n.

位置是这样定义的:栈底编号为1,栈顶编号为n

A stack is specified by giving the diameter of eachpancake in the stack in the order in which the pancakes appear.

一个栈的煎饼的给出方式,是从上到下给出煎饼的直径。

For example, consider the three stacks of pancakesbelow (in which pancake 8 is the top-most pancake of the left stack):

举例来说,这是三个栈,左边的栈的最上面的煎饼直径为8

8 7 2

4 6 5

6 4 8

7 8 4

5 5 6

2 2 7

The stack on the left can be transformed to the stackin the middle  via flip(3). The middle stack can be transformed into the right stack  via the commandflip(1).

左侧栈,可在位置3(即直径7)处翻转,得到中间的那个栈,而中间那个栈可在位置1(即直径2)处翻转,得到右侧的栈。

Input(输入)

The input consists of a sequence of stacks ofpancakes. Each stack  will consist of between 1 and 30 pancakes and each pancake will have an  integerdiameter between 1 and 100. The input is terminated by  end-of-file. Each stack is given as a single lineof input with the top  pancake on a stack appearing first on a line, the bottom pancake  appearing last,and all pancakes separated by a space.

输入由多个煎饼栈组成。每个栈有1到30个煎饼,每个煎饼的直径在1-100之间。以文档结束为输入结束。每个栈,独占一行,从左到右依次代表从栈顶到栈底的煎饼的直径,空格隔开。

Output(输出)

For each stack of pancakes, the output should echo theoriginal stack  on one line, followed by some sequence of flips that results in the  stack ofpancakes being sorted so that the largest diameter pancake is on  the bottom and the smallest on top. For eachstack the sequence of flips  should be terminated by a ‘0’ (indicating no more flips necessary).  Once astack is sorted, no more flips should be made.

对于每个煎饼栈,输出首先应原样将栈的数据打印成一行。

随后的一行是翻转位置的次序,空格隔开,以0结束。(结束的目标是最大直径在最下面,最小直径在最上面)。

Sample Input

1 2 3 4 5

5 4 3 2 1

5 1 2 3 4

Sample Output

1 2 3 4 5

0

5 4 3 2 1

1 0

5 1 2 3 4

1 2 0

*/

题解:

/*****************************************

*

  • @author 化粪池堵塞的凶手
  • 思路:将最大值排在末尾然后翻转
  • 先判断最大值,最大值有三种情况分别用三种方法解决:
  • 1.如果最大值在开头则以最尾部的节点为翻转点翻转之后在缩小范围(排除尾部的最大值判断次大值)
  • 2.如果最大值在结尾则直接缩小范围
  • 3.如果最大值在中间,则先将最大值所在处作为翻转点翻转,然后再以开头的节点(下标为0)作为翻转点进行翻转
    */
package 蓝桥;
import java.util.Arrays;
import java.util.Scanner;
/*****************************************
 * 
 * @author 化粪池堵塞的凶手
 * 思路:将最大值排在末尾然后翻转
 * 先判断最大值,最大值有三种情况分别用三种方法解决:
 * 1.如果最大值在开头则以最尾部的节点为翻转点翻转之后在缩小范围(排除尾部的最大值判断次大值)
 * 2.如果最大值在结尾则直接缩小范围
 * 3.如果最大值在中间,则先将最大值所在处作为翻转点翻转,然后再以开头的节点(下标为0)作为翻转点进行翻转
 */
public class 翻煎饼 {
  static int[] a=new int[30],b=new int[30];
  static int n;
  public static void main(String[] args) {
    Scanner scanner=new Scanner(System.in);
    n=scanner.nextInt();
    for (int i = 0; i < n; i++) {
      a[i]=scanner.nextInt();
      b[i]=a[i];
    }
    Arrays.sort(b,0,n);
    paixu(0,n);
    System.out.println("0");
  }
  public static void paixu(int l,int r) {
    int i ;
    for ( i = 0; i < r; i++) {
      if(a[i]!=b[i])
      {
        break;
      }
    }
    if (i==r) {
      return;
    }
    for (int j = 0; j < r; j++) {
      if (a[j]==b[r-1]) {
        if (j==0) {
          fanzhuan(r-1);
          //System.out.println(r-r+1);//  shuchu
          paixu(0,r-1);
          break;
        }
        else if (j==r-1) {
          paixu(0,r-1);
          break;
        }
        else {
          fanzhuan(j);
          fanzhuan(r-1);
          paixu(0,r-1);
          break;
        }
      }
    }
  }
  public static void fanzhuan(int i) {
    System.out.print((n-i)+" ");
    for (int j = 0; j <= i/2; j++) {
      int t=a[j];
      a[j]=a[i-j];
      a[i-j]=t;
    }
  }
}

   


相关文章
|
6月前
|
存储 物联网
【洛谷 P1135】奇怪的电梯 题解(广度优先搜索)
这是一个关于奇怪电梯的编程问题摘要: - 电梯在每层停,且每层有特定数字 $K_i$ 决定上/下按钮的功能。 - 目标是从 $A$ 楼到 $B$ 楼,求最少按键次数,若无法到达则输出 `-1`。 - 输入包括 $N$(楼层数)、$A$(起点)和 $B$(终点),以及每层的 $K_i$ 数字。 - 使用广度优先搜索(BFS)解决,通过队列存储访问过的楼层,避免重复并计算步数。 - 当到达目标楼层时返回步数,队列空时返回 `-1`。
51 0
蓝桥杯:翻硬币
蓝桥杯:翻硬币
71 0
|
C++
【PAT甲级 - C++题解】1049 Counting Ones
【PAT甲级 - C++题解】1049 Counting Ones
68 0
LeetCode每日一题题解:1189. “气球” 的最大数量
LeetCode每日一题题解:1189. “气球” 的最大数量
|
C++
2014秋C++ OJ题解:母牛的故事
课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂“贺老师课堂”同步展示,使用的帐号请到课程主页中查看。  Description  有一头母牛,它每年年初生一头小母牛。每头小母牛从第四个年头开始,每年年初也生一头小母牛。请编程实现在第n年的时候,共有多少头母牛?Input  输入数据由多个测试实例组成,
2303 0
|
机器学习/深度学习 算法 前端开发
「LeetCode」70-爬楼梯⚡️
「LeetCode」70-爬楼梯⚡️
112 0
「LeetCode」70-爬楼梯⚡️
|
算法 前端开发 程序员
「LeetCode」860-柠檬水找零⚡️
「LeetCode」860-柠檬水找零⚡️
124 0
「LeetCode」860-柠檬水找零⚡️
|
算法 前端开发 程序员
「LeetCode」剑指Offer-58-II左旋转字符串⚡️
「LeetCode」剑指Offer-58-II左旋转字符串⚡️
162 0
「LeetCode」剑指Offer-58-II左旋转字符串⚡️