UVa 1592 Database

本文探讨了UVA 1592 Database问题的解决方案,对比了使用STL与C字符串和哈希表的不同效率。通过分析刘大爷版本的代码,解释了如何利用getline()和find()函数避免 cin >> n >> m 后的换行符问题,以及如何高效地处理数据并使用ID函数存储子串。最后,介绍了print()函数的实现,帮助理解二维数组的构建过程。
摘要由CSDN通过智能技术生成

其实紫书在第五章STL初步的时候介绍这个题,主要是为了演示STL的各种用法,但是效率会比较低。实践中一般会使用C字符串和哈希表来实现。

我自己先写过一遍,就是先将数据一行行的读入一个string类型的数组中,然后设计一个函数,用来取指定行指定列的子串,然后主程序开始从第一列的第一行一直遍历到最后一行,中间每取出一个子串就将其保存到一个map映射表中,键为该子串,值为该子串所在的行数。若该子串在同一列出现过,我们就对其后面几列进行判断。这样一来我就写了4个循环,结果一提交发现,Time limit exceeded。这样超时了,这种方法行不通。

于是我找到了这个题的刘大爷版本来好好研究:
先看mian()函数:

//全局变量
typedef pair<int,int> PII;
const int maxr = 10000 + 5;
const int maxc = 10 + 5;
int m, n, db[maxr][maxc], cnt;
map<string, int> id;

//主函数
int main() {
  string s;
  
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值