字符个数统计——来自华为OJ平台测试基础篇
2014-09-28 17:03
375 查看
/*
* 字符个数统计
* 描述: 编写一个函数,计算字符串中含有的不同字符的个数。字符在ACSII码范围内(0~127)。不在范围内的不作统计。
* 知识点: 字符串,函数,指针
* 题目来源: 内部整理
* 练习阶段: 初级
* 运行时间限制: 10Sec
* 内存限制: 128MByte
* 输入:
* 输入N个字符,字符在ACSII码范围内(0~127)。
* 输出:
* 输出字符的个数。
* 样例输入: abc
* 样例输出: 3
*/
#include <iostream>
#include <map>
#include <string>
using namespace std;
void Input(std::string &str,int &strlen);
void Count(std::string str,int strlen,int &number);
int main()
{
std::string str;
int strlen = 0;
int num = 0;
Input(str,strlen);
Count(str,strlen,num);
std::cout << num << endl;
system("pause");
return 0;
}
void Input(std::string &str,int &strlen)
{
getline(std::cin,str,'\n');
strlen = str.size();
return;
}
void Count(std::string str,int strlen,int &number)
{
typedef map<char,int> celements;
char c;
celements paris;
for(int i=0;i<strlen;i++)
{
c = str.at(i);
if((c>=0) && (c<=127))
{
++paris[c];
}
}
number = paris.size();
return;
}
/*
* 字符个数统计
* 描述: 编写一个函数,计算字符串中含有的不同字符的个数。字符在ACSII码范围内(0~127)。不在范围内的不作统计。
* 知识点: 字符串,函数,指针
* 题目来源: 内部整理
* 练习阶段: 初级
* 运行时间限制: 10Sec
* 内存限制: 128MByte
* 输入:
* 输入N个字符,字符在ACSII码范围内(0~127)。
* 输出:
* 输出字符的个数。
* 样例输入: abc
* 样例输出: 3
*/
#include <iostream>
#include <map>
#include <string>
using namespace std;
void Input(std::string &str,int &strlen);
void Count(std::string str,int strlen,int &number);
int main()
{
std::string str;
int strlen = 0;
int num = 0;
Input(str,strlen);
Count(str,strlen,num);
std::cout << num << endl;
system("pause");
return 0;
}
void Input(std::string &str,int &strlen)
{
getline(std::cin,str,'\n');
strlen = str.size();
return;
}
void Count(std::string str,int strlen,int &number)
{
typedef map<char,int> celements;
char c;
celements paris;
for(int i=0;i<strlen;i++)
{
c = str.at(i);
if((c>=0) && (c<=127))
{
++paris[c];
}
}
number = paris.size();
return;
}
相关文章推荐
- 统计各类字符个数——来自华为OJ平台测试基础篇
- 计算字符个数——来自华为OJ平台测试基础篇
- 字符统计——来自华为OJ平台测试基础篇
- 字符串匹配——来自华为OJ平台测试的基础篇
- 统计大写字母个数——来自华为OJ平台测试基础篇
- 输入n个整数,输出其中最小的k个——来自华为OJ平台测试基础篇
- DNA序列——来自华为OJ平台测试的基础题
- 句子逆序——来自华为OJ平台测试基础篇
- 找出字符串中第一个只出现一次的字符——来自华为OJ平台测试基础篇
- 华为OJ平台试题 —— 排序:字符统计
- 数字颠倒——来自华为OJ平台测试基础篇
- 字符串反转——来自华为OJ平台测试基础篇
- 在字符串中找出连续最长的数字串 ——来自华为OJ平台测试基础篇
- 华为OJ平台——(基础篇)字符统计
- 华为OJ题目(三):字符统计
- 华为OJ(字符统计)
- 华为OJ基础篇-字符串匹配
- 华为OJ试题:输入一行字符,分别统计出包含英文字母、空格、数字和其它字符的个数
- 【华为OJ】统计字符个数
- 华为OJ平台试题 ——字符串:打印字符串中重复的字符