烙饼排序问题最优次数求解

将直径不同的烙饼有序排列的问题,求取最优解需要的反转次数。

代码:

 

ExpandedBlockStart.gif
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace CakeSorting
{
    
class Program
    {
        
private int[] cakeSizeArray;//大饼直径队列
        private int[] cakeArray;//大饼队列
        const int cakeNum = 5;
        
private int maxTime = 0;
        
static void Main(string[] args)
        {
            Program p 
= new Program();
            p.run();
        }

        
void run()
        {
            init();
            search(
0);
            Console.WriteLine(
"maxtime is :{0}", maxTime);
            Console.ReadLine();
        }

        
void init()
        {
            
//初始化赋值
            maxTime = 2 * (cakeNum - 1);
            cakeArray 
= new int[cakeNum];
            cakeSizeArray 
= new int[cakeNum];
            
for (int i = 0; i < cakeSizeArray.Length; i++)
            {
                cakeSizeArray[i] 
= i;
            }
//大饼直径初始化
            randomCollection();
            
//队列初始化完毕

        }

        
void randomCollection()
        {
            
if (cakeSizeArray.Length != cakeArray.Length)
                
return;

            Random r 
= new Random();

            
for (int i = 0; i < cakeSizeArray.Length; i++)
            {
                cakeArray[i] 
= cakeSizeArray[0];
            }

            
for (int i = 1; i < cakeSizeArray.Length; i++)
            {
                
int address = r.Next(10);
                
for(;;)
                {
                    
if (address >= cakeSizeArray.Length)
                        address 
= 0;
                    
if (cakeArray[address] != cakeSizeArray[0])
                        address
++;
                    
else
                        
break;
                }
                cakeArray[address] 
= cakeSizeArray[i];
            }
           
            
//打印结果
            Console.WriteLine("Cake Array:");
            
for (int i = 0; i < cakeArray.Length; i++)
            {
                Console.Write(
"{0}\t", cakeArray[i]);
            }
        }

        
void search(int step)
        {
            
if (step > maxTime)
                
return;//大于2(n-1)时退出

            
for (int i = 1; cakeArray [i-1]<cakeArray [i]; i++)
            {
                
if (i == cakeArray.Length - 1)
                {
                    maxTime 
= step;
                    
return;
                }
            }
//排序成功退出

            
for (int i = 0; i < cakeArray.Length; i++)
            {
                revert(
0, i);
                search(step
+1);
                revert(
0, i);
            }
//递归穷举所有方案
        }

        
void revert(int begin, int end)
        {
            
int t = cakeArray[begin];
            
for (int i = begin, j = end; i < j; i++, j--)
            {
                t 
= cakeArray[i];
                cakeArray[i] 
= cakeArray[j];
                cakeArray[j] 
= t;
            }
        }
    }
}
本文转自today4king博客园博客,原文链接:http://www.cnblogs.com/jinzhao/archive/2008/08/21/1272660.html,如需转载请自行联系原作者
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值