14.字符串hash寻找第一个只出现一次的字符

 1 //char 0-255一共256个
 2 char getonebyhash(char *str)
 3 {
 4     if (str == NULL)
 5     {
 6         return '\0';
 7     }
 8     char ch = '\0';
 9     //哈希表设置为0
10     int hashtable[256] = { 0 };
11     //依次获取
12     char *phash = str;
13 
14     //遍历循环字符串数据存放在hash表
15     while (*phash != '\0')
16     {
17         hashtable[*phash]++;
18         phash++;
19     }
20 
21     //备份首地址,寻找到第一个值为1的字符
22     phash = str;
23     while (*phash != '\0')
24     {
25         if (hashtable[*phash] == 1)
26         {
27             ch = *phash;
28             break;
29         }
30         phash++;
31     }
32     return ch;
33 
34     
35 }

 

转载于:https://www.cnblogs.com/xiaochi/p/8366143.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值