Fortran Coder

查看: 6513|回复: 4
打印 上一主题 下一主题

[数值问题] 找数组中最多的元素以及其个数,为什么没有计算0的值

[复制链接]

7

帖子

2

主题

0

精华

入门

F 币
28 元
贡献
17 点
跳转到指定楼层
楼主
发表于 2020-3-3 16:48:56 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
想了一个方法但是只找到了非0元素中最多的元素以及其个数,不太理解为什么
[Fortran] 纯文本查看 复制代码
!par20_ex7_t32
PROGRAM Vote32

! input constants
! N is the number votes
! M is maximum allowed number
INTEGER, PARAMETER :: N = 20, M = 4
INTEGER, PARAMETER :: seed = 42

! normal variables
INTEGER :: winner = 0, wincount = 0
INTEGER :: countnum_p = 0, countnum_n = 0

! votes is the input array
INTEGER, DIMENSION(N) :: votes
INTEGER, DIMENSION(-1:M) :: counts;

! init random number generator
i = RAND(seed)

! init votes
DO  i=1,N
    votes(i) = RAND() * (M+3) - 2;
END DO

WRITE(*,"(A,100I3)") 'Input is: ', votes

! TODO
! find which was most voted number

DO j=1,N-1
    countnum_p = count(votes == votes(j))
    countnum_n = count(votes == votes(j+1)) 
    if (countnum_n > countnum_p) then
        winner = countnum_n
        wincount = votes(j+1)
    else
        winner = countnum_p
        wincount = votes(j)
    END if
END DO


WRITE(*,*) 'Most votes was: ', wincount
WRITE(*,*) 'Winners were:   ', winner


END PROGRAM Vote32




分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

7

帖子

2

主题

0

精华

入门

F 币
28 元
贡献
17 点
沙发
 楼主| 发表于 2020-3-3 16:49:58 | 只看该作者
仍然是在第31行开始,为什么没有统计到0的个数呢

7

帖子

2

主题

0

精华

入门

F 币
28 元
贡献
17 点
板凳
 楼主| 发表于 2020-3-3 17:00:09 | 只看该作者
我用了一种比较偷懒的方式,直接先计算0的个数然后最后再和这个比较,但还是不太明白这个count计数为什么没有把0算进去,求大佬解答一下
[Fortran] 纯文本查看 复制代码
INTEGER :: countnum_p = 0, countnum_n = 0, countnum_z = 0
if (countnum_z >winner) then
    winner = countnum_z
        wincount = 0
END if

250

帖子

2

主题

0

精华

宗师

F 币
1730 元
贡献
872 点

规矩勋章

地板
发表于 2020-3-3 23:07:54 | 只看该作者
if (countnum_n > countnum_p) then
这句的意思是一个数的出现次数大于后一个数的次数则保存前一个数的出现次数和数值,不是保存最多的元素以及其个数。
如果有2个数出现的次数并列第一,楼主也没有考虑

798

帖子

2

主题

0

精华

大宗师

F 币
3793 元
贡献
2268 点
5#
发表于 2020-3-4 13:51:14 | 只看该作者
本帖最后由 li913 于 2020-3-4 14:03 编辑

如果数组较大,建议直接用排序,然后统计。如果数组的取值范围较窄,可以直接开数组,用直接统计法。
[Fortran] 纯文本查看 复制代码
!par20_ex7_t32
PROGRAM Vote32
! input constants
! N is the number votes
! M is maximum allowed number
INTEGER, PARAMETER :: N = 20, M = 4
INTEGER, PARAMETER :: sed = 42

! normal variables
INTEGER :: winner = 0, wincount = 0
INTEGER :: countnum_p = 0, countnum_n = 0

! votes is the input array
INTEGER, DIMENSION(N) :: votes
INTEGER, DIMENSION(-1:M) :: counts;
real ran
integer num(-2:5)
! init random number generator
call random_seed()

! init votes
DO  i=1,N
    call random_number(ran)
    votes(i) = RAN * (M+3) - 2;
END DO

WRITE(*,"(A,100I3)") 'Input is: ', votes

! TODO
! find which was most voted number
wincount = 0
DO j=1,N
    countnum_p = count(votes == votes(j))
    if(wincount<countnum_p) then
      wincount = countnum_p
      winner = votes(j)
    end if
END DO
WRITE(*,*) '个数: ', wincount
WRITE(*,*) 'Winner:   ', winner

!直接统计法
num=0
do j=1,n
num(votes(j)) = num(votes(j)) + 1
end do
WRITE(*,*) '个数: ', maxval(num)
WRITE(*,*) 'Winner:   ', maxloc(num)-1+lbound(num)

pause



END PROGRAM Vote32
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-4-29 02:39

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表