algorithm - 需要有关二进制搜索算法错误的帮助

标签 algorithm fortran binary-search fortran95

使用 g95编译器,我有一个错误:

Error: Operands of comparison operator '.EQ.' at (1) are LOGICAL(4)/LOGICAL(4)

我不知道这是什么意思。我包括子程序。您有解决此问题的想法吗?

非常感谢您的宝贵时间。

  SUBROUTINE search(iarray, ItemSought, Found, Location)
CHARACTER(20), DIMENSION(50),INTENT(IN)::itemarray
CHARACTER(20)::ItemSought
LOGICAL, INTENT(OUT)::Found
INTEGER, INTENT(OUT)::Location
INTEGER:: First, Last, Middle

WRITE(*,'(1x,A)',ADVANCE="NO"),"What are you searching for? "
READ*, ItemSought

First=1
Last=SIZE(Iarray)
FOUND = .FALSE.

DO
    IF ((First > Last) .OR. Found) RETURN
        Middle = (First+Last)/2
    IF (ItemSought < Iarray(Middle)) THEN
        Last=Middle-1
    ELSE IF (ItemSought > Iarray(Middle)) THEN
        First=Middle+1
    ELSE
        Found = .TRUE.
        Location = Middle
    END IF
END DO


IF (Found == .TRUE.) THEN
PRINT*, Itemsought

END SUBROUTINE

最佳答案

我不想承认我上次使用 FORTRAN 是什么时候,但它看起来确实与我内存中的大不相同。所以这只是一个猜测。

根据错误消息我会说它在这一行(你没有说是哪一行):

IF (Found == .TRUE.) THEN

同样只是猜测,您通常不会通过与 true/false 比较来测试逻辑值,而是直接使用它:

IF (Found) THEN

关于algorithm - 需要有关二进制搜索算法错误的帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5705510/

相关文章:

c++ - C++ STL中的二叉搜索树实现?

java - 滞后套接字java

带粗细绘制算法的圆

algorithm - 梯度下降算法在 Haskell 中不收敛

python - 如何将参数传递给 ABAQUS python 代码?

arrays - 二进制搜索算法实现

algorithm - 可以由字符串列表组成的最长字符串

fortran - Fortran 类型绑定(bind)过程的 doxygen 处理

arrays - 如何知道 Fortran 数组中非零元素的个数?

c++ - 在 C/C++ 中使用二进制搜索在日志文件中搜索日期时间