亚洲免费av电影一区二区三区,日韩爱爱视频,51精品视频一区二区三区,91视频爱爱,日韩欧美在线播放视频,中文字幕少妇AV,亚洲电影中文字幕,久久久久亚洲av成人网址,久久综合视频网站,国产在线不卡免费播放

        ?

        最少錢幣數(shù)量的計算與錢幣面額的確定

        2018-08-20 03:44:22肖紅德
        計算機(jī)工程與應(yīng)用 2018年16期
        關(guān)鍵詞:曲線擬合錢幣差值

        肖紅德

        XIAO Hongde

        河南大學(xué) 數(shù)學(xué)與統(tǒng)計學(xué)院,河南 開封 475004

        School of Mathematics and Statistics,Henan University,Kaifeng,Henan 475004,China

        1 概述

        計算機(jī)作為一種工具,在處理需要大量計算的場合發(fā)揮著巨大的作用,在解決需要大量計算的問題上,一般涉及兩方面:一方面是需要設(shè)計相關(guān)的算法盡量降低算法的復(fù)雜度;另一方面在通過計算機(jī)語言進(jìn)行實現(xiàn)的時候還需要對算法進(jìn)行優(yōu)化,從而使得在解決問題時盡可能地提高效率。本文通過結(jié)合埃拉托色尼篩法、迪杰斯特拉算法和圖的廣度優(yōu)先遍歷算法的思想,提出了一種用來計算平均錢幣數(shù)量的快速算法,即最少錢幣數(shù)量篩法,并通過計算給定范圍的三種錢幣組合計算其平均錢幣數(shù)量,與動態(tài)規(guī)劃算法相比,計算速度明顯加快,與貪心算法相比,計算結(jié)果更好。對于給定范圍、給定錢幣種類,如何確定錢幣組合這個問題,本文通過對不同錢幣之間數(shù)值特征的分析,給出了各個數(shù)值滿足的擬合曲線,從而在尋找最佳錢幣種類組合上使得算法的時間復(fù)雜度大大降低,程序的運算時間大大縮短。文中選擇MATLAB R2017b作為運行環(huán)境,針對上述提出的兩種算法進(jìn)行了具體實現(xiàn)。

        2 相關(guān)研究

        關(guān)于紙幣面值的組合情況研究,Jeffrey已經(jīng)給出了相關(guān)研究結(jié)果,見參考文獻(xiàn)[1]。其結(jié)果如表1所示。

        表2給出的貨幣最佳發(fā)行方案是通過動態(tài)規(guī)劃算法計算出來的。動態(tài)規(guī)劃有關(guān)的算法見參考文獻(xiàn)[2-4],本文計算的結(jié)果與Jeffrey給出的結(jié)果不同,原因是Jeffrey計算的范圍包括1但不包括100,且按照100進(jìn)行平均。如果本文也按照這樣的方法進(jìn)行計算,則得到的結(jié)果與Jeffrey相同。其他錢幣方案中平均錢幣數(shù)量的計算與此類似。

        對于給定某個值,在計算其所需要最少數(shù)量錢幣組合的時候,如果錢幣種類多于兩種,盡管貪心算法計算速度比較快,卻一般不能使用貪心算法進(jìn)行計算,貪心算法的相關(guān)內(nèi)容見參考文獻(xiàn)[2,5-6]。這是由于對于貪心算法計算出來的結(jié)果,在某些組合下不能得到最優(yōu)結(jié)果。比如,使用貪心算法,對于1-5-16-23-33這種組合,在計算32最優(yōu)組合方案時,使用貪心算法計算的結(jié)果是32=23×1+5×1+1×4,一共需要6個錢幣,而如果使用動態(tài)規(guī)劃計算結(jié)果為32=16×2,一共需要2個錢幣。因此,貪心算法在有些情況下得到的不是最優(yōu)錢幣組合。

        對于錢幣種類的確定還有很多其他相關(guān)研究,比如參考文獻(xiàn)[7]研究了有關(guān)增加某個錢幣面額的數(shù)值分析和確定方法。

        3 確定平均錢幣數(shù)量的快速計算方法——最少錢幣數(shù)量篩法

        借助埃拉托色尼篩法(見參考文獻(xiàn)[8-10])、迪杰斯特拉算法(見參考文獻(xiàn)[11-13])、圖的廣度優(yōu)先遍歷算法(見參考文獻(xiàn)[11])的思想,提出一種新的對于給定錢幣種類之后在一定范圍內(nèi)進(jìn)行快速計算最少需要錢幣數(shù)量的算法,以下稱之為最少錢幣數(shù)量篩法。

        最少錢幣數(shù)量篩法實現(xiàn)的具體計算過程如下:

        首先令W為給定數(shù)值的錢幣組合,V為一定范圍內(nèi)的數(shù)據(jù)集合,cur:=1,cur值用于表示當(dāng)前能夠計算出來的錢幣值所需要的最少錢幣數(shù)量,把需要計算的錢幣范圍V分成兩組:

        (1)S,已求出最小錢幣數(shù)量的錢幣集合(初始時為0);

        (2)T:=V-S,尚未確定最小錢幣數(shù)量的錢幣集合(初始時為V的全集)。

        然后進(jìn)行以下計算過程:

        (1)將S中新加入的每一個數(shù)加上W中的每一個數(shù)(初始時認(rèn)為新加入的數(shù)是0),若得到的數(shù)在T中,則將其加入到S中,其錢幣數(shù)量記為cur;

        (2)修改集合T,去除(1)中S新加入數(shù)的集合;

        (3)將cur值加1,即cur:=cur+1;

        (4)重復(fù)執(zhí)行(1)~(3),直到集合T為空。

        4 對任意數(shù)量范圍內(nèi)通過構(gòu)造錢幣組合確定平均錢幣數(shù)量

        對于不同錢幣數(shù)量最優(yōu)組合的確定,給定錢幣范圍[1,n],N種錢幣組合的情況,可以構(gòu)造(n0/N,n1/N,…,n(N-1)/N)這種按照等比數(shù)列規(guī)律出現(xiàn)的一組數(shù)字,這里用(1,a,…,aN-1)表示,其中a=n1/N,為了表達(dá)方便,假設(shè)其為整數(shù)。對于這樣的構(gòu)造方案,其好處是在計算其平均錢幣數(shù)量時可以使用貪心算法來得到某個數(shù)值的錢幣數(shù)量,這樣方便統(tǒng)計其平均錢幣數(shù)量。

        表1 Jeffrey的貨幣最佳發(fā)行方案

        表2 本文計算出來的貨幣最佳發(fā)行方案

        由上面的構(gòu)造組合可以得出以下結(jié)論:錢幣組合方案的最佳組合不高于構(gòu)造組合(1,a,…,aN-1)。對于這樣的構(gòu)造組合,下面通過計算得到平均錢幣數(shù)量。

        f(1)=最大錢幣值為1的錢幣數(shù)值數(shù)量

        f(2)=最大錢幣值為a的錢幣數(shù)值數(shù)量

        f(N)=最大錢幣值為aN-1的錢幣數(shù)值數(shù)量

        則有:

        最后+1表示的是aN,即n這一個數(shù)的表示。從而有:

        從而可以推出總數(shù)量為:

        進(jìn)而說明上述計算的錢幣數(shù)值包含錢幣范圍內(nèi)的所有錢幣數(shù)值。

        對于通過上述方案構(gòu)造的錢幣組合,可以計算其平均錢幣數(shù)量,具體計算過程如下:令t()

        i=由所有最大錢幣面額為ai-1的錢幣組合錢幣數(shù)量之和,其中1≤i≤N。則有:

        最后+a表示的是aN,即n這一個數(shù)的表示,需要的錢幣數(shù)量為a。

        因此,需要的平均錢幣數(shù)量為:

        對于三種錢幣的組合,通過遍歷計算得到的平均錢幣數(shù)量最優(yōu)值和上述構(gòu)造方法得到的平均錢幣數(shù)量比值大約在(0.95,1.00)之間,并且隨著范圍的增大,比值也趨向于增大。

        5 構(gòu)造組合和最優(yōu)組合的對比

        對于最優(yōu)組合的設(shè)計,需要將第一個錢幣固定為1,其他錢幣種類需要進(jìn)行遍歷得到。對于錢幣種類為2的錢幣組合,通過第4章關(guān)于平均錢幣數(shù)量的計算比較容易得到,第二個錢幣值是關(guān)于a0.5的向上取整或向下取整的整數(shù),見表3和圖1。對于錢幣種類大于2的錢幣種類的確定,需要通過遍歷方式得到。

        表3 兩種錢幣組合在最優(yōu)錢幣組合下平均錢幣數(shù)量表

        圖1 兩種錢幣組合平均數(shù)量理論值與實際值對比

        圖1說明:藍(lán)線表示在最優(yōu)錢幣組合下的平均錢幣數(shù)量圖,綠色表示通過構(gòu)造錢幣組合得到的平均錢幣數(shù)量理論值,其公式為y=x1/2-1+x-1/2,其中x表示錢幣范圍,y表示平均需要的錢幣數(shù)量。通過圖1可以發(fā)現(xiàn),對于兩種錢幣的組合,理論值和實際值基本完全吻合。

        以下討論如何確定錢幣的最優(yōu)組合問題。

        對于三種錢幣的最優(yōu)錢幣種類確定問題,當(dāng)取值范圍很大時,需要遍歷次數(shù)太多,因此需要盡可能縮小遍歷次數(shù)。通過計算可知,對于113≤n≤253的情況,第一個數(shù)是固定的1,第二個數(shù)通過已有例子的模擬(見圖4和圖5)可以確定其曲線擬合表達(dá)式為n1040/2711+1255/452,擬合值與真實值的差值在區(qū)間[-8197/521,8107/702]上,第三個數(shù)的曲線擬合表達(dá)式為n25391/38087+1235/478,擬合值與真實值的差值在區(qū)間[-8197/521,8107/702]上。第二個數(shù)的平方與第三個數(shù)的比值處于(2.5,3.2)之間。通過對第二個數(shù)和第三個數(shù)以及第二個和第三個數(shù)之間關(guān)系的限定,可以大大減少遍歷次數(shù)。

        曲線擬合的實現(xiàn)是按照最小二乘法原理進(jìn)行實現(xiàn)的,有關(guān)曲線擬合的MATLAB實現(xiàn)和最小二乘法原理見參考文獻(xiàn)[14-18]。

        對于三種錢幣的最優(yōu)錢幣組合,最終所得結(jié)果見表4和圖2。

        表4 三種錢幣組合在最優(yōu)錢幣組合下平均錢幣數(shù)量表

        圖2 三種錢幣組合平均數(shù)量理論值與實際值對比

        圖2說明:藍(lán)色表示在最優(yōu)錢幣組合下的平均錢幣數(shù)量圖,綠色表示通過構(gòu)造錢幣組合得到的平均錢幣數(shù)量圖,其公式為y=3×a/2-3/2+a-2,其中a=n1/3。由圖2可知,構(gòu)造值比真實值要高,真實值與構(gòu)造值之比主要集中于0.96~0.97之間。

        以下是計算3個最優(yōu)錢幣組合與數(shù)值范圍n相互之間關(guān)系的模擬效果圖。圖3中橫軸表示數(shù)值范圍n,縱軸表示第二個數(shù)的平方與第三個數(shù)的比值。第二個數(shù)和第三個數(shù)之間差值的計算可以通過該結(jié)果進(jìn)行估計。

        第二個參數(shù)和第三個參數(shù)之間的關(guān)系可以通過圖3的模擬結(jié)果進(jìn)行估計。第二個數(shù)的數(shù)量級可以通過圖4的模擬結(jié)果進(jìn)行估計。第三個數(shù)的數(shù)量級可以通過圖5的模擬結(jié)果進(jìn)行估計。

        圖3 三種錢幣組合第二個數(shù)與第三個數(shù)的關(guān)系

        圖4 三種錢幣組合第二個錢幣值的擬合效果圖

        圖3說明:在該圖中,最大值為1296/409(約為3.1687),最小值為361/139(約為2.5971)。

        圖5 三種錢幣組合第三個錢幣值的擬合效果圖

        圖4說明:藍(lán)色曲線表示第二個錢幣種類的真實值,綠色表示第二個錢幣種類的曲線擬合值,其擬合曲線方程為y=x1040/2711+1255/452,其中x表示錢幣的范圍,y表示第二個錢幣種類的曲線擬合值,擬合值和真實值的最大差值為1216/985(約為1.2345),最小差值為-853/475(約為-1.7958)。

        圖5說明:藍(lán)色曲線表示第三個錢幣種類的真實值,綠色表示第三個錢幣種類的曲線擬合值,其擬合曲線方程為y=x25391/38087+1235/478,其中x表示錢幣的范圍,y表示第三個錢幣種類的曲線擬合值,擬合值和真實值的最大差值為8107/702(約為11.5484),最小差值為-8197/521(約為-15.7332)。

        四種以及更多種錢幣組合的確定更為復(fù)雜。與三種錢幣組合的確定類似,第一個數(shù)是固定的1,后面的數(shù)值需要通過遍歷或者通過已經(jīng)找出的數(shù)值發(fā)現(xiàn)數(shù)值規(guī)律,在規(guī)律的基礎(chǔ)上進(jìn)行限制,這里不再討論。

        6 結(jié)論

        本文提出了一種對于給定錢幣組合在給定范圍情況下快速計算需要的平均錢幣數(shù)量的方法,對于三種錢幣組合,給出了一種確定錢幣范圍的計算方法,并在此基礎(chǔ)上對錢幣種類的范圍進(jìn)行了限制,其好處是可以大大減少對于最佳錢幣組合的搜索范圍。

        猜你喜歡
        曲線擬合錢幣差值
        錢幣翻倍
        差值法巧求剛體轉(zhuǎn)動慣量
        組合錢幣
        曲線擬合的方法
        價值工程(2017年31期)2018-01-17 00:34:27
        基于曲線擬合的投棄式剖面儀電感量算法
        電子測試(2017年12期)2017-12-18 06:35:46
        枳殼及其炮制品色差值與化學(xué)成分的相關(guān)性
        中成藥(2017年6期)2017-06-13 07:30:35
        突騎施錢幣和突騎施
        中國錢幣(2016年6期)2016-06-15 20:29:57
        Matlab曲線擬合工具箱在地基沉降預(yù)測模型中的應(yīng)用
        Matlab曲線擬合法在地基沉降預(yù)測中的應(yīng)用
        基于區(qū)域最大值與平均值差值的動態(tài)背光調(diào)整
        国产精品亚洲一区二区三区16| 中国午夜伦理片| 国产a在亚洲线播放| 欧美私人情侣网站| 日本大尺度吃奶呻吟视频| 青青草国产成人99久久| 日韩欧美国产亚洲中文| 一区二区三区精品偷拍| 丝袜美腿在线播放一区二区| 中文字幕一区二区三区四区五区| 男人的天堂免费a级毛片无码| 色欲aⅴ亚洲情无码av蜜桃| 2021精品综合久久久久| 日产国产精品亚洲高清| 精品国品一二三产品区别在线观看| 少妇寂寞难耐被黑人中出| 国产中文aⅴ在线| 中文字幕精品亚洲二区| 久久精品天堂一区二区| 精品无码av一区二区三区不卡| 在线观看特色大片免费视频| 丁香五香天堂网| 国产女同一区二区在线| 亚洲精品综合一区二区| 亚洲精品宾馆在线精品酒店| 国产人与zoxxxx另类| 精品国产v无码大片在线观看| 日韩精人妻无码一区二区三区 | 国产91会所女技师在线观看| 久久久久久人妻无码| 国产欧美日韩一区二区三区在线| 国产91在线精品福利| 日韩av一区二区蜜桃| 免费观看18禁无遮挡真人网站| 日本高清一区二区三区水蜜桃 | 亚洲国产精品特色大片观看完整版| 欧美日本视频一区| 久久亚洲av熟女国产| 中文字幕在线乱码一区| 东京无码熟妇人妻av在线网址| 91精品久久久久含羞草|