“玲瓏杯”ACM比賽 Round #18--最後你還是AK了(搜索+思維)

来源:http://www.cnblogs.com/chen9510/archive/2017/07/16/7191871.html
-Advertisement-
Play Games

題目鏈接 DESCRIPTION INPUT 題目鏈接 DESCRIPTION INPUT INPUT INPUT OUTPUT OUTPUT SAMPLE INPUT 1 4 2 1 2 5 2 3 5 3 4 5 5 5 SAMPLE INPUT 1 4 2 1 2 5 2 3 5 3 4 5 ...


題目鏈接   DESCRIPTION

 

INPUT

OUTPUT SAMPLE INPUT 1 4 2 1 2 5 2 3 5 3 4 5 5 5 SAMPLE OUTPUT 35 HINT 對於樣例,我們將1和4匹配,2和3匹配,然後對2和3之間的邊使用膜法,對3和4之間的邊使用魔法 若出現爆棧問題,改棧方法請參考1093題目代碼 1093地址:http://www.ifrog.cc/acm/problem/1093  代碼地址:http://ideone.com/Wk24ET   思路:官方題解:             我的理解:其實每條邊上的值的大小並不影響點的匹配,對於任意一條邊來說,對應一個父節點和孩子節點,令以這個孩子為根節點的子樹包含的節點數為 t,總節點數位 n,我們應該儘量使子樹上的點都過這條邊去和子樹以外的點匹配,所以過該邊的最大點對數為min(t,n-t), 所以ans+=min(t,n-t)*w ,可以利用樹上搜索得到該樹的最大可愛值,對於k次使用魔法,可以對每條邊進過的次數進行排序,貪心的吧增量大用得到進過次數多的邊上即可。   代碼如下:
#define OPENSTACK
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <vector>
using namespace std;
typedef long long LL;
const int maxn=1e5+5;
vector<pair<int,int> > v[maxn];
int c[maxn], cn[maxn], tmp, n;
LL ans;

int dfs(int p,int f)
{
    int count=0;
    for(int i=0; i<v[p].size(); i++)
    {
        pair<int,int>pa=v[p][i];
        if(pa.first==f) continue;

        int t=dfs(pa.first,p);
        cn[tmp]=min(t,n-t);
        ans+=(LL)cn[tmp]*(LL)pa.second;
        tmp++;
        count+=t;
    }
    return count+1;
}

int main()
{
    #ifdef OPENSTACK
    long long size = 64 << 20; // 64MB
    char *p = (char*)malloc(size) + size;
    #if (defined _WIN64) or (defined __unix)
        __asm__("movq %0, %%rsp\n" :: "r"(p));
    #else
        __asm__("movl %0, %%esp\n" :: "r"(p));
    #endif
    #endif

    int T,k;  cin>>T;
    while(T--)
    {
        for(int i=0;i<maxn;i++) v[i].clear();
        scanf("%d%d",&n,&k);
        for(int i=1;i<n;i++)
        {
            int u1,u2,w;
            scanf("%d%d%d",&u1,&u2,&w);
            pair<int,int>pa1=make_pair(u1,w);
            pair<int,int>pa2=make_pair(u2,w);
            v[u1].push_back(pa2);
            v[u2].push_back(pa1);
        }
        for(int i=0;i<k;i++) scanf("%d",&c[i]);
        ans=0; tmp=0;
        int res=dfs(1,-1);
        //cout<<"點數-----"<<res<<endl;
        //cout<<"    -----"<<ans<<endl;
        sort(cn,cn+tmp);
        sort(c,c+k);
        for(int i=tmp-1, j=k-1; j>=0; i--, j--)
        {
            ans+=(LL)c[j]*(LL)cn[i];
        }
        printf("%lld\n",ans);
    }
    #ifdef OPENSTACK
    exit(0);
    #else
        return 0;
    #endif
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 前言 Java的基類Object提供了一些方法,其中equals()方法用於判斷兩個對象是否相等,hashCode()方法用於計算對象的哈希碼。equals()和hashCode()都不是final方法,都可以被重寫(overwrite)。 本文介紹了2種方法在使用和重寫時,一些需要註意的問題。 一 ...
  • 引言 如果說JdbcTemplate類是Spring Jdbc的核心類,那麼execute方法算得上Spring Jdbc的核心方法了,畢竟JdbcTemplate的很多public方法內部實際上是調用execute方法實現的。 public T execute(ConnectionCallback ...
  • 第一個註意點:選擇器的使用(標簽、class、id) 三種選擇器中id(#)的優先順序最高,根據id名篩選出唯一元素; 如下輸入:#menu{ width:1200px; height:45px; background:#90F} <div id="menu"></div> 其次是class(.)的優 ...
  • 10年的技術開發團隊,提供網站建設,APP開發,網站推廣等服務,專業微信小程式定製開發,需要這方面的朋友,可以咨詢一下。 案例演示: 成功案例: 聯繫方式:8582-36016 ,微信號:luenmicro ,電話:131-1221-5717 ...
  • 註意 if(i%prime[j]==0) 不要寫成if(!i%prime[j]) ...
  • 三木運算,三元運算 name = 值1 if 條件 else 值2 深拷貝淺拷貝 str創建一個值不能修改,如果修改在,創建一個 對於int和str 賦值,深拷貝,淺拷貝地址是不變的 對於dict,list,tup 淺拷貝僅拷貝最外層 深拷貝是除了最內層都拷貝 函數 動態參數 萬能參數 *arges ...
  • MultiProcessing模塊是一個優秀的類似多線程MultiThreading模塊處理併發的包 之前接觸過一點這個庫,但是並沒有深入研究,這次閑著無聊就研究了一下,算是解惑吧。 ...
  • 歐拉篩素數: 時間複雜度:O(n) 主要思路:對於每一個合數,讓他的最大的約數把他篩去 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...