例题5-9 数据库(Database,ACM/ICPC NEERC 2009,UVa1592)

2024-04-13 03:32

本文主要是介绍例题5-9 数据库(Database,ACM/ICPC NEERC 2009,UVa1592),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原题链接:https://vjudge.net/problem/UVA-1592
分类:<map>
备注:map的妙用
分析:已经有过几个题通过map把某个数据以数字代表的经历了,这点其实不难想到。为了快一点遍历,不能搞四重循环,按紫书上说的,对于每两列一行行遍历,把之前发现的数据记录下来,如果发现重复的则输出答案然后进入下一个循环即可。

代码如下:

#include<iostream>
#include<cstdio>
#include<string>
#include<vector>
#include<map>
using namespace std;
typedef pair<int, int>PII;
const int maxr = 1e4 + 5;
int ID(string x, map<string, int>& id, int& cnt)
{if (id.count(x))return id[x];return id[x] = ++cnt;
}
int main(void)
{int row, col;while (cin >> row >> col){getchar();int cnt = 0;string line;map<string, int>id;vector<int>biao[maxr];for (int i = 0; i < row; i++){int st, tail = -1;getline(cin, line);for (int j = 1; j <= col; j++){st = tail + 1;tail = line.find(',', st);if (tail == string::npos)tail = line.length();biao[i].push_back(ID(line.substr(st, tail - st), id, cnt));}}map<PII, int>haved; int flag = 0;for (int j = 0; j < col - 1; j++){if (flag)break;for (int k = j + 1; k < col; k++){if (flag)break;haved.clear();haved[PII(biao[0][j], biao[0][k])] = 0;for (int i = 1; i < row; i++){int c1 = biao[i][j], c2 = biao[i][k];if (haved.count(PII(c1, c2))){printf("NO\n%d %d\n%d %d\n", haved[PII(c1, c2)] + 1, i + 1, j + 1, k + 1);flag = 1; break;}else haved[PII(c1, c2)] = i;}}}if (flag)continue;printf("YES\n");}return 0;
}

这篇关于例题5-9 数据库(Database,ACM/ICPC NEERC 2009,UVa1592)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/899026

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意