zoukankan      html  css  js  c++  java
  • 字符个数统计

    1、题目描述

    编写一个函数,计算字符串中含有的不同字符的个数。字符在ACSII码范围内(0~127)。不在范围内的不作统计。

    输入描述:

    输入N个字符,字符在ACSII码范围内(0~127)。

    输出描述:

    输出字符的个数。

    输入例子:

    abc

    输出例子:

    3

    2、算法

    方案一

    /*编写一个函数,计算字符串中含有的不同字符的个数。字符在ACSII码范围内(0~127)。不在范围内的不作统计*/
    //输入描述:输入N个字符,字符在ACSII码范围内(0~127)
    //输出描述:输出字符的个数 
    #include<iostream> using namespace std; int main(){ char ch; int arr[128]={0}; int count=0; while(cin>>ch){ if(ch>=0 && ch<=127){ arr[ch]++; } } for(int i=0;i<128;i++){ if(arr[i]>0) count++; } cout<<count<<endl; return 0; }

     注意:这里实际上就是桶排序的思想。

    方案二

    /*C++
    输入字符,ascii值在[0,127]时插入集合set中,输出set中的元素个数。*/
    #include<iostream>
    #include<set>
    using namespace std;
    int main()
    {
        char c;
        set<char> s;
        while(cin>>c){
            if(c>=0 && c<=127){
                s.insert(c);
            }
        }
        cout << s.size() <<endl;
    }
    

      

    方案三

    #include<iostream>
    #include<string>
    #include<map>
    using namespace std;
    int main()
    {
       string s;
       int num=0;
       map<char,int> str;
       while(cin>>s)
       {
           for(int i=0;i<s.length();i++)
           {
               if((s[i]<=127)&&(s[i]>=0))
               {
                  str.insert(pair<char,int>(s[i],1));
               }
               else
               {
                  continue;
               }
           }
           cout<<str.size()<<endl;
       }
        return 0;  
    }
  • 相关阅读:
    CF1093F Vasya and Array
    CF1093D Beautiful Graph
    mysql主主同步
    mysql主从机制的部署与应用
    什么是多项式?
    从线性逼近到多项式逼近:泰勒级数
    机器学习--boosting家族之XGBoost算法
    倾情大奉送--Spark入门实战系列
    [机器学习笔记] 什么是分类,什么是回归?
    kafka中处理超大消息的一些考虑
  • 原文地址:https://www.cnblogs.com/yedushusheng/p/5519105.html
Copyright © 2011-2022 走看看