87. [NOIP2000] 乘積最大

来源:http://www.cnblogs.com/zwfymqz/archive/2017/05/23/6895123.html
-Advertisement-
Play Games

★☆ 輸入文件:cjzd.in 輸出文件:cjzd.out 簡單對比 時間限制:1 s 記憶體限制:128 MB 問題描述 今年是國際數學聯盟確定的“2000——世界數學年”,又恰逢我國著名數學家華羅庚先生誕辰90周年。在華羅庚先生的家鄉江蘇金壇,組織了一場別開生面的數學智力競賽的活動,你的一個好朋友 ...


★☆   輸入文件:cjzd.in   輸出文件:cjzd.out   簡單對比
時間限制:1 s   記憶體限制:128 MB

  問題描述  

 

今年是國際數學聯盟確定的“2000——世界數學年”,又恰逢我國著名數學家華羅庚先生誕辰90周年。在華羅庚先生的家鄉江蘇金壇,組織了一場別開生面的數學智力競賽的活動,你的一個好朋友XZ也有幸得以參加。活動中,主持人給所有參加活動的選手出了這樣一道題目:

 

設有一個長度為N的數字串,要求選手使用K個乘號將它分成K+1個部分,找出一種分法,使得這K+1個部分的乘積能夠為最大。

 

同時,為了幫助選手能夠正確理解題意,主持人還舉瞭如下的一個例子:

 

有一個數字串:312,N=3,K=1時會有以下兩種分法:

 

1)   3*12=36

2)  31*2=62

  

  這時,符合題目要求的結果是:31*2=62

 

  現在,請你幫助你的好朋友XZ設計一個程式,求得正確的答案。

 

  輸  入  

 

  程式的輸入共有兩行:

  第一行共有2個自然數N,K(6≤N≤40,1≤K≤6)

  第二行是一個長度為N的數字串。

 


  輸  出  


  結果顯示在屏幕上,相對於輸入,應輸出所求得的最大乘積(一個自然數)。

 

  樣  例  


輸入


4 2

1231


輸出

62

 

我們用dp[i][j]來表示前i個數中用了j個乘號的最大值

然後我們枚舉我們所有可以取得值,k

那麼dp[i][j]=max(dp[i][j],dp[k][j-1]*calc(k+1,i));

對於每一個i,j我們需要在dp[i][j]和從第k位,用了j-1個乘號,再再乘上後面的值(本次乘相當於用了第i個乘號)

中取一個最大值

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #define LL long long 
 6 using namespace std;
 7 int read(int & n)
 8 {
 9     int flag=0,x=0;char c='/';
10     while(c<'0'||c>'9'){c=getchar();if(c=='-')flag=1;}
11     while(c>='0'&&c<='9')x=x*10+(c-48),c=getchar();
12     if(flag)n=-x;
13     else n=x;
14 }
15 int n,k;
16 char a[101];
17 LL dp[101][101];
18 LL calc(int ll,int rr)
19 {
20     long long int ans=0;
21     for(int i=ll;i<=rr;i++)
22         ans=ans*10+a[i]-48;
23     return ans;
24 }
25 
26 int main()
27 {
28     freopen("cjzd.in","r",stdin);
29     freopen("cjzd.out","w",stdout);
30     cin>>n>>k;
31     scanf("%s",a+1);
32     
33     for(int i=1;i<=n;i++)
34     dp[i][0]=calc(1,i);
35     
36     for(int i=1;i<=n;i++)// 每一位數 
37     {
38         for(int j=1;j<=k&&j<i;j++)//乘號的數目 
39         {
40             for(int k=j;k<i;k++)// k的最小值 到 i 
41             {
42                 dp[i][j]=max(dp[i][j],dp[k][j-1]*calc(k+1,i));
43             }
44         }
45     }
46     cout<<dp[n][k];
47     return 0;
48 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一,安裝編程工具併進入編程界面 首先去https://www.continuum.io/downloads/網站下載Anaconda工具並安裝;打開cmd,輸入jupyter notebook並回車(win7),他會自動幫你打開編輯界面(基於瀏覽器的);點擊new按鈕新建一個Python3的編輯框, ...
  • ★☆ 輸入文件:BlackHawk.in 輸出文件:BlackHawk.out 評測插件 時間限制:0.05 s 記憶體限制:256 MB 【題目描述】 正義的萌軍瞄準了位於南極洲的心靈控制器,為此我們打算用空襲摧毀心靈控制器,然而心靈控制器是如此強大,甚至能緩慢控制飛行員。一群勇敢計程車(feng)兵 ...
  • 輸入:以文件的形式,包括: 1.狀態機的輸入/輸出 2.狀態機中使用的變數 3.狀態機模型 應包括:Nodes、Transition、Condition等信 息 功能:1.根據狀態機格式化數據,完成狀態機函數的自 動生成。 2.(選做)可運用工具完成狀態機的圖形自動生成。註 意圖形工具的輸入格式。 ...
  •   當我們想研究不同sample的某個變數A之間的差異時,往往會因為其它一些變數B對該變數的固有影響,而影響不同sample變數A的比較,這個時候需要對sample變數A進行標準化之後才能進行比較。標準化的方法是對sample 的 A變數和B變數進行loess回歸,擬合變數A關於 ...
  • 題目鏈接 Problem Description Given two sequences of numbers : a[1], a[2], ...... , a[N], and b[1], b[2], ...... , b[M] (1 <= M <= 10000, 1 <= N <= 1000000 ...
  • 這兩天在用python的bottle框架開發後臺管理系統,介面約定使用RESTful風格請求,前端使用jquery ajax與介面進行交互,使用POST與GET請求時都正常,而Request Method使用PUT或DELETE請求時,直接爆“HTTP Error 405: Method Not A ...
  • Django 自稱是“最適合開發有限期的完美WEB框架”。本文參考《Django web開髮指南》,快速搭建一個blog 出來,在中間涉及諸多知識點,這裡不會詳細說明,如果你是第一次接觸Django ,本文會讓你在感性上對Django有個認識,完成本文操作後會讓你有興趣閱讀的相關書籍和文檔。 本博客 ...
  • ★★ 輸入文件:dec.in 輸出文件:dec.out 簡單對比 時間限制:1 s 記憶體限制:128 MB Description 出題是一件痛苦的事情! 題目看多了也有審美疲勞,於是我捨棄了大家所熟悉的A+B Problem,改用A-B了哈哈! 好吧,題目是這樣的:給出一串數以及一個數字C,要求計 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...