Logo
Книга для начинающих
ВходРегистрация
/
Программирование
/
Курс Golang
/

Сравнение срезов

Golang: Сравнение срезов

Срезы (slices) в Go нельзя сравнивать напрямую с помощью операторов == или !=. Компилятор не позволит выполнить сравнение двух срезов, даже если они имеют одинаковую длину и значения.

a := []int{1, 2, 3}
b := []int{1, 2, 3}

fmt.Println(a == b) // ошибка компиляции

Как сравнивать срезы

Для сравнения содержимого срезов используется пакет slices из стандартной библиотеки, который содержит функцию slices.Equal().

import "slices"

a := []int{1, 2, 3}
b := []int{1, 2, 3}
fmt.Println(slices.Equal(a, b)) // => true

Сравнение на равенство ссылок

Если необходимо проверить, ссылаются ли два среза на один и тот же массив в памяти, можно сравнить &a[0] и &b[0] при условии, что оба среза непустые. Это используется редко.

a := []int{1, 2, 3}
b := a
fmt.Println(&a[0] == &b[0]) // => true

Проверка на nil

Срезы можно сравнивать с nil. Срез, объявленный без инициализации, равен nil.

var s []int
fmt.Println(s == nil) // => true

empty := []int{}
// пустой, но не nil
fmt.Println(empty == nil) // => false

Задание

Реализуйте функцию AreOrderHistoriesEqual(history1, history2 [][]string) bool, которая проверяет, совпадают ли два списка историй заказов.

Каждая история — это список товаров (срез строк). Истории считаются равными, если количество заказов одинаково и каждый заказ (список товаров) содержит те же товары в том же порядке.

Примеры

history1 := [][]string{
	{"milk", "bread"},
	{"apple", "banana"},
}
history2 := [][]string{
	{"milk", "bread"},
	{"apple", "banana"},
}
AreOrderHistoriesEqual(history1, history2) // true

AreOrderHistoriesEqual(history1, [][]string{
	{"milk", "bread", "butter"},
	{"apple", "banana"},
}) // false
AreOrderHistoriesEqual(nil, [][]string{})  // false
Коммерческий опыт и Трудоустройство

Полезное

  • Пакет slices содержит полезные функции для работы со слайсами

Команда проекта находится в телеграм-сообществе. Там можно задать любой вопрос и повлиять на проект

Если вы зашли в тупик, то самое время поговорить с нашим асситентом Тота во вкладке "ИИ-помощник":

Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи. В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в обратной связи нашего сообщества

Нашли ошибку? Есть что добавить? Пулреквесты приветствуются
/
Программирование
/
Курс Golang
/

Сравнение срезов

Golang: Сравнение срезов

Срезы (slices) в Go нельзя сравнивать напрямую с помощью операторов == или !=. Компилятор не позволит выполнить сравнение двух срезов, даже если они имеют одинаковую длину и значения.

a := []int{1, 2, 3}
b := []int{1, 2, 3}

fmt.Println(a == b) // ошибка компиляции

Как сравнивать срезы

Для сравнения содержимого срезов используется пакет slices из стандартной библиотеки, который содержит функцию slices.Equal().

import "slices"

a := []int{1, 2, 3}
b := []int{1, 2, 3}
fmt.Println(slices.Equal(a, b)) // => true

Сравнение на равенство ссылок

Если необходимо проверить, ссылаются ли два среза на один и тот же массив в памяти, можно сравнить &a[0] и &b[0] при условии, что оба среза непустые. Это используется редко.

a := []int{1, 2, 3}
b := a
fmt.Println(&a[0] == &b[0]) // => true

Проверка на nil

Срезы можно сравнивать с nil. Срез, объявленный без инициализации, равен nil.

var s []int
fmt.Println(s == nil) // => true

empty := []int{}
// пустой, но не nil
fmt.Println(empty == nil) // => false

Задание

Реализуйте функцию AreOrderHistoriesEqual(history1, history2 [][]string) bool, которая проверяет, совпадают ли два списка историй заказов.

Каждая история — это список товаров (срез строк). Истории считаются равными, если количество заказов одинаково и каждый заказ (список товаров) содержит те же товары в том же порядке.

Примеры

history1 := [][]string{
	{"milk", "bread"},
	{"apple", "banana"},
}
history2 := [][]string{
	{"milk", "bread"},
	{"apple", "banana"},
}
AreOrderHistoriesEqual(history1, history2) // true

AreOrderHistoriesEqual(history1, [][]string{
	{"milk", "bread", "butter"},
	{"apple", "banana"},
}) // false
AreOrderHistoriesEqual(nil, [][]string{})  // false
Коммерческий опыт и Трудоустройство

Полезное

  • Пакет slices содержит полезные функции для работы со слайсами

Команда проекта находится в телеграм-сообществе. Там можно задать любой вопрос и повлиять на проект

Если вы зашли в тупик, то самое время поговорить с нашим асситентом Тота во вкладке "ИИ-помощник":

Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи. В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в обратной связи нашего сообщества

Нашли ошибку? Есть что добавить? Пулреквесты приветствуются
← ПредыдущийСледующий →
← ПредыдущийСледующий →
← ПредыдущийСледующий →

Ваше упражнение проверяется по этим тестам

// Тесты
package solution

import (
	"testing"

	"github.com/stretchr/testify/assert"
)

func TestAreOrderHistoriesEqual(t *testing.T) {
	tests := []struct {
		name     string
		h1       [][]string
		h2       [][]string
		expected bool
	}{
		{
			name: "Equal histories",
			h1: [][]string{
				{"milk", "bread"},
				{"apple", "banana"},
			},
			h2: [][]string{
				{"milk", "bread"},
				{"apple", "banana"},
			},
			expected: true,
		},
		{
			name: "Different orders",
			h1: [][]string{
				{"milk", "bread"},
				{"apple", "banana"},
			},
			h2: [][]string{
				{"milk", "bread", "butter"},
				{"apple", "banana"},
			},
			expected: false,
		},
		{
			name: "Different sequence",
			h1: [][]string{
				{"milk", "bread"},
				{"apple", "banana"},
			},
			h2: [][]string{
				{"apple", "banana"},
				{"milk", "bread"},
			},
			expected: false,
		},
		{
			name:     "Nil vs empty",
			h1:       nil,
			h2:       [][]string{},
			expected: false,
		},
		{
			name:     "Both empty",
			h1:       [][]string{},
			h2:       [][]string{},
			expected: true,
		},
	}

	for _, tt := range tests {
		t.Run(tt.name, func(t *testing.T) {
			result := AreOrderHistoriesEqual(tt.h1, tt.h2)
			assert.Equal(t, tt.expected, result)
		})
	}
}
← ПредыдущийСледующий →

Решение учителя откроется через:

20:00

waiting_clock
← ПредыдущийСледующий →