名企笔试:2016奇虎360研发工程师内推笔试编程题(出现一次的字符)

32 篇文章 0 订阅

正在挑战一个CrackMe的你,把需要填写的前面几位密码都正确猜出了,可是这最后一位密码,好像藏得有点深。CrackMe的作者还挑衅般的在里面藏了个.tar.gz文件,解压缩出来,里面写道


你要的最后一个字符就在下面这个字符串里,这个字符是下面整个字符串中第一个只出现一次的字符”。(比如,串是abaccdeff,那么正确字符就是b了) 


然而下面给出来的字符串好像太长太长了,单靠人力完全无法找出来。


于是,你需要写一个程序代劳了。输入文件体积较大,请使用一些快速的输入输出手段,不推荐使用cin/cout,对Java并不推荐使用Scanner直接读写。

输入描述:


第一行,一个正整数T(T≤20) ,表示输入数据组数。


之后T行,每行一个字符串S。( 1≤S 的长度≤1000000 ,保证字符串中出现的字符的ASCII码在[0x21,0x7F)范围内,即均为可显示的非空白符,同时保证一定有解)


输出描述:


一共T 行,每行一个字符C ,表示所给的相应字符串中第一个只出现一次的字符。


输入例子:


2
abaccdeff
testonline


输出例子:


b
s


#include<iostream>
#include<string>
#include<algorithm>
#include<list>

using namespace std;
int main() {
	
	string h1;
	cin >> h1;//输入一个数组
	int length = h1.length();//记录数组的长度
	char *a=new char[length+1];//创建一个一维的char的数组  长度必须比lh1长,否则空间不够
	
	
	strcpy_s(a,length+1,h1.c_str());//将str类型的数组拷贝到char类型的

	sort(a, a + length);//对数组a进行排序按照ASCII码升序

	for (int i = 0; i < length; i++)//打印输出
	{
	cout << a[i];
	}
	cout << endl;

	//从第一个数组开始遍历
	for (int i = 0; i < length; i++)
	{
		if (a[i] != a[i + 1])//如果当前的和前一个不同
		{
			if (a[i] != a[i - 1])//然后检查是否和上一个也不同
			{
				cout << a[i] << endl; break;//输出  结束循环
			}
		}
	}
	//这个算法的唯一问题,他输出的不一定是第一个出现的字母而是在排序中首先出现的第一个字母
	
	
	
	//将所有的出现一次字母的字母统计     然后依次与之前的数组对比即可


	cout << endl;
	return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值