I will provide you with a programming problem description, and your task is to generate adversarial test input samples using the CYaRon library.

You need to complete the following steps:
1. Parse the constraints on the input from the problem description, such as the range of input data, specific input constraints, etc.
2. Write a function generate_test_input using the CYaRon library to generate a single adversarial test input designed to challenge boundary conditions or worst-case complexity. The function should **internally randomize which adversarial strategy to use**, without accepting any parameters. The generated input should still conform to the problem constraints.
3. Write a function validate_test_input to verify whether the generated test input satisfies the requirements specified in the problem description. This includes checking the input data type and constraints parsed in step 1. The function should take input_string as input and return a boolean (True/False).

Output format (strictly follow):
Part 1: Parse Input Constraints
Specify the input constraints as described in the problem.

Part 2: Code for Test Input Generation
import cyaron as cy # cyaron version: 0.7.0
import random

def generate_test_input():
    # set parameters constraints that meet requirements (e.g. 1 <= N <= 300)
    ...
    # Randomly choose one adversarial strategy
    strategy = random.choice(["equal_weights", "alternating_large_small", "large_ends"])
    
    if strategy == "equal_weights":
        # example: all weights are maximal
        N = cy.randint(100000, 100000) # fix to worst-case size
        max_weight = cy.randint(10**9, 10**9)
        k = random.choice([1, N//2, N-1, N])
        weights = [max_weight] * N
    elif strategy == "alternating_large_small":
        N = cy.randint(100000, 100000)
        max_weight = cy.randint(10**9, 10**9)
        k = random.choice([1, N//2, N-1, N])
        weights = [max_weight if i%2 else 1 for i in range(N)]
    else: # large_ends
        N = cy.randint(100000, 100000)
        max_weight = cy.randint(10**9, 10**9)
        k = random.choice([1, N//2, N-1, N])
        weights = [max_weight] + [1]*(N-2) + [max_weight]
    
    # Build input string
    input_lines = [f"{N} {k}"] + [str(w) for w in weights]
    return "\n".join(input_lines)

Part 3: Code to Validate Test Input
def validate_test_input(input_string):
    try:
        lines = input_string.strip().split('\n')
        N_k = lines[0].split()
        if len(N_k) != 2:
            return False
        N, k = map(int, N_k)
        if not (1 <= N <= 100000):
            return False
        if not (1 <= k <= N):
            return False
        weights = list(map(int, lines[1:]))
        if len(weights) != N:
            return False
        for w in weights:
            if not (1 <= w <= 10**9):
                return False
        return True
    except:
        return False

Note:
- generate_test_input() must return a single adversarial input string, not a list.
- Use cy.randint instead of cy.Integer().
- The function should generate adversarial yet valid data fully inside, without parameters.
