【面试经典题之字符串】实现一个算法,确定一个字符串的所有字符是否全都不同。假设不允许使用额外的数据结构
2016-03-08 18:05
751 查看
实现一个算法,确定一个字符串的所有字符是否全都不同。假设不允许使用额外的数据结构。
解题:
首先我们假设这个字符串中全都是ASCII字符(如果不是需要另外讨论了)。因为ASCII字符集中总共有256个字符,所以我们可以知道如果字符串的长度超过了那么字符串中肯定有相同的字符。
定义一个bool型大小为256的数组array,然后遍历输入的字符串,每遍历一个字符,令int型变量val等于该字符的的ASCII码,如果这个字符之前都没有出现过,那么令array[val]等于true,如果这个字符之前出现过了,也就是array[val]已经等于true了,就返回false。当字符串中所有字符都遍历结束后,如果没有返回false,那么说明字符串中没有重复的字符,返回true。
源代码:
#include<iostream>
#include<string>
using namespace std;
bool ifnosame(string str)//定义一个bool型函数实现算法
{
if (str.length() > 256)
{
return false;
}
bool array[256];
int val;
for (int i = 0; i < str.length(); i++)
{
val = str[i];
if (array[val] == true)
{
return false;
}
array[val] = true;
}
return true;
}
int main()
{
string s;
cout << "输入一个字符串,判断其中所有字符是否全都不同:";
cin >> s;
if (ifnosame(s))
{
cout << "字符串中所有字符全都不同" << endl;
}
else
{
cout << "字符串中所有字符并不是全都不同的" << endl;
}
system("pause");
return true;
}
解题:
首先我们假设这个字符串中全都是ASCII字符(如果不是需要另外讨论了)。因为ASCII字符集中总共有256个字符,所以我们可以知道如果字符串的长度超过了那么字符串中肯定有相同的字符。
定义一个bool型大小为256的数组array,然后遍历输入的字符串,每遍历一个字符,令int型变量val等于该字符的的ASCII码,如果这个字符之前都没有出现过,那么令array[val]等于true,如果这个字符之前出现过了,也就是array[val]已经等于true了,就返回false。当字符串中所有字符都遍历结束后,如果没有返回false,那么说明字符串中没有重复的字符,返回true。
源代码:
#include<iostream>
#include<string>
using namespace std;
bool ifnosame(string str)//定义一个bool型函数实现算法
{
if (str.length() > 256)
{
return false;
}
bool array[256];
int val;
for (int i = 0; i < str.length(); i++)
{
val = str[i];
if (array[val] == true)
{
return false;
}
array[val] = true;
}
return true;
}
int main()
{
string s;
cout << "输入一个字符串,判断其中所有字符是否全都不同:";
cin >> s;
if (ifnosame(s))
{
cout << "字符串中所有字符全都不同" << endl;
}
else
{
cout << "字符串中所有字符并不是全都不同的" << endl;
}
system("pause");
return true;
}
相关文章推荐
- 数据结构(23)--排序篇之插入排序
- Android Binder机制(二) Binder中的数据结构
- R语言中的数据结构
- 阿里巴巴实习内推二面经验总结(客户端开发岗)
- 2015年大二上-数据结构-查找-2-(1)-HashTable
- 数据结构笔记——
- 【数据结构】线性表(数组实现)
- 小蚂蚁学习数据结构(35)——直接插入排序
- 简单数据结构(三)栈
- 数据结构与算法学习笔记(四)
- 数据结构之“Ordered List and Sorted List”(六)
- 数据结构与算法笔记 —— 向量
- 数据结构与算法笔记 —— 排序算法及代码实现
- bzoj1012[最大数]
- 《数据结构》链栈
- 《数据结构》顺序栈
- 最小堆建立
- 数据结构复习提纲
- PHP实现栈数据结构
- 数据结构-----线性表学习笔记