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;
}
相关推荐
再睡一夏就好10 分钟前
【C++闯关笔记】STL:deque与priority_queue的学习和使用
java·数据结构·c++·笔记·学习·
我是华为OD~HR~栗栗呀31 分钟前
华为OD-23届考研-测试面经
java·c++·python·华为od·华为·面试·单元测试
Qt程序员1 小时前
基于原子操作的 C++ 高并发跳表实现
c++·线程·c/c++·原子操作·无锁编程
_dindong1 小时前
牛客101:链表
数据结构·c++·笔记·学习·算法·链表
蓝创精英团队2 小时前
C++DirectX9坐标系与基本图元之渲染状态(RenderState)_0304
前端·c++·性能优化
筏.k3 小时前
C++ 设计模式系列:生产者-消费者模式完全指南
开发语言·c++·设计模式
LXS_3577 小时前
Day 05 C++ 入门 之 指针
开发语言·c++·笔记·学习方法·改行学it
挂科是不可能出现的9 小时前
最长连续序列
数据结构·c++·算法
mjhcsp10 小时前
C++ int 类型深度解析:从底层实现到实战应用
c++·int
程序员老舅11 小时前
C++参数传递:值、指针与引用的原理与实战
c++·c/c++·值传递·引用传递·指针传递·参数传递机制