| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1258 人关注过本帖
标题:[求助]四舍六入,奇进偶舍的函数,谁能给修改修改
只看楼主 加入收藏
hytf
Rank: 1
等 级:新手上路
帖 子:56
专家分:0
注 册:2007-5-11
收藏
 问题点数:0 回复次数:3 
[求助]四舍六入,奇进偶舍的函数,谁能给修改修改

Private Function GetNumber(f As Double, iPos As Integer) As String
Dim k As Integer
Dim s As String, s1 As String, s2 As String
Dim i As Double, k1 As Double, k2 As Double

s = CStr(f)
i = InStr(1, s, ".") '查找小数点的位置
'检查是否需要进行处理
s1 = Mid(s, i + iPos + 1, 1)
s2 = Mid(s, i + iPos, 1)
k = Val(s1)
k2 = Val(s2)
If Len(s) - i < iPos Then
MsgBox "小数位数不足,请人工检查"
End If
If Len(s) - i = iPos Then s1 = s
If Len(s) - i > iPos Then '最后一位<5:舍去,>5:进位,=5:奇进偶舍

If k < 5 Then '舍去
s1 = Left$(s, i + iPos)
ElseIf k > 5 Then '进位
s1 = Mid(s, i + iPos, 1)
k = Val(s1)
k = k + 1
s1 = Left$(s, i + iPos - 1) + Trim(Str(k))
ElseIf k = 5 Then '奇进偶舍
s1 = Mid(s, i + iPos, 1)
k = Val(s1)
k2 = Len(s) - i - iPos - 1
' Print Len(s); i; iPos
If k2 = 0 Then '偶舍
If k Mod 2 = 0 Then
s1 = Left$(s, i + iPos)
Else '奇进
k = k + 1
s1 = Left$(s, i + iPos - 1) + Trim$(Str(k))
End If
Else
k = k + 1
s1 = Left$(s, i + iPos - 1) + Trim$(Str(k))
End If
End If
End If

' s1 = Format(s1, "####0.000")
' Print s1
GetNumber = CStr(s1) '送回处理后的数据
End Function

搜索更多相关主题的帖子: 函数 Double String iPos Dim 
2007-08-15 16:33
zzxwill
Rank: 1
等 级:新手上路
帖 子:398
专家分:0
注 册:2007-8-15
收藏
得分:0 

#include <stdio.h>
void main()
{
float a;
int b;
scanf("%f",&a);
b=(int)(a+0.5);
printf("%d\n",b);
}
2.3
2
Press any key to continue

2.6
3
Press any key to continue


一分耕耘,一分收获。
2007-08-29 19:56
zzxwill
Rank: 1
等 级:新手上路
帖 子:398
专家分:0
注 册:2007-8-15
收藏
得分:0 
不好意思,还不人合乎    奇进偶舍  的要求~~

一分耕耘,一分收获。
2007-08-29 19:57
zzxwill
Rank: 1
等 级:新手上路
帖 子:398
专家分:0
注 册:2007-8-15
收藏
得分:0 
奇进偶舍 我不会,这是什么意思 ?谢谢~~

一分耕耘,一分收获。
2007-08-29 19:58
快速回复:[求助]四舍六入,奇进偶舍的函数,谁能给修改修改
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014624 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved