首页 > 代码库 > HDU 4329 MAP(stringstream的用法)
HDU 4329 MAP(stringstream的用法)
这个题目有点绕,但是按着他的意思写不难模拟出来。本来是一场学弟们的训练赛,我这个学长在赛场上却WA了四次都没过,三条黑线就一直在我的脑袋上挂着。。。
赛后开始找原因,后来发现题目看错了,1/R中的R是指原先URL的个数。
改过来发现还是过不了,想到了自己的输入处理可能是有问题的,既然自己模拟容易出错,那就使用了stringstream,自动提取单词,成功AC。
意外的发现stringstream的功能十分强大,但是因为速度比较慢,用处比较少,所以也不怎么用,这个哥们写的不错,感兴趣可以去看看哦。
具体注释在代码里~
#include<iostream>#include<cstdio>#include<cstring>#include<map>#include<sstream>using namespace std;#define N 110#define M 10005int rel[N];char a[M];map<string,int>mp[N];void Init(int k){ istringstream str(a);///istringstream是一个类,str为它的一个对象 ///这里使用构造函数接受一个字符串 string tmp; int tot = 0; str >> tmp; ///提取一个单词,空格用于区分单词,不可能被提取到单词中 ///其实如果自己模拟出错,应该就是把空格提到了单词中 mp[k].clear(); while(str >> tmp){///怎么样,是不是很短,很方便呢~ tot++; mp[k][tmp] = 1; } rel[k] = tot;}double Get_AveP(int k){ istringstream str(a); string tmp; int i = 0,R = 0; double res = 0; str >> tmp; while(str >> tmp){ ++i; if(mp[k][tmp] == 1) { R++; res += R*1.0/i; } } return res/rel[k];}int main(){// freopen("G.in.cpp","r",stdin); int t,n,ca=0; scanf("%d",&t); while(t--) { scanf("%d",&n); getchar(); for(int i = 1; i <= n; i++) { gets(a); Init(i); } double MAP = 0.0; for(int i = 1; i <= n; i++) { gets(a); MAP += Get_AveP(i); } MAP /= n; printf("Case #%d: %.6lf\n",++ca,MAP); } return 0;}
HDU 4329 MAP(stringstream的用法)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。