首页 > 代码库 > UVA 538 - Balancing Bank Accounts(贪心)
UVA 538 - Balancing Bank Accounts(贪心)
UVA 538 - Balancing Bank Accounts
题目链接
题意:给定一些人的欠钱关系,要求在n-1次内还清钱,问方案
思路:贪心,处理出每个人最后钱的状态,然后直接每个人都和最后一个人操作即可
代码:
#include <cstdio> #include <cstring> #include <iostream> #include <string> #include <map> using namespace std; const int N = 25; int n, m, have[N]; map<string, int> hash; string name[N]; int main() { int cas = 0; while (~scanf("%d%d", &n, &m) && n || m) { hash.clear(); memset(have, 0, sizeof(have)); for (int i = 1; i <= n; i++) { cin >> name[i]; hash[name[i]] = i; } string a, b; int val; while (m--) { cin >> a >> b >> val; int u = hash[a], v = hash[b]; have[u] += val; have[v] -= val; } printf("Case #%d\n", ++cas); for (int i = 1; i < n; i++) { if (have[i] < 0) cout << name[i] << " " << name[n] << " " << -have[i] << endl; else if (have[i] > 0) cout << name[n] << " " << name[i] << " " << have[i] << endl; have[n] -= have[i]; } printf("\n"); } return 0; }
UVA 538 - Balancing Bank Accounts(贪心)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。