国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設(shè)計 > 正文

UVA-12166 天平性質(zhì)+字符處理

2019-11-14 11:16:32
字體:
供稿:網(wǎng)友

          這題思維難度很大,關(guān)鍵是總結(jié)這個性質(zhì)。

  1.天平性質(zhì):某個秤砣重量為w,高度為h,如果要讓這個天平平衡并且以這個秤砣為基準,那么整個天平的總重量為w*(2^h)

  2.利用這個性質(zhì):題目要求秤砣數(shù)量改變最少,就是說盡量多的不改變秤砣重量,把總質(zhì)量作為主鍵,統(tǒng)計總質(zhì)量相同的秤砣個數(shù),

最后計算出數(shù)量最多的,就是不用改變質(zhì)量的最大秤砣數(shù)量,用所有秤砣數(shù)減去不用改變質(zhì)量的最大秤砣數(shù)量就是答案。

  3.當然,用這個性質(zhì),會讓某些秤砣的質(zhì)量變?yōu)樾?shù)。

  4.注意,總重量可能會變成long long類型。

AC代碼:

#include<cstdio>#include<cstring>#include<map>using namespace std;#define max(x,y) (x) > (y) ? (x) : (y)typedef long long LL;const int maxn = 1e6 + 5;char str[maxn];map<LL, int>ha;int node; //numbers of nodevoid dfs(int l, int r, int h){    if(str[l] == '[') {        int p = 0;        for(int i = l + 1; i < r ; ++i){            if(str[i] == '[') ++p;            else if(str[i] == ']') --p;            else if(str[i] == ',' && p == 0) {                dfs(l + 1, i - 1, h + 1); //Left                dfs(i + 1, r - 1, h + 1); //Right            }        }    }    else {        ++node;        int num = 0;        while(l <= r) num = num * 10 + str[l++] - '0';        ha[(LL)num << h]++;    }}int main(){    int T;    scanf("%d", &T);    while(T--) {        node = 0;        scanf("%s", str);        int n = strlen(str);        dfs(0, n-1, 0);        int ans = 0;        for(map<LL, int>::iterator c = ha.begin(); c != ha.end(); ++c) {            ans = max(ans, c->second);        }        PRintf("%d/n",node - ans);        ha.clear();    }    return 0;}如有不當之處歡迎指出!


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 河曲县| 万盛区| 离岛区| 门头沟区| 绥江县| 外汇| 定安县| 廊坊市| 商水县| 柘城县| 沧州市| 江山市| 迁安市| 周宁县| 长子县| 蛟河市| 衡南县| 惠安县| 余庆县| 新民市| 伽师县| 乐山市| 通辽市| 肇源县| 玉田县| 昭觉县| 古交市| 礼泉县| 精河县| 青岛市| 泊头市| 呼伦贝尔市| 台江县| 龙山县| 周宁县| 天津市| 乌鲁木齐市| 县级市| 灵台县| 成武县| 北川|