Предмет: Информатика,
автор: monetkayahoo
Помогите с массивом c#
В одномерном массиве нужно удалить элементы, стоящие между максимальным отрицательным и минимальным положительным.
Aillianna:
в массиве элементы не удаляются
массивы под это не заточены
проще всего создать новый массив в котором нет ненужных элементов
или работать со списком List<>
так что именно надо?
я не знаю, на ваше усмотрение
Ответы
Автор ответа:
1
private static int[] DeleteSomethingInArray(int[] a)
{
Debug.Assert(a.Length > 1 && a.Any(x => x > 0) && a.Any(x => x < 0)); // это просто проверка, можно удалить или закоментировать
if (a.Length == 2)
return a;
var max_i = -1;
var min_i = -1;
for (var i = 0; i < a.Length; i++)
{
if (a[i] < 0 && (max_i < 0 || a[max_i] < a[i]))
max_i = i;
if (a[i] > 0 && (min_i < 0 || a[min_i] > a[i]))
min_i = i;
}
var result = new int[a.Length - Math.Abs(max_i - min_i) + 1];
var j = 0;
for (var i = 0; i < a.Length; i++)
{
if (i <= Math.Min(max_i, min_i) || i >= Math.Max(max_i, min_i))
result[j++] = a[i];
}
return result;
}
На всякий случай в заголовках
using System;
using System.Diagnostics;
using System.Linq;
{
Debug.Assert(a.Length > 1 && a.Any(x => x > 0) && a.Any(x => x < 0)); // это просто проверка, можно удалить или закоментировать
if (a.Length == 2)
return a;
var max_i = -1;
var min_i = -1;
for (var i = 0; i < a.Length; i++)
{
if (a[i] < 0 && (max_i < 0 || a[max_i] < a[i]))
max_i = i;
if (a[i] > 0 && (min_i < 0 || a[min_i] > a[i]))
min_i = i;
}
var result = new int[a.Length - Math.Abs(max_i - min_i) + 1];
var j = 0;
for (var i = 0; i < a.Length; i++)
{
if (i <= Math.Min(max_i, min_i) || i >= Math.Max(max_i, min_i))
result[j++] = a[i];
}
return result;
}
На всякий случай в заголовках
using System;
using System.Diagnostics;
using System.Linq;
Спасибо! выводит ошибку что нет главной точки входа статического метода Main
Правильно. Сделайте его и вызовите из него эту функцию, чтоя написала
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
internal static class Program
{
private static void Main()
{
try
{
var r = DeleteSomethingInArray(new[] {-2, -3, -1, 0, 0, 1, 2, 3});
Console.WriteLine(r.Aggregate("", (s, x) => $"{s} {x}"));
}
catch(Exception e)
{
Console.WriteLine(e);
}
finally
{
Console.ReadLine();
}
}
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
internal static class Program
{
private static void Main()
{
try
{
var r = DeleteSomethingInArray(new[] {-2, -3, -1, 0, 0, 1, 2, 3});
Console.WriteLine(r.Aggregate("", (s, x) => $"{s} {x}"));
}
catch(Exception e)
{
Console.WriteLine(e);
}
finally
{
Console.ReadLine();
}
}
private static int[] DeleteSomethingInArray(int[] a)
{
Debug.Assert(a.Length > 1 && a.Any(x => x > 0) && a.Any(x => x < 0));
if (a.Length == 2)
return a;
var max_i = -1;
var min_i = -1;
for (var i = 0; i < a.Length; i++)
{
if (a[i] < 0 && (max_i < 0 || a[max_i] < a[i]))
max_i = i;
if (a[i] > 0 && (min_i < 0 || a[min_i] > a[i]))
min_i = i;
}
{
Debug.Assert(a.Length > 1 && a.Any(x => x > 0) && a.Any(x => x < 0));
if (a.Length == 2)
return a;
var max_i = -1;
var min_i = -1;
for (var i = 0; i < a.Length; i++)
{
if (a[i] < 0 && (max_i < 0 || a[max_i] < a[i]))
max_i = i;
if (a[i] > 0 && (min_i < 0 || a[min_i] > a[i]))
min_i = i;
}
var result = new int[a.Length - Math.Abs(max_i - min_i) + 1];
var j = 0;
for (var i = 0; i < a.Length; i++)
{
if (i <= Math.Min(max_i, min_i) || i >= Math.Max(max_i, min_i))
result[j++] = a[i];
}
return result;
}
}
var j = 0;
for (var i = 0; i < a.Length; i++)
{
if (i <= Math.Min(max_i, min_i) || i >= Math.Max(max_i, min_i))
result[j++] = a[i];
}
return result;
}
}
Вот полностью с оберткой. Просто оно все довольно массивное.
Спасибо!!
Похожие вопросы
Предмет: Геометрия,
автор: dragonstandof2
Предмет: История,
автор: iolanta1234573
Предмет: История,
автор: Nna24
Предмет: Математика,
автор: sgolumbiauskien