这个难吗???如何将一个字符串转化成一个唯一整数?

Godshow 2005-09-26 04:29:46
字符串长度在2到10位左右,包含小写字母与数字。
用hashCode()方法可能出现重复值。
有无其他方法?
...全文
1283 26 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
26 条回复
切换为时间正序
请发表友善的回复…
发表回复
shine333 2005-10-31
  • 打赏
  • 举报
回复
如果楼主的目的只是加密用户名密码,且没有什么找回遗失密码功能的情况,还是用MD5之类的信息摘要
,(当然如果字符串长度不定,摘要仍然可能重复,即使可能性非常小,可以忽略)

否则信息摘要(包括hashCode)是不可逆的,与类似压缩/解压缩的加密/解密不同
xhjf777 2005-10-31
  • 打赏
  • 举报
回复
当然是用MD5了
Godshow 2005-10-31
  • 打赏
  • 举报
回复
楼上,我要的就是算法啊.写不出来.
注意,是整型而不是长整型.
format_jade 2005-10-24
  • 打赏
  • 举报
回复
对呀,自己给hash表一个可以产生唯一数字的算法啊!
jordan1 2005-10-24
  • 打赏
  • 举报
回复
study
pauliuyou 2005-10-24
  • 打赏
  • 举报
回复
用md5还是不错的.
Godshow 2005-10-24
  • 打赏
  • 举报
回复
测试了一下,cu653的方法还是超长
arsaluo 2005-10-13
  • 打赏
  • 举报
回复
cu653的方法可以试试,我觉得这个可行。
Godshow 2005-10-13
  • 打赏
  • 举报
回复
每一位都按ascii转换,如果5位帐号不就3*15=15位了?况且我还有10位帐号的情况
如何保证是整型?
cu653的方法不知道可行否,试试
believefym 2005-10-04
  • 打赏
  • 举报
回复
楼上的方法不错,我也刚刚想到,
不过再对数字做加密算法不就又回不来了吗,
如果只需要按照楼主的需求的话,直接采用asicc就可以了
njwangchuan 2005-10-03
  • 打赏
  • 举报
回复
根据楼主的情况,我猜测是做帐号密码的存放这一类问题的算法.记住一个原则,加密算法的不可逆和加密后的可重复性!如果飞要唯一性,可将这个字符串的没一位按ASICC码转换(数字也看成字符),一位变三位不足前补零.再对数字串做加密算法
Linyco 2005-10-03
  • 打赏
  • 举报
回复
如果写hashCode()的话不大可能完全没有重复的。
只能减少重复,不能消灭重复。
Godshow 2005-09-27
  • 打赏
  • 举报
回复
victorppy(键盘上的鱼) ,必须保证每次转换都要得到同样的值.你的方法...
Godshow 2005-09-27
  • 打赏
  • 举报
回复
我还是倾向于使用算法解决.因为每周要同步这些帐号.
如果放到表里生成ID,下次增加或删除了一些帐号,需要对照该表才可以生成新ID.比较复杂.
另外,中文名是否可以转成整型?
3个字的名字加一位区分重名位,13位还是超出整型了.
victorppy 2005-09-27
  • 打赏
  • 举报
回复
可以用时间,年月日时分秒(毫秒)。重复的可能性很小。
比如现在是2005年9月27日8时34分20秒。则可以为: 20050927083420

cu653 2005-09-27
  • 打赏
  • 举报
回复
long m=0;
long step=1;
for(int i=0;i<s.length();i++)
{
char ch = s.charAt(i);
//把ch转为整数
int n = toInt(ch);
m+=step*n;
step *= 256; //要超过最大的n
}

cu653 2005-09-27
  • 打赏
  • 举报
回复
long m=0;
long step=1;
for(int i=0;i<s.length();i++)
{
char ch = s.charAt(i);
//把ch转为整数
int n = toInt(ch);
m+=step+n;
step *= 256; //要超过最大的n
}
leslir 2005-09-27
  • 打赏
  • 举报
回复
我也认为还是放到一个表中,用自动生成的ID很好了,不过比较麻烦了。但是也是不是办法的办法。
呵呵 关注!
sqlink 2005-09-26
  • 打赏
  • 举报
回复
用MD5
z_j 2005-09-26
  • 打赏
  • 举报
回复
在数据库中建一个表 create table t1( id int identity(1,1) not null, name varchar(100) null,primary key(id))
然后把你说的那些帐号插入到这个表中,这样,数据库就自动生成一个ID,且肯定是不重复的,你看是不是能满足你的要求
加载更多回复(5)

62,634

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧