UVA, 10336 Rank the Languages
难点在于:递归函数和输出;
#include <iostream>
#include <vector>
#include <algorithm>
#include <map>
using namespace std;
class Rank{
private:
int length,width,ans=0;
char c;
vector <char> v;
int a[26][1000];
map <char,int> m; //output
char field[1000][1000];
public:
void Readcase(){
cin>>width>>length;
for(int i=0;i<width;i++){
for(int j=0;j<length;j++){
cin>>field[i][j];
}
}
}
void Computing(){
for(int i=0;i<width;i++)
for(int j=0;j<length;j++){
vector<char>::iterator it=find(v.begin(),v.end(),field[i][j]);
if(it!=v.end()) continue; //找到了
else v.push_back(field[i][j]);
}
for(int i=0;i<v.size()-1;i++)
if(v[i]>v[i+1]) swap(v[i],v[i+1]);
for(int k=0;k<v.size();k++){
c=v[k];
for(int i=0;i<width;i++){
for(int j=0;j<length;j++){
if(field[i][j]==c){
dfs(i,j);
ans++;
}
}
}
m.insert(map<char,int>::value_type(c,ans));
ans=0;
}
}
void Output(){
int l=m.size(),max;
map<char,int>::iterator it3;
while(l--){
max=m.begin()->second;
for(map<char,int>::iterator it2=m.begin();it2!=m.end();it2++){
if(it2->second>max) max=it2->second;
}
for(it3=m.begin();it3!=m.end();it3++){
if(max==it3->second) break;
}
cout<<it3->first<<": "<<it3->second<<endl;
m.erase(it3);
}
}
void dfs(int x,int y){
field[x][y]='*'; //标记这个地方已经找过了
if(0<=x&&x<width&&0<=y&&(y-1)<length&&field[x][y-1]==c){
dfs(x,y-1);
}
if(0<=x&&x<width&&0<=y&&(y+1)<length&&field[x][y+1]==c){
dfs(x,y+1);
}
if(0<=(x+1)&&(x+1)<width&&0<=y&&y<length&&field[x+1][y]==c){
dfs(x+1,y);
}
if(0<=(x-1)&&(x-1)<width&&0<=y&&y<length&&field[x-1][y]==c){
dfs(x-1,y);
}
}
};
int main()
{
int cases;
cin>>cases;
for(int i=1;i<=cases;i++){
Rank r;
r.Readcase();
r.Computing();
cout<<"World #"<<i<<endl;
r.Output();
}
return 0;
}
UVA, 10336 Rank the Languages的更多相关文章
- [uva] 1671 History of Languages
题目描述 输入两个DFA,判断是否等价. https://uva.onlinejudge.org/external/16/1671.pdf 输入 第一行T 可以接受的字母表 第二行N 状态数 接下去N ...
- UVA 10887 Concatenation of Languages 字符串hash
题目链接:传送门 题意: 给你两个集合A,B,任意组合成新的集合C(去重) 问你最后C集合大小 题解: 暴力 组成的新串hash起来 #include<bits/stdc++.h> usi ...
- OJ题解记录计划
容错声明: ①题目选自https://acm.ecnu.edu.cn/,不再检查题目删改情况 ②所有代码仅代表个人AC提交,不保证解法无误 E0001 A+B Problem First AC: 2 ...
- 2534: Uva10829L-gap字符串
2534: Uva10829L-gap字符串 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 177 Solved: 66[Submit][Statu ...
- 几道hash题
1: UVa 10887 - Concatenation of Languages map 可以做 ,但是输入实在恶心,有空串之类的HASH模板: int Hash(char *s){ int s ...
- UVa 112 - Tree Summing(树的各路径求和,递归)
题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...
- 图-用DFS求连通块- UVa 1103和用BFS求最短路-UVa816。
这道题目甚长, 代码也是甚长, 但是思路却不是太难.然而有好多代码实现的细节, 确是十分的巧妙. 对代码阅读能力, 代码理解能力, 代码实现能力, 代码实现技巧, DFS方法都大有裨益, 敬请有兴趣者 ...
- uva 387 A Puzzling Problem (回溯)
A Puzzling Problem The goal of this problem is to write a program which will take from 1 to 5 puzz ...
- Uva 120 - Stacks of Flapjacks(构造法)
UVA - 120 Stacks of Flapjacks Time Limit: 3000MS Memory Limit: Unknown 64bit IO Format: %lld &a ...
随机推荐
- ASP.NET Aries 入门开发教程6:列表数据表格的格式化处理及行内编辑
前言: 为了赶进度,周末也写文了! 前几篇讲完查询框和工具栏,这节讲表格数据相关的操作. 先看一下列表: 接下来我们有很多事情可以做. 1:格式化 - 键值的翻译 对于“启用”列,已经配置了格式化 # ...
- 23种设计模式--建造者模式-Builder Pattern
一.建造模式的介绍 建造者模式就是将零件组装成一个整体,用官方一点的话来讲就是将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示.生活中比如说组装电脑,汽车等等这些都是建 ...
- 猖獗的假新闻:2017年1月1日起iOS的APP必须使用HTTPS
一.假新闻如此猖獗 刚才一位老同事 打电话问:我们公司还是用的HTTP,马上就到2017年了,提交AppStore会被拒绝,怎么办? 公司里已经有很多人问过这个问题,回答一下: HTTP还是可以正常提 ...
- Java中Comparable与Comparator的区别
相同 Comparable和Comparator都是用来实现对象的比较.排序 要想对象比较.排序,都需要实现Comparable或Comparator接口 Comparable和Comparator都 ...
- 浏览器中用JavaScript获取剪切板中的文件
本文转自我的个人网站 , 原文地址:http://www.zoucz.com/blog/2016/01/29/get-file-from-clipboard/ ,欢迎前往交流讨论 在网页上编辑内容 ...
- spring remoting源码分析--Hessian分析
1. Caucho 1.1 概况 spring-remoting代码的情况如下: 本节近分析caucho模块. 1.2 分类 其中以hession为例,Hessian远程服务调用过程: Hessian ...
- C#创建、安装、卸载、调试Windows Service(Windows 服务)的简单教程
前言:Microsoft Windows 服务能够创建在它们自己的 Windows 会话中可长时间运行的可执行应用程序.这些服务可以在计算机启动时自动启动,可以暂停和重新启动而且不显示任何用户界面.这 ...
- C# 数组的交集、差集、并集
C# 数组的交集.差集.并集 工作中经常会用这方面的知识来检查那些字段是必须输入的,那些是禁止输入. using System; using System.Collections.Generic; u ...
- arcgis api for js入门开发系列五地图态势标绘(含源代码)
上一篇实现了demo的地图查询功能,本篇新增地图态势标绘模块,截图如下: 本篇核心的在于调用API的Draw工具:https://developers.arcgis.com/javascript/3/ ...
- 在redis中使用lua脚本让你的灵活性提高5个逼格
在redis的官网上洋洋洒洒的大概提供了200多个命令,貌似看起来很多,但是这些都是别人预先给你定义好的,但你却不能按照自己的意图进行定制, 所以是不是感觉自己还是有一种被束缚的感觉,有这个感觉就对了 ...