def river_crossing(sisters_left, brothers_left):
    sisters_right = 0
    brothers_right = 0
    trips = 0
    
    while sisters_left > 2:
        # Two sisters cross
        sisters_left -= 2
        sisters_right += 2
        trips += 1
        
        if sisters_left == 0:
            break
        
        # One sister returns
        sisters_left += 1
        sisters_right -= 1
        trips += 1
        
        if brothers_left >= 2:
            # Two brothers cross
            brothers_left -= 2
            brothers_right += 2
            trips += 1
        else:
            break
        
        # One brother returns with one sister
        brothers_left += 1
        brothers_right -= 1
        sisters_left += 1
        sisters_right -= 1
        trips += 1
    
    # The last two sisters cross together
    sisters_left -= 2
    sisters_right += 2
    trips += 1
    
    print(f"All sisters and brothers have crossed the river in {trips} trips.")
    print(f"Left Bank: {sisters_left}S, {brothers_left}B")
    print(f"Right Bank: {sisters_right}S, {brothers_right}B")

# Initial state: 30 sisters and 30 brothers on the left bank
river_crossing(30, 30)






