• BNUOJ 34981 A Matrix


    BNUOJ 34981 A Matrix

    题目地址:BNUOJ 34981

    题意: 
    给你一个把一个排列放到矩阵里面的算法和矩阵,要你从矩阵写出排列。 
    假设答案有多个。输出翻转后字典序最大的那个。

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

    代码

    /*
    *  Author:      illuz <iilluzen[at]gmail.com>
    *  File:        a.cpp
    *  Create Date: 2014-05-29 21:05:38
    *  Descripton:   
    */
    
    #include <cstdio>
    #include <vector>
    using namespace std;
    
    const int N = 1e5 + 10;
    int t, n, m, p[N], tmp, ans[N], cnt;
    bool flag;
    vector<int> v[N];
    
    void dfs(int r, int val) {
    	if (r >= m || p[r] - 1 < 0 || v[r][p[r] - 1] < val)
    		return;
    	ans[cnt++] = v[r][p[r] - 1];
    	dfs(r + 1, v[r][p[r] - 1]);
    	p[r]--;
    }
    
    int main()
    {
    	scanf("%d", &t);
    	for (int cas = 1; cas <= t; cas++) {
    		printf("Case #%d:", cas);
    
    		scanf("%d%d", &n, &m);
    		flag = false;
    
    		for (int i = 0; i < m; i++) {
    			v[i].clear();
    			scanf("%d", &p[i]);
    
    			for (int j = 0; j < p[i]; j++) {
    				scanf("%d", &tmp);
    				v[i].push_back(tmp);
    				if (j > 0 && v[i][j] < v[i][j - 1])
    					flag = true;
    			}
    
    			if (i > 0 && v[i][0] < v[i - 1][0])
    				flag = true;
    		}
    
    		if (flag) {
    			puts(" No solution");
    			continue;
    		}
    
    		cnt = 0;
    		for (int i = p[0] - 1; i >= 0; i--) {
    			ans[cnt++] = v[0][i];
    			dfs(1, v[0][i]);
    		}
    
    		if (cnt != n) {
    			puts(" No solution");
    			continue;
    		}
    		for (int i = cnt - 1; i >= 0; i--)
    			printf(" %d", ans[i]);
    		puts("");
    	}
    	return 0;
    }
    


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

  • 相关阅读:
    java如何编写多线程
    Java调用dll动态库
    HashMap源码解析
    LinkedList源码解析
    ArrayList源码解析
    springboot配置cxf
    java生成二维码
    原生js--跨域消息传递
    原生js--应用程序存储和离线web应用
    原生js--userData
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4623506.html
Copyright © 2020-2023  润新知