BNUOJ 34981 A Matrix

题目地址:

pid=34981" style="color:rgb(0,136,204); text-decoration:none">BNUOJ 34981

题意: 

给你一个把一个排列放到矩阵里面的算法和矩阵,要你从矩阵写出排列。 

假设答案有多个。输出翻转后字典序最大的那个。

分析: 

想了半天仅仅能想到链表版的,并且非常可能TLE,看了帆神的题解后豁然开朗..Orz..

代码:

  1. /*
  2. * Author: illuz <iilluzen[at]gmail.com>
  3. * File: a.cpp
  4. * Create Date: 2014-05-29 21:05:38
  5. * Descripton:
  6. */
  7.  
  8. #include <cstdio>
  9. #include <vector>
  10. using namespace std;
  11.  
  12. const int N = 1e5 + 10;
  13. int t, n, m, p[N], tmp, ans[N], cnt;
  14. bool flag;
  15. vector<int> v[N];
  16.  
  17. void dfs(int r, int val) {
  18. if (r >= m || p[r] - 1 < 0 || v[r][p[r] - 1] < val)
  19. return;
  20. ans[cnt++] = v[r][p[r] - 1];
  21. dfs(r + 1, v[r][p[r] - 1]);
  22. p[r]--;
  23. }
  24.  
  25. int main()
  26. {
  27. scanf("%d", &t);
  28. for (int cas = 1; cas <= t; cas++) {
  29. printf("Case #%d:", cas);
  30.  
  31. scanf("%d%d", &n, &m);
  32. flag = false;
  33.  
  34. for (int i = 0; i < m; i++) {
  35. v[i].clear();
  36. scanf("%d", &p[i]);
  37.  
  38. for (int j = 0; j < p[i]; j++) {
  39. scanf("%d", &tmp);
  40. v[i].push_back(tmp);
  41. if (j > 0 && v[i][j] < v[i][j - 1])
  42. flag = true;
  43. }
  44.  
  45. if (i > 0 && v[i][0] < v[i - 1][0])
  46. flag = true;
  47. }
  48.  
  49. if (flag) {
  50. puts(" No solution");
  51. continue;
  52. }
  53.  
  54. cnt = 0;
  55. for (int i = p[0] - 1; i >= 0; i--) {
  56. ans[cnt++] = v[0][i];
  57. dfs(1, v[0][i]);
  58. }
  59.  
  60. if (cnt != n) {
  61. puts(" No solution");
  62. continue;
  63. }
  64. for (int i = cnt - 1; i >= 0; i--)
  65. printf(" %d", ans[i]);
  66. puts("");
  67. }
  68. return 0;
  69. }

版权声明:本文博客原创文章,博客,未经同意,不得转载。

BNUOJ 34981 A Matrix的更多相关文章

  1. 【BNUOJ19500】 Matrix Decompressing

    https://www.bnuoj.com/v3/problem_show.php?pid=19500 (题目链接) 题意 给出一个R行C列的正整数矩阵,设前${A_i}$项为其前i行所有元素之和,$ ...

  2. bnuoj 34985 Elegant String DP+矩阵快速幂

    题目链接:http://acm.bnu.edu.cn/bnuoj/problem_show.php?pid=34985 We define a kind of strings as elegant s ...

  3. bnuoj 16493 Just Pour the Water(矩阵快速幂)

    http://www.bnuoj.com/bnuoj/problem_show.php?pid=16493 [题解]:矩阵快速幂 [code]: #include <cstdlib> #i ...

  4. BNUOJ 12756 Social Holidaying(二分匹配)

    题目链接:http://www.bnuoj.com/bnuoj/problem_show.php?pid=12756 Social Holidaying Time Limit: 3000ms Memo ...

  5. angular2系列教程(十一)路由嵌套、路由生命周期、matrix URL notation

    今天我们要讲的是ng2的路由的第二部分,包括路由嵌套.路由生命周期等知识点. 例子 例子仍然是上节课的例子:

  6. Pramp mock interview (4th practice): Matrix Spiral Print

    March 16, 2016 Problem statement:Given a 2D array (matrix) named M, print all items of M in a spiral ...

  7. Atitit Data Matrix dm码的原理与特点

    Atitit Data Matrix dm码的原理与特点 Datamatrix原名Datacode,由美国国际资料公司(International Data Matrix, 简称ID Matrix)于 ...

  8. Android笔记——Matrix

    转自:http://www.cnblogs.com/qiengo/archive/2012/06/30/2570874.html#translate Matrix的数学原理 在Android中,如果你 ...

  9. 通过Matrix进行二维图形仿射变换

    Affine Transformation是一种二维坐标到二维坐标之间的线性变换,保持二维图形的"平直性"和"平行性".仿射变换可以通过一系列的原子变换的复合来 ...

随机推荐

  1. C# 5.0 Async函数的提示和技巧

    一.创建Async函数 Async是C# 5.0中新增的关键字,通过语法糖的形式简化异步编程,它有如下三种方式: async Task<T> MyReturningMethod { ret ...

  2. HDU--3081--Marriage Match II--最大匹配,匈牙利算法

    Marriage Match II Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  3. retry policy is RetryUpToMaximumCountWithFixedSleep(maxRetries=10, sleepTime=1 SECONDS)

    [root@qa bin]# hadoop fs -ls / Warning: $HADOOP_HOME is deprecated. 14/07/29 13:25:35 INFO ipc.Clien ...

  4. UI标签库的话题:JEECG智能开发平台 BaseTag(样式表和JS标签的引入)

    UI标签库专题一:JEECG智能开发平台 BaseTag(样式表和JS引入标签) 1.BaseTag(样式表和JS引入标签) 1.1. 演示样例 <t:base type="jquer ...

  5. [LeetCode92]Reverse Linked List II

    题目: Reverse a linked list from position m to n. Do it in-place and in one-pass. For example:Given 1- ...

  6. 宝更容易使用比读IC卡信息的工具

    编程语言:VC++ 更新时间:2014.10.23 操作系统:windowAll 工具:PCSC读卡器 在上一个博文<<解惑:NFC手机怎样轻松读取银行卡信息?>>中,介绍了支 ...

  7. SICP-2锻炼.34

    [锻炼2.34] 为x给定值,找到一个多项式x的值,它也可以被形式化为累积. 下多项式的值: an*x^n + an-1*x^n-1 + .... + a1*x + a0 採用著名的Horner规则, ...

  8. 最快的方法来清除Chrome浏览器DNS高速缓存

    最快的方法是直接数据url.那么不需要清除dns高速缓存. chrome://net-internals/#dns 一般步骤,要经过下列几项. Chrome - > 扳手 - > 选项 - ...

  9. 【我们都爱Paul Hegarty】斯坦福大学IOS8公开组个人笔记28 ScrollView 幻灯片视图

    随着移动设备,iphone屏幕尺寸的限制.超过内容的屏幕大小为scrollview于,通过滑动来获得.scrollview滑动方向可以是也可以是横向垂直,scrollview可以嵌套,例如,纵向滑动s ...

  10. HDU 1710-Binary Tree Traversals(二进制重建)

    Binary Tree Traversals Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/O ...