package main

import (
	"bufio"
	"fmt"
	"math"
	"os"
	"strconv"
	"strings"
)

// エントリポイント
func main() {
	in := bufio.NewScanner(os.Stdin)
	// 記録の個数
	in.Scan()
	input1 := in.Text()
	// 1 回の睡眠あたりの寝た時刻と起きた時刻の記録
	input2 := make([]string, 0)
	for in.Scan() {
		input2 = append(input2, in.Text())
	}

	fmt.Println(timeOfSleeping(input1, input2))
}

// 睡眠時間の合計を分にして返す。
func timeOfSleeping(lineNum string, sleep []string) string {
	// 定数 1日の分
	const dayMinute = 24 * 60
	_ = lineNum
	minute := 0
	for _, v := range sleep {
		// 寝た時間と起きた時間
		sp := strings.Split(v, " ")

		// 寝た時間(分)
		sleepSp := strings.Split(sp[0], ":")
		sleepH, _ := strconv.Atoi(sleepSp[0])
		sleepM, _ := strconv.Atoi(sleepSp[1])
		sleepMinute := sleepH*60 + sleepM

		// 起きた時間(分)
		getupSp := strings.Split(sp[1], ":")
		getupH, _ := strconv.Atoi(getupSp[0])
		getupM, _ := strconv.Atoi(getupSp[1])
		getupMinute := getupH*60 + getupM

		// 睡眠時間(分)
		if sleepMinute < getupMinute {
			// マイナス値になるので絶対値に変換
			minute += int(math.Abs(float64(sleepMinute - getupMinute)))
		} else {
			minute += getupMinute + dayMinute - sleepMinute
		}
	}
	return strconv.Itoa(minute)
}