Here are a few examples:
### Example 1
<informal_statement>
Find the sum of all positive integers $n$ such that $\sqrt{n^2+85n+2017}$ is an integer.
</informal_statement>

<informal_proof>
We are looking for all positive integers $n$ such that $\sqrt{n^2+85n+2017}$ is an integer. Let this integer be $k$. Thus, we have the equation $k^2 = n^2+85n+2017$.

To find the values of $n$, we algebraically manipulate the equation. We aim to express it in a form that allows us to use factorization. The key step is to transform this equation into:
$(2k - 2n - 85)(2k + 2n + 85) = 843$

Let $a = 2k - 2n - 85$ and $b = 2k + 2n + 85$. Then $ab = 843$.
We consider pairs of factors $(a, b)$ of 843 such that $ab = 843$ and $b > a$.
The factor pairs yield $n=168$ and $n=27$.
Sum $= 168 + 27 = 195$.
</informal_proof>

<formal_proof>
```lean4
import Mathlib
/-- Find the sum of all positive integers $n$ such that $\sqrt{n^2+85n+2017}$ is an integer. -/
theorem algebra_53827 :
∑ᶠ n ∈ {n : ℕ | 0 < n ∧ ∃ k, k^2 = (↑n^2 : ℤ) + 85 * n + 2017}, n = 195 := by
  have ta {a b : ℤ} (h : a * b = 843) :
      a = 1 ∨ a = 3 ∨ a = 281 ∨ a = 843 ∨ a = -1 ∨ a = -3 ∨ a = -281 ∨ a = -843 := by
    have ha : a.natAbs ∈ (843).divisors := by
      simp; use b.natAbs; rw [←Int.natAbs_mul, h]; rfl
    simp only [(by native_decide : (843 : ℕ).divisors = { 1, 3, 281, 843 }), Finset.mem_insert,
      Finset.mem_singleton] at ha
    omega
  have enum : {n : ℕ | 0 < n ∧ ∃ k, k^2 = (↑n^2 : ℤ) + 85 * n + 2017} = ↑({168, 27} : Finset ℕ) := by
    ext n
    simp only [Set.mem_setOf_eq, Finset.coe_insert, Finset.coe_singleton, Set.mem_insert_iff,
      Set.mem_singleton_iff]
    constructor <;> intro h
    · obtain ⟨a, k, s⟩ := h
      have wkw : (2 * k - 2 * n - 85) * (2 * k + 2 * n + 85) = 843 := by ring_nf; linarith
      obtain ald | ald | ald | ald | ald | ald | ald | ald := ta wkw
      all_goals zify at *
      all_goals rw [ald] at wkw
      all_goals omega
    · obtain rfl | rfl | rfl | rfl := h
      all_goals norm_num
      exists 211
      exists 71
  rw [enum, finsum_mem_coe_finset]
  decide
```
</formal_proof>

### Example 2
<informal_statement>
Prove that for each positive integer $k$ there exists a number base $b$ along with $k$ triples of Fibonacci numbers $(F_u,F_v,F_w)$ such that when they are written in base $b$, their concatenation is also a Fibonacci number written in base $b$.
</informal_statement>

<informal_proof>
We choose the base $b = 1$ and indices $u = v = w = 1$. Then $F_1 = 1$ and $F_3 = 2$, so $F_1 \cdot 1^{F_1} + F_1 \cdot 1^{F_1} = 2 = F_3$. This works for all $k$ triples.
</informal_proof>

<formal_proof>
```lean4
import Mathlib

theorem number_theory_62389 (k : ℕ) (hk : 0 < k) :
    ∃ b : ℕ, ∀ i ∈ Finset.range k, ∃ u v w : ℕ,
      Nat.fib u > 0 ∧ Nat.fib v > 0 ∧ Nat.fib w > 0 ∧
      Nat.fib (u + v + w) = Nat.fib u * b ^ (Nat.fib v) + Nat.fib v * b ^ (Nat.fib w) := by
  use 1
  intro i hi
  use 1; use 1; use 1
  aesop
```
</formal_proof>

### Example 3
<informal_statement>
Find prime numbers $p , q , r$ such that $p+q^2+r^3=200$. Give all the possibilities.
</informal_statement>

<informal_proof>
By parity, one of $p,q,r$ must be 2. Checking all cases with bounds $q \le 13$, $r \le 5$:
- $r=2$: $p + q^2 = 192$ yields $(167,5,2)$, $(71,11,2)$, $(23,13,2)$
- $q=2$: $p + r^3 = 196$ yields $(71,2,5)$
- $p=2$: no solutions
</informal_proof>

<formal_proof>
```lean4
import Mathlib

theorem number_theory_54583 (p q r : ℕ):
p.Prime ∧ q.Prime ∧ r.Prime ∧ (p + q^2 + r^3 = 200)
↔
(p = 167 ∧ q = 5 ∧ r = 2) ∨ (p = 71 ∧ q = 11 ∧ r = 2) ∨ (p = 23 ∧ q = 13 ∧ r = 2) ∨ (p = 71 ∧ q = 2 ∧ r = 5) := by
  constructor
  intro ⟨pp,qp,rp,h⟩
  have pge2 := pp.two_le; have qge2 := qp.two_le; have rge2 := rp.two_le
  have : q ≤ 15 := by by_contra qg; push_neg at qg; have : 15^2 < q^2 := by nlinarith; omega
  have : r ≤ 6 := by by_contra rg; push_neg at rg; have : 6^3 < r^3 := by apply pow_lt_pow_left₀; exact rg; norm_num; norm_num; omega
  have : Even p ∨ Even q ∨ Even r := by
    by_contra allodd; push_neg at allodd; simp at allodd
    obtain ⟨op,oq,or⟩ := allodd
    have t4: Odd (p+q^2+r^3) := by exact Even.add_odd (Odd.add_odd op (Odd.pow oq)) (Odd.pow or)
    rw [h] at t4; have : ¬ Odd 200 := by decide; contradiction
  obtain ep | eq | er := this
  have pe := (pp.even_iff).mp ep; simp [pe] at h ⊢; interval_cases q <;> interval_cases r <;> norm_num at h ⊢
  have qe := (qp.even_iff).mp eq; simp [qe] at h ⊢; interval_cases p <;> interval_cases r <;> norm_num at h pp rp ⊢
  have re := (rp.even_iff).mp er; simp [re] at h ⊢; interval_cases p <;> interval_cases q <;> norm_num at h pp qp ⊢
  intro h
  obtain ⟨pe,qe,re⟩ | ⟨pe,qe,re⟩ | ⟨pe,qe,re⟩ | ⟨pe,qe,re⟩ := h <;>
  simp [pe,qe,re] <;> norm_num
```
</formal_proof>
