煎饼分类的 C 程序?
此 C 程序在整数数组中实施煎饼分类。
煎饼分类是分类问题的一种变体,其中唯一允许的操作是反转序列中某个前缀的元素。
煎饼分类是对在杂乱的煎饼堆中按照大小进行分类这一数学问题的通俗说法,此时可以在堆中的任意一点插入一个铲子,用它翻转在其上方的所有煎饼。煎饼数是给定数量的煎饼所需的最少翻转次数
Input:5,3,2,1,4 Output:1 2 3 4 5
说明
它是分类问题的一种变体,其中唯一允许的操作是反转序列中某个前缀的元素。与尝试用尽可能少的比较次数来分类的传统分类算法不同,它的目标是用尽可能少的反转来对序列进行分类。这个问题的一个变体关注于烧焦的煎饼,其中每个煎饼都有烧焦的一面,此外,所有的煎饼都必须将烧焦的一面包在下面。
示例
#include <iostream> using namespace std; void do_flip(int *, int, int); int pancake_sort(int *list, unsigned int length) { if (length < 2) return 0; int i, a, max_num_pos, moves; moves = 0; for (i = length;i > 1;i--) { max_num_pos = 0; for (a = 0;a < i;a++){ if (list[a] > list[max_num_pos]) max_num_pos = a; } if (max_num_pos == i - 1) continue; if (max_num_pos){ moves++; do_flip(list, length, max_num_pos + 1); } do_flip(list, length, i); } return moves; } void do_flip(int *list, int length, int num) { int swap; int i = 0; for (i=0;i < --num;i++) { swap = list[i]; list[i] = list[num]; list[num] = swap; } } int main(int argc, char **argv) { int arr[]={5,3,2,1,4}; int n=5; int moves=pancake_sort(arr, n); for (int i = 0;i < n;i++) { printf("%d ", arr[i]); } printf(" - with a total of %d moves
", moves); }
广告