青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

獨立博客: 哲學(xué)與程序

哲學(xué)與程序

ZOJ@3447題解

http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4190
題意即通過合并求最大的合并數(shù)與最小的合并數(shù)之差。
最大合并數(shù)策略:每次選取最小的兩個數(shù)合并;
最小合并數(shù)策略:每次選最大的K個數(shù)合并。
注意:大數(shù)運算。
#include<stdio.h>
#include
<algorithm>
#include
<vector>
#include
<iterator>
#include
<string.h>
using namespace std;
const int MAXN = 102;

class bigInt

public
    
int num[302], len; 
    bigInt() { num[
0= 0, len = 0; }
    bigInt 
operator=(const int &a) 
    { 
        
int tmp = a; 
        len 
= 0
        
while (tmp) 
            num[len
++= tmp % 10, tmp /= 10
        
if (!len) num[0= 0, len = 1
    }
    bigInt(
const int &a) 
    { 
        
int tmp = a; 
        len 
= 0
        
while (tmp) 
            num[len
++= tmp % 10, tmp /= 10
        
if (!len) num[0= 0, len = 1
    }
    
bool operator<(const bigInt &a) 
    { 
        
if (a.len != len) 
            
return len < a.len; 
        
for (int i = len - 1; i >= 0; i--
            
if (num[i] != a.num[i]) 
                
return num[i] < a.num[i]; 
        
return false
    } 
    bigInt 
operator+(const bigInt &a) 
    { 
        bigInt res; 
        
int i, j, c = 0, adda, addb; 
        
for (i = 0, j = 0; i < len || j < a.len || c; ) 
        { 
            adda 
= 0, addb = 0
            
if (i < len) 
                adda 
= num[i++]; 
            
if (j < a.len) 
                addb 
= a.num[j++]; 
            res.num[res.len
++= (adda + addb + c) % 10
            c 
= (adda + addb + c) / 10
        } 
        
return res; 
    } 
    bigInt 
operator-(const bigInt &b) 
    { 
        bigInt res; 
        
int i, j, c = 0, suba, subb; 
        
for (i = 0, j = 0; i < len || j < b.len || c; ) 
        { 
            suba 
= 0, subb = 0
            
if (i < len) 
                suba 
= num[i++]; 
            
if (j < b.len) 
                subb 
= b.num[j++]; 
            res.num[res.len
++= (suba - subb + c + 10% 10
            c 
= (suba - subb + c + 10/ 10 - 1
        } 
        
for (i = res.len - 1; i > 0; i--
            
if (res.num[i]) break
        res.len 
= i + 1
        
return res; 
    } 
    bigInt 
operator*(const bigInt &b) 
    { 
        bigInt res; 
        
int i, j, c, now, mulb, tmp; 
        memset(res.num, 
0sizeof(int* (len + b.len)); 
        
for (i = 0; i < len; i++
        { 
            now 
= i, c = 0
            
for (j = 0; j < b.len || c; ) 
            { 
                mulb 
= 0
                
if (j < b.len) 
                    mulb 
= b.num[j++]; 
                tmp 
= res.num[now] + num[i] * mulb + c; 
                res.num[now
++= tmp % 10
                c 
= tmp / 10
            } 
        } 
        
for (i = len + b.len - 1; i > 0; i--
            
if (res.num[i]) break
        res.len 
= i + 1
        
return res; 
    } 
    bigInt 
operator/(const bigInt &b) 
    { 
        bigInt res, diva; 
        
int i, j, c; 
        
for (i = len - 1; i >= 0; i--
        { 
            
if (diva.len > 1 || diva.num[0]) 
            { 
                
for (j = diva.len - 1; j >= 0; j--
                    diva.num[j 
+ 1= diva.num[j]; 
                diva.len
++
            } 
            diva.num[
0= num[i]; 
            
if (!diva.len) diva.len = 1
            res.num[i] 
= 0
            
while (!(diva < b)) 
                diva 
= diva - b, res.num[i]++
        } 
        
for (i = len - 1; i > 0; i--
            
if (res.num[i]) break
        res.len 
= i + 1
        
return res; 
    } 
    bigInt 
operator%(const bigInt &b) 
    { 
        bigInt res, diva; 
        
int i, j, c; 
        
for (i = len - 1; i >= 0; i--
        { 
            
if (diva.len > 1 || diva.num[0]) 
            { 
                
for (j = diva.len - 1; j >= 0; j--
                    diva.num[j 
+ 1= diva.num[j]; 
                diva.len
++
            } 
            diva.num[
0= num[i]; 
            
if (!diva.len) diva.len = 1
            res.num[i] 
= 0
            
while (!(diva < b)) 
                diva 
= diva - b, res.num[i]++
        } 
        
for (i = diva.len - 1; i > 0; i--
            
if (diva.num[i]) break
        diva.len 
= i + 1
        
return diva; 
    } 
    
void display() 
    { 
        
int i; 
        
for (i = len - 1; i > 1; i--
            
if (num[i]) break
        
for (; i >= 0; i--
            printf(
"%d", num[i]); 
        printf(
"\n");
    } 
}; 

bool cmp(bigInt a, bigInt b)
{
    
return (b<a);
}
bool cmp1(bigInt a, bigInt b)
{
    
return (a<b);
}

int main()
{
    
int x, n, k;
    vector
<bigInt>v;
    vector
<bigInt>t;
    vector
<bigInt>tmp;
    bigInt tmpx;
    
while(scanf("%d%d",&n,&k)!=EOF)
    {
        v.clear();
        t.clear();
        
for(int i = 0; i < n; i++)
        {
            scanf(
"%d",&x);
            bigInt tmp_x 
= x;
            v.push_back(tmp_x);
        }
        copy(v.begin(),v.end(),back_inserter(t));
        
while(v.size()>1)
        {
            tmp.clear();
            sort(v.begin(),v.end(),cmp);
            
if(v.size()> k){
                
for(int i = k; i < v.size(); i++){
                    tmp.push_back(v[i]);
                }
                tmpx 
= 1;
                
for(int i = 0; i < k; i++){
                    tmpx 
= tmpx * v[i];
                }
                tmpx 
= tmpx + 1;
                tmp.push_back(tmpx);
                v.swap(tmp);
            }
else{
                tmpx 
= 1;
                
for(int i = 0; i < v.size(); i++)
                    tmpx 
= tmpx * v[i];
                tmpx 
= tmpx + 1;
                tmp.push_back(tmpx);
                v.swap(tmp);
            }
        }
        
while(t.size()>1)
        {
            tmp.clear();
            sort(t.begin(),t.end(),cmp1);
            
if(t.size()>2){
                
for(int i = 2; i < t.size(); i++){
                    tmp.push_back(t[i]);
                }
                tmpx 
= 1;
                
for(int i = 0; i < 2; i++){
                    tmpx 
= tmpx*t[i];
                }
                tmpx 
= tmpx + 1;
                tmp.push_back(tmpx);
                t.swap(tmp);
            }
else{
                tmpx 
= 1;
                
for(int i = 0; i < t.size(); i++)
                    tmpx 
= tmpx * t[i];
                tmpx 
= tmpx + 1;
                tmp.push_back(tmpx);
                t.swap(tmp);
            }
        }
        tmpx 
= t[0]-v[0];
        tmpx.display();
    }
    
return 0;
}

posted on 2011-01-07 21:16 哲學(xué)與程序 閱讀(692) 評論(2)  編輯 收藏 引用 所屬分類: Algorithm

評論

# re: ZOJ@3447題解 2011-01-08 21:15 jing

不得不佩服,居然寫了那么多代碼  回復(fù)  更多評論   

# re: ZOJ@3447題解 2011-01-09 10:28 patriking

@jing
貼了一個大數(shù)運算的模版,所以代碼看起來比較多了。  回復(fù)  更多評論   

導(dǎo)航

公告

歡迎訪問 http://zhexue.sinaapp.com

常用鏈接

隨筆分類(37)

隨筆檔案(41)

Algorithm

最新隨筆

搜索

最新評論

獨立博客: 哲學(xué)與程序
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲国产一区二区三区在线播 | 国内精品国产成人| 99精品视频免费全部在线| 欧美成人午夜77777| 老**午夜毛片一区二区三区| 亚洲国产欧美日韩精品| 91久久精品日日躁夜夜躁欧美| 欧美成年人网| 亚洲一区在线直播| 亚洲免费视频观看| 在线观看国产一区二区| 亚洲片国产一区一级在线观看| 欧美日韩在线三级| 久久9热精品视频| 蜜桃av久久久亚洲精品| 在线亚洲+欧美+日本专区| 这里是久久伊人| 国产揄拍国内精品对白| 欧美激情国产高清| 国产精品久久久久99| 久久人91精品久久久久久不卡 | 亚洲精选视频免费看| 国产精品另类一区| 欧美国产亚洲视频| 国产酒店精品激情| 亚洲国产综合在线看不卡| 国产精品视频久久一区| 欧美国产国产综合| 国产精品久在线观看| 免费看成人av| 国产精品稀缺呦系列在线| 欧美大片在线观看一区二区| 国产精品久久久久久福利一牛影视 | 欧美日韩在线高清| 嫩草影视亚洲| 国产精品乱码一区二三区小蝌蚪| 久久另类ts人妖一区二区| 欧美国产日韩一区二区三区| 亚洲欧美中文日韩v在线观看| 久久偷看各类wc女厕嘘嘘偷窃| 亚洲一区二区三区中文字幕| 可以免费看不卡的av网站| 欧美中文字幕在线视频| 欧美日韩中字| 亚洲黄色小视频| 在线成人激情| 欧美在线高清| 欧美在线观看一区| 国产精品久久久久999| 亚洲精品免费一区二区三区| **性色生活片久久毛片| 久久精品人人做人人爽| 欧美一区二区三区在线观看视频 | 免播放器亚洲| 国产日本欧美一区二区三区| 99精品99久久久久久宅男| 亚洲精品日韩一| 免费成人av在线看| 欧美二区在线播放| 在线观看视频日韩| 久久久九九九九| 久久深夜福利| 激情六月综合| 久久精品夜色噜噜亚洲aⅴ| 久久国产精品一区二区| 国产女主播视频一区二区| 亚洲一区二区三区四区五区黄| 亚洲视频福利| 国产精品久久久久久久久久直播 | 国产欧美日韩精品专区| 亚洲一区二区网站| 久久高清免费观看| 狠狠色伊人亚洲综合成人| 欧美专区18| 欧美大尺度在线| 一本色道久久加勒比88综合| 欧美人体xx| 亚洲男人的天堂在线| 久久婷婷麻豆| 亚洲精品黄色| 国产精品国产三级国产aⅴ入口| 一区二区三区四区在线| 欧美在线观看一区| 亚洲福利在线视频| 欧美日本韩国一区| 亚洲一区二区在线免费观看| 久久精品国产精品亚洲| 激情综合色丁香一区二区| 免费日韩精品中文字幕视频在线| 亚洲成色777777女色窝| 中国成人亚色综合网站| 国产精品欧美久久久久无广告| 午夜亚洲性色视频| 亚洲第一精品久久忘忧草社区| av成人福利| 国产午夜精品在线| 欧美成人精品一区| 亚洲性夜色噜噜噜7777| 欧美成人精品福利| 亚洲在线成人| 在线日本欧美| 欧美亚州一区二区三区| 久久久久久亚洲精品杨幂换脸 | 久久综合五月天婷婷伊人| 99视频精品全部免费在线| 久久久久久**毛片大全| 一区二区欧美日韩| 国产伊人精品| 国产精品v日韩精品v欧美精品网站| 午夜精品久久久久久久久| 亚洲电影自拍| 久久久免费观看视频| 一本色道婷婷久久欧美| 伊人激情综合| 国产精品伊人日日| 欧美裸体一区二区三区| 一区二区不卡在线视频 午夜欧美不卡'| 久久久精品欧美丰满| 亚洲一二三区精品| 亚洲人成7777| 永久免费精品影视网站| 国产精品一二三视频| 欧美激情第10页| 久久精品亚洲精品| 先锋影音网一区二区| 一区二区国产精品| 亚洲精品国产欧美| 亚洲国产精品va在线看黑人动漫| 久久久亚洲综合| 欧美在线不卡| 欧美在线视频免费播放| 一区二区三区精品在线| 日韩视频二区| 亚洲免费av电影| 91久久视频| 91久久国产综合久久| 一色屋精品视频在线看| 国模吧视频一区| 国产综合一区二区| 一区视频在线看| 伊人婷婷欧美激情| 麻豆久久精品| 玖玖玖国产精品| 久久野战av| 欧美黄色影院| 亚洲激情影院| 亚洲毛片网站| 在线一区二区日韩| 一区二区三区欧美日韩| 在线亚洲高清视频| 亚洲淫性视频| 午夜精品久久久久久久男人的天堂| 亚洲一区二区视频| 亚洲综合视频1区| 欧美在线观看视频| 六月丁香综合| 欧美高清一区二区| 国产精品扒开腿爽爽爽视频| 国产精品一区二区你懂得| 国产精品无人区| 国产视频久久久久| 黄色成人免费观看| 亚洲精品网站在线播放gif| 亚洲理论在线观看| 先锋影音久久久| 玖玖国产精品视频| 亚洲精品国产精品乱码不99 | 欧美在线观看一区| 欧美成人午夜77777| 99精品视频免费观看| 亚洲男人的天堂在线观看| 久久精品青青大伊人av| 欧美日本精品| 国产综合香蕉五月婷在线| 亚洲啪啪91| 欧美一级成年大片在线观看| 免费的成人av| 中文在线不卡视频| 狂野欧美激情性xxxx| 国产精品theporn| 在线观看日韩www视频免费| 一本在线高清不卡dvd| 久久精品国产69国产精品亚洲 | 能在线观看的日韩av| 一区二区三区欧美在线观看| 久久www免费人成看片高清| 欧美日韩性视频在线| 红桃视频国产一区| 午夜精品久久| 亚洲国产日韩综合一区| 羞羞视频在线观看欧美| 欧美日韩另类国产亚洲欧美一级| 国内偷自视频区视频综合| 亚洲午夜电影| 欧美激情一二区| 欧美伊人影院| 国产精品国产自产拍高清av| 亚洲另类春色国产| 欧美sm极限捆绑bd| 欧美制服第一页|