C#遞歸算法之分而治之策略
1.分而治之的概念
分而治之是一種使用遞歸解決問題的算法,主要的技巧是將一個大的復雜的問題劃分為多個子問題,而這些子問題可以作為終止條件,或者在一個遞歸步驟中得到解決,所有子問題的解決結合起來就構成了對原問題的解決
2.分而治之的優(yōu)點和缺點
分而治之算法通常包括一個或者多個遞歸方法的調用,當這些調用將數(shù)據(jù)分隔成為獨立的集合從而處理較小集合的時候,分而治之的策略將會有很高的效率,而在數(shù)據(jù)進行分解的時候,分而治之的策略可能會產(chǎn)生大量的重復計算,從而導致性能的降低。
3.畫標尺程序的分析講解
畫標尺是分而治之的策略的一個簡單應用,標尺是由長度為1英寸的單元構成的序列,每個單元的末端有最長的記號,每個寸單元的1/2英寸處的記號要比末端的短,在1/4處的記號比1/2的要短,1/8處比1/4處短,編寫一個程序,在一條線上,用規(guī)則間隔來繪制標記,在特定位置有特定大小的記號。
分析:在一個直線上,我們可以首先將這條直線一分為二,然后對分出來的二個再進行拆分。直到滿足一定的精度要求,比如以最小刻度為1/8英寸為例,drawRuler作為畫標尺的第歸函數(shù),在drawRuler函數(shù)中用一段線段的兩端(起點(startPos),終點(endPos)),和變量h作為參數(shù),標記的基礎高度為baseHeight,而標記的高度應該為h*baseHeight,則標尺的畫法可以分析如下:
計算間隔(0.0,1.0)的中點:midPos = (startPost+endPos)/2;在中點1/2處畫一個標記,高度為3*baseHeight
將中點分隔開的為兩條直線,再使用第歸函數(shù)drawRule,對應的起點,終點為(0.0,0.5)和(0.5,1.0),參數(shù)h-1,這樣可以使高度相比短些
第歸步驟2(h=2)
midPos = (0.0+0.5)/2 (1/4處),高度為 2*baseHeight
midPos = (0.5+1.0)/2 (3/4處)高度為 2*baseHeight
第歸步驟(h=1)
分別在1/8處和7/8處標記,計算方法
midPos = (0.0+0.25)/2 (1/8) 高度為baseHeight
midPos = (0.75+1)/2 (7/8) 高度為baseHeight
用圖示可以表示如下
我們可以將連續(xù)第歸產(chǎn)生的記號看作二叉樹的節(jié)點。樹根h為初值。就是1/2處的記號,每個父記號都產(chǎn)生了兩個子記號。如下圖所示
4.可執(zhí)行程序文件
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
namespace DrawRuler
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
}
void drawRuler(float startPos, float endPos, int h)
{
float baseHeight =4;
if (h > 0)
{
float midPos = (startPos + endPos) / 2;
float height = h * baseHeight;
drawMark(midPos, height);
drawRuler(startPos, midPos, h - 1);
drawRuler(midPos, endPos, h - 1);
}
}
void drawMark(float pos, float height)
{
using (Graphics g = this.CreateGraphics())
{
float xOffset = 100 + pos;
float yOffset = 100-height;
SolidBrush brusuh = new SolidBrush(Color.Black);
Pen p = new Pen(brusuh, 1);
g.DrawLine(p, xOffset, yOffset, xOffset, 100);
}
}
private void Form1_Paint(object sender, PaintEventArgs e)
{
#region 首先畫一條直線
using (Graphics g = e.Graphics)
{
float xOffset = 100;
float yOffset = 100;
int len = 300;
SolidBrush brusuh = new SolidBrush(Color.Black);
Pen p = new Pen(brusuh, 2);
g.DrawLine(p, xOffset, yOffset, xOffset + len, yOffset);
}
#endregion
drawRuler(0, 300, 3);
}
}
}
5.代碼下載
http://xiazai.jb51.net/201606/yuanma/DrawRuler(jb51.net).rar
以上就是本文的全部內容,希望能給大家一個參考,也希望大家多多支持我們。
上一篇:淺談C#中的值類型和引用類型
欄 目:C#教程
下一篇:FTPClientHelper輔助類 實現(xiàn)文件上傳,目錄操作,下載等操作
本文標題:C#遞歸算法之分而治之策略
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/6427.html
您可能感興趣的文章
- 01-10C#一個簡單的定時小程序實現(xiàn)代碼
- 01-10微信開放平臺之網(wǎng)站授權微信登錄功能
- 01-10C#編程自學之數(shù)據(jù)類型和變量二
- 01-10C#編程自學之開篇介紹
- 01-10C#編程自學之數(shù)據(jù)類型和變量三
- 01-10C#編程自學之運算符和表達式
- 01-10C#編程自學之類和對象
- 01-10C#編程自學之數(shù)據(jù)類型和變量一
- 01-10C#編程自學之流程控制語句
- 01-10C#基于委托實現(xiàn)多線程之間操作的方法


閱讀排行
本欄相關
- 01-10C#通過反射獲取當前工程中所有窗體并
- 01-10關于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當前操作系統(tǒng)已
隨機閱讀
- 01-10C#中split用法實例總結
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10SublimeText編譯C開發(fā)環(huán)境設置


