查找不在数组里的字母

题目:有一个数组包含 很多字母,如何查找 26 个字母 不在 里面的字母

            eg: {a,b,c,c,c,c} 那么就是 d - z

算法思路:维护一个 整形数组 对应 字母数组的 asci 码, 查找 字母数组,如果某字母出现一次,对应的 整形数组 就 + 1。最后,整形 数组为 0 的,就是没出现的。

C#代码实现如下:

            //1. 1+'a' 会得到一个数字
            //2. 为了使 算法更完善,加入一个 计数,如果 26 个字母都找到了,就不需要在找了

            char[] chArr = new char[] { 'a', 'b', 'c', 'd', 'e', 'g', 'k', 'k', 'l', 'l', 'z' };
            int[] intArr = new int[26];
            int num = 26;

            for(int i = 0;i < chArr.Length;i++)
            {
                if (intArr[chArr[i] - 'a'] == 0 && num > 0)
                {
                    intArr[chArr[i] - 'a']++;
                    num--;
                }
            }

            for (int i = 0; i < intArr.Length;i++ )
            {
                if (intArr[i] == 0)
                    Console.WriteLine(Convert.ToChar(i + 'a'));
            }

这只是本人的想法和实现,如果有其它意见的,欢迎提出讨论。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值