1592 - Database (UVA)

题目链接如下:

Online Judge

这道题刘汝佳的解法复杂度要低很多。注意到m远小于n,他的解法是遍历不同的列组合c1, c2, 然后再遍历行,如果对应元素相同,输出。

我的解法复杂度高很多,但这道题的时间限制有9秒,所以能AC.....

cpp 复制代码
#include <iostream>
#include <cstdio>
#include <string>
#include <map>
#include <set>
#include <algorithm>
// #define debug
const int maxN = 10001;
const int maxM = 11;
const int comma = 44;

int n, m, pos, pre, cnt = 0;
int table[maxN][maxM];
std::string line, str;
std::map<std::string, int> mp;
char ch;
bool flag;

int main(){
    #ifdef debug
    freopen("0.txt", "r", stdin);
    freopen("1.txt", "w", stdout);
    #endif
    while(scanf("%d %d", &n, &m) == 2){
        getchar();
        for(int i = 1; i <= n; ++i){
            getline(std::cin, line);
            line.push_back(',');
            pre = -1;
            for(int j = 1; j <= m; ++j){
                pos = line.find(',', pre + 1);
                str = line.substr(pre + 1, pos - pre - 1);
                pre = pos;
                if(mp.find(str) == mp.end()){
                    mp[str] = ++cnt;
                }
                table[i][j] = mp[str];
            }
        }
        flag = true;
        for(int i = 1; i < n; ++i){
            for(int j = i + 1; j <= n; ++j){
                std::set<int> st;
                for(int k = 1; k <= m; ++k){
                    if(table[i][k] == table[j][k]){
                        st.insert(k);
                    }
                }
                if(st.size() > 1){
                    printf("NO\n%d %d\n%d %d\n", i, j, *(st.begin()), *(++st.begin()));
                    flag = false;
                    i = n;
                    break;
                }
            }
        }
        printf("%s", flag ? "YES\n" : "");
    }
    #ifdef debug
    fclose(stdin);
    fclose(stdout);
    #endif
    return 0;
}

根据刘汝佳解法改写的代码如下,还是快不少的:

cpp 复制代码
#include <iostream>
#include <cstdio>
#include <string>
#include <map>
#include <algorithm>
// #define debug
const int maxN = 10001;
const int maxM = 11;
const int comma = 44;
const int hashMul = 100001;

int n, m, pos, pre, cnt = 0;
int table[maxN][maxM];
std::string line, str;
std::map<std::string, int> mp;
char ch;
bool flag;

int main(){
    #ifdef debug
    freopen("0.txt", "r", stdin);
    freopen("1.txt", "w", stdout);
    #endif
    while(scanf("%d %d\n", &n, &m) == 2){
        mp.clear();
        for(int i = 1; i <= n; ++i){
            getline(std::cin, line);
            line.push_back(',');
            pre = -1;
            for(int j = 1; j <= m; ++j){
                pos = line.find(',', pre + 1);
                str = line.substr(pre + 1, pos - pre - 1);
                pre = pos;
                if(mp.find(str) == mp.end()){
                    mp[str] = ++cnt;
                }
                table[i][j] = mp[str];
            }
        }
        flag = true;
        for(int i = 1; i < m; ++i){
            for(int j = i + 1; j <= m; ++j){
                std::map<int, int> p;
                for(int k = 1; k <= n; ++k){
                    int temp = table[k][i] * hashMul + table[k][j];
                    if(p.count(temp)){
                        printf("NO\n%d %d\n%d %d\n", p[temp], k, i, j);
                        flag = false;
                        j = m + 1;
                        i = m + 1;
                        break;
                    } else{
                        p[temp] = k;
                    }
                }
            }
        }
        printf("%s", flag ? "YES\n" : "");
    }
    #ifdef debug
    fclose(stdin);
    fclose(stdout);
    #endif
    return 0;
}
相关推荐
恋爱绝缘体19 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
Z1Jxxx10 小时前
加密算法加密算法
开发语言·c++·算法
乌萨奇也要立志学C++10 小时前
【洛谷】递归初阶 三道经典递归算法题(汉诺塔 / 占卜 DIY/FBI 树)详解
数据结构·c++·算法
️停云️11 小时前
【滑动窗口与双指针】不定长滑动窗口
c++·算法·leetcode·剪枝·哈希
charlie11451419111 小时前
嵌入式现代C++教程: 构造函数优化:初始化列表 vs 成员赋值
开发语言·c++·笔记·学习·嵌入式·现代c++
IT=>小脑虎12 小时前
C++零基础衔接进阶知识点【详解版】
开发语言·c++·学习
在路上看风景12 小时前
01. C++是如何工作的
开发语言·c++
码农小韩12 小时前
基于Linux的C++学习——指针
linux·开发语言·c++·学习·算法
小L~~~12 小时前
绿盟校招C++研发工程师一面复盘
c++·面试
微露清风12 小时前
系统性学习C++-第十九讲-unordered_map 和 unordered_set 的使用
开发语言·c++·学习