社区
Java SE
帖子详情
这个难吗???如何将一个字符串转化成一个唯一整数?
Godshow
2005-09-26 04:29:46
字符串长度在2到10位左右,包含小写字母与数字。
用hashCode()方法可能出现重复值。
有无其他方法?
...全文
1283
26
打赏
收藏
这个难吗???如何将一个字符串转化成一个唯一整数?
字符串长度在2到10位左右,包含小写字母与数字。 用hashCode()方法可能出现重复值。 有无其他方法?
复制链接
扫一扫
分享
转发到动态
举报
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)
不使用
字符串
转换
整数
的库函数将
一个
字符串
转换成
一个
整数
牛客剑指Offer一道题,链接如下:https://www.nowcoder.com/practice/1277c681251b4372bdef344468e4f26e 题目描述: 将
一个
字符串
转换成
一个
整数
,要求不能使用
字符串
转换
整数
的库函数。数值为0或者
字符串
不是
一个
合法的数值则返回0 输入描述: 输入
一个
字符串
,包括数字字母符号,可以为空 返回值描述: 如果是合法的数值表达则返回该数字,否则返回0 示例1: 输入: “+2147483647” 返回.
剑指Offer Java 把
字符串
转换成
整数
将
一个
字符串
转换成
一个
整数
,要求不能使用
字符串
转换
整数
的库函数。 数值为0或者
字符串
不是
一个
合法的数值则返回0
题目描述 将
一个
字符串
转换成
一个
整数
,要求不能使用
字符串
转换
整数
的库函数。 数值为0或者
字符串
不是
一个
合法的数值则返回0 输入描述: 输入
一个
字符串
,包括数字字母符号,可以为空 输出描述: 如果是合法的数值表达则返回该数字,否则返回0 输入 +2147483647 1a33 输出 2147483647 0 第一次发现剑指offer果然厉害啊,这道题是我在58同城的面试题! (但是面试的时候还没刷到这..) public class Solution { public int
剑指offer:将
一个
字符串
转换成
一个
整数
,要求不能使用
字符串
转换
整数
的库函数。 数值为0或者
字符串
不是
一个
合法的数值则返回0。
剑指offer算法题
字符串
数学 题目描述 将
一个
字符串
转换成
一个
整数
,要求不能使用
字符串
转换
整数
的库函数。 数值为0或者
字符串
不是
一个
合法的数值则返回0 输入描述: 输入
一个
字符串
,包括数字字母符号,可以为空 返回值描述: 如果是合法的数值表达则返回该数字,否则返回0 题目分析 本题主要考察边界判断。 如,数字上下限,空
字符串
,只有正负号,有无正负号,以及是否是正确数字这几项。 数字结果的上下限判断可以先利用long型来存储计算的结果,之后跟Int型的Integer.MAX_VALUE和Integer.
将
一个
字符串
转换成
一个
整数
题目:将
一个
字符串
转换成
一个
整数
,要求不能使用
字符串
转换
整数
的库函数。 数值为0或者
字符串
不是
一个
合法的数值则返回0输入描述:输入
一个
字符串
,包括数字字母符号,可以为空输出描述:如果是合法的数值表达则返回该数字,否则返回0思路:将
字符串
转化为字符数组,然后将通过num = num*10 + 字符数组[i] 转化为数字。 注意的要点:判断非法输入输出0和正常输入0的区别。判断正负号。public c
将
一个
字符串
转换成
一个
整数
,要求不能使用
字符串
转换
整数
的库函数
(1)
整数
不仅仅含有数字,还可能以 + 或者 - 开头,表示
整数
的正负。因此需要对
字符串
的第
一个
字符做特殊处理。 (2)输入的
字符串
中可能含有不是数字的字符。 (3)输入的可能是空
字符串
。 (4)溢出问题,超过
整数
的最大范围。 public class String2Int { public static int StringtoInt(String str) { ...
Java SE
62,634
社区成员
307,269
社区内容
发帖
与我相关
我的任务
Java SE
Java 2 Standard Edition
复制链接
扫一扫
分享
社区描述
Java 2 Standard Edition
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章