Hardwood Species(stl map)

http://acm.sdut.edu.cn:8080/vjudge/contest/view.action?cid=203#problem/B

属于暴力

复制代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <algorithm>
#include <queue>
#include <string>//string在这个头文件里;
#include <map>//map在这个头文件里;
#include <iostream>//cout在这个头文件里;
int cmp(const void *a,const void *b)
{
    return strcmp((char *)a,(char *)b);
}
using namespace std;
char a[1000001][31];
int main()
{
    int i=0;
    map<string,int>q;
    //q.clear();
    while(gets(a[i])!=NULL)
    {
        i++;
    }
    qsort(a,i,sizeof(a[0]),cmp);
    for(int j=0;j<i;j++)
    {
        q[a[j]]++;
    }
    float rr;
    rr=q[a[0]]*100.0/i;
    printf("%s %.4f\n",a[0],rr);
    for(int j=1;j<i;j++)
    {
        if(strcmp(a[j],a[j-1])!=0)
        {
             rr=q[a[j]]*100.0/i;
             printf("%s %.4f\n",a[j],rr);
        }
    }
    return 0;
}
复制代码

 现在STL刚入门

复制代码
#include <string.h>
//#include <stdlib.h>//加了它编译错误
#include <stdio.h>
#include <string>
#include <map>
using namespace std;

int main()
{
    int tt=0;
    char a[100];
    double sum;
    map<string,int>q;
    map<string,int>::iterator it;
    while(gets(a)!=NULL)
    {
        q[a]++;
        tt++;
    }
    for(it=q.begin();it!=q.end();it++)
    {
        sum=100.0*((double)it->second/((double)tt));
        printf("%s %.4lf\n",it->first.data(),sum);
    }
    return 0;
}
复制代码

 这是学长以前写的

这个代码是我第一次写的,不知道为什么 刚开始用了很多头文件,G++ wrong,  c++ 编译错误

现在是 改了头文件后的 AC代码

复制代码
复制代码
 1 #include<cstdio>
 2  #include<string>
 3  #include<iostream>
 4  #include<map>
 5  using namespace std;
 6  
 7  char s[100];
 8  int main()
 9  {
10      map<string,int>mp;
11      map<string,int>::iterator iter;
12      int i,sum=0;
13      while(gets(s)!=NULL)
14      {
15          mp[s]++;
16          sum++;
17      }
18      iter=mp.begin();
19      while(iter!=mp.end())
20      {
21          cout<<iter->first;
22          printf(" %.4lf\n",100*1.0*iter->second/sum);
23          iter++;
24      }
25      return 0;
26  }
27  
复制代码
复制代码
posted @   人艰不拆_zmc  阅读(245)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 张高兴的大模型开发实战:(一)使用 Selenium 进行网页爬虫
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示