bnu 34982 Beautiful Garden(暴力)
来源:互联网 发布:淘宝上怎么换货 编辑:程序博客网 时间:2024/06/03 15:57
题目链接:bnu 34982 Beautiful Garden
题目大意:给定一个长度为n的序列,问说最少移动多少点,使得序列成等差序列,点的位置可以为小数。
解题思路:算是纯暴力吧,枚举等差的起始和中间一点,因为要求定中间一点的位置,所以这一步是o(n3);然后用o(n)的算法确定说需要移动几个来保证序列等差。
#include <cstdio>#include <cstring>#include <vector>#include <algorithm>using namespace std;const int N = 1e5+5;bool flag;int n, m, c, mv, f[N], r[N], ans[N];vector<int> g[N];int getfar(int x) { return x == f[x] ? x : f[x] = getfar(f[x]);}void init () { scanf("%d%d", &n, &m); flag = false; for (int i = 0; i <= n; i++) r[i] = f[i] = i; for (int i = 0; i < m; i++) g[i].clear(); int t; for (int i = 0; i < m; i++) { scanf("%d", &t); int a, pre = 0; for (int j = 0; j < t; j++) { scanf("%d", &a); g[i].push_back(a); if (a < pre) flag = true; pre = a; } }}bool insert (int x, int d) { for (int j = mv-1; j >= 0; j--) { if (g[d][j] < x) { int p = getfar(g[d][j]); f[p] = x; r[p] = x; mv = j; return true; } } return false;}void put(int x) { ans[c--] = x; if (r[x] != x) put(r[x]);}void solve () { for (int i = m-1; i; i--) { int t = g[i].size(); mv = g[i-1].size(); for (int j = t-1; j >= 0; j--) if (!insert(g[i][j], i-1)) { flag = true; return; } } c = n; int t = g[0].size(); for (int i = t-1; i >= 0; i--) put(g[0][i]);}int main () { int cas; scanf("%d", &cas); for (int i = 1; i <= cas; i++) { init (); printf("Case #%d: ", i); solve(); if (flag) { printf("No solution\n"); } else { for (int j = 1; j < n; j++) printf("%d ", ans[j]); printf("%d\n", ans[n]); } } return 0;}
1 0
- bnu 34982 Beautiful Garden(暴力)
- bnu 34982 Beautiful Garden
- BNU 34982 Beautiful Garden
- BNUOJ 34982 Beautiful Garden
- 北京邀请赛 B. Beautiful Garden
- BNU - Candles - 暴力枚举
- BNUOJ 34982 Beautiful Garden 2014北京邀请赛B (有意思的枚举题)
- 2014北京邀请赛 B Beautiful Garden
- 2014北京邀请赛B Beautiful Garden
- bnu 34986 Football on Table(数学+暴力)
- Garden
- HDU 5062 Beautiful Palindrome Number(暴力)
- HDU 5062Beautiful Palindrome Number(暴力)
- cf#345-B - Beautiful Paintings-暴力
- 【CodeForces】651B - Beautiful Paintings(暴力)
- BNU
- BNU 34986 Football on Table 解题报告(暴力)
- ACM程序设计选修课——1057: Beautiful Garden(模拟+耐心调试)
- 程序员必须知道的10大基础实用算法及其讲解(Javascript代码实现)
- 快速排序-c++(分别用数组和容器实现)
- 黑马程序员--进制转换
- Qt学习之路(6): API文档的使用
- Qt学习之路(7): 创建一个对话框(上)
- bnu 34982 Beautiful Garden(暴力)
- matlab中滤波函数
- OC和DC的比较
- linux学习总结4
- Java中的static静态代码块的使用
- 黑马程序员2.封装&构造函数&构造代码块&this关键字
- MFC--1.初始化对话框位置与大小
- DropDownList和ListBox控件实现数据联动
- 做软件