Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C#] Обработка одномерных массивов 
:(
    Опции темы
GNWP69
Дата 6.4.2011, 08:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 2
Регистрация: 6.4.2011

Репутация: нет
Всего: нет



Цитата

Разработать и отладить программу, в которой реализовать алгоритмы сортировки и поиска в соответствии с заданием. Определить время работы программы. 
Для выполнения задания необходимо использовать два одномерных массива целых чисел А[M] и В[N] (М и N – произвольные целые числа, не превышающие 2^14). Инициализируйте исходные массивы данными, после чего отсортируйте массивы с использованием алгоритма, указанного в вашем задании. Создайте одномерный массив С, который содержит в одном экземпляре (без повторений) элементы, которые присутствуют в нескольких экземплярах либо только в массиве A, либо только в массиве В. Сравните время работы программы при следующих размерах исходных массивов: 100, 1000, 5000, 10000, 15000 элементов.
Указание: Вспомогательные массивы использовать запрещается, если в алгоритме сортировки не оговорено обратное.


Требуется код для выделенной жирным части задания. Необходимо использовать линейный алгоритм поиска.
Код,который написал сам. Я только начинаю изучать программирование,так что не судите строго. 
Код

using System;

namespace Обработка_одномерных_массивов
{
    class Program
    {
        static void Main()
        {
            int n, m, i, j, d;
            Console.Write("Задайте количество элементов в массиве А: ");
            n = Convert.ToInt32(Console.ReadLine());
            Console.Write("Задайте количество элементов в массиве B: ");
            m = Convert.ToInt32(Console.ReadLine());
            int[] a = new int[n];
            int[] b = new int[m];
            
            Random Rnd = new Random();
            int maxValue = 1000;
            //Заполнение массива А
            for (i = 0; i < n; i++) a[i] = Rnd.Next(0, maxValue);//случайными числами от 0 до 1000
            for (i = 0; i < m; i++) b[i] = Rnd.Next(0, maxValue);//Заполнение массива B
            
            for (i = 0; i < n; i++) Console.Write(a[i] + " ");
            Console.WriteLine();
            for (i = 0; i < m; i++)Console.Write(b[i] + " ");
            Console.WriteLine();
            
            for (i = 1; i < n; i++)//Сортировка "пузырьком" массива А
            {
                for (j = 0; j < n - i; j++)
                {
                    if (a[j] > a[j + 1])
                    {
                        d = a[j];
                        a[j] = a[j + 1];
                        a[j + 1] = d;
                    }
                }
            }
            for (i = 1; i < m; i++)//Сортировка массива Б
            {
                for (j = 0; j < m - i; j++)
                {
                    if (b[j] > b[j + 1])
                    {
                        d = b[j];
                        b[j] = b[j + 1];
                        b[j + 1] = d;
                    }
                }
            }
            for (i = 0; i < n; i++) Console.Write(a[i] + " ");
            Console.WriteLine();
            for (i = 0; i < m; i++) Console.Write(b[i] + " ");
            Console.ReadKey();
        }
    }
}


Это сообщение отредактировал(а) GNWP69 - 6.4.2011, 10:46
PM MAIL   Вверх
Silent
Дата 7.4.2011, 12:14 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 252
Регистрация: 3.10.2006

Репутация: 6
Всего: 9



Как-то так:
Код

int [] c = new [n+m];
int count = 0;
for (int i = 0; i < n; i++)
{
    int j = 0;
    while ((j < m) && (a[i] != b[j])) j++;
    if (j == m)
        c[count++] = a[i];
}
for (int i = 0; i < m; i++)
{
    int j = 0;
    while ((j < n) && (b[i] != a[j])) j++;
    if (j == n)
        c[count++] = b[i];
}

всего получится count элементов
PM MAIL   Вверх
GNWP69
Дата 8.4.2011, 10:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 2
Регистрация: 6.4.2011

Репутация: нет
Всего: нет



Ошибка    1    Синтаксическая ошибка, требуется "]"    
Ошибка    2    Требуется "}"    
Ошибка    3    Недопустимый элемент "]" 
И подчеркивает n и m вот в этом месте.
Код

int [] c = new [n+m];


PM MAIL   Вверх
Silent
Дата 11.4.2011, 12:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 252
Регистрация: 3.10.2006

Репутация: 6
Всего: 9



учись понимать компилятор:
1) первое сообщение компилятора - я недописал объявление массива, 
Код
int [] c = new [n+m];
 - следует читать как 
Код
int [] c = new int [n+m];

2) еще две "ошибки" - компилятор ругается на новые объявления переменных i и j - я ж не стал смотреть, что они у тебя глобальные, да и всегда объявляю переменную цикла локальной.
Не надо тупо копипастить, элементарно посмотри

на всякий случай полный код, вдруг-таки у тебя не получится:
Код

using System;
namespace Обработка_одномерных_массивов
{
    class Program
    {
        static void Main()
        {
            int n, m, i, j, d;
            Console.Write("Задайте количество элементов в массиве А: ");
            n = Convert.ToInt32(Console.ReadLine());
            Console.Write("Задайте количество элементов в массиве B: ");
            m = Convert.ToInt32(Console.ReadLine());
            int[] a = new int[n];
            int[] b = new int[m];

            Random Rnd = new Random();
            int maxValue = 1000;
            //Заполнение массива А
            for (i = 0; i < n; i++) a[i] = Rnd.Next(0, maxValue);//случайными числами от 0 до 1000
            for (i = 0; i < m; i++) b[i] = Rnd.Next(0, maxValue);//Заполнение массива B

            for (i = 0; i < n; i++) Console.Write(a[i] + " ");
            Console.WriteLine();
            for (i = 0; i < m; i++) Console.Write(b[i] + " ");
            Console.WriteLine();

            for (i = 1; i < n; i++)//Сортировка "пузырьком" массива А
            {
                for (j = 0; j < n - i; j++)
                {
                    if (a[j] > a[j + 1])
                    {
                        d = a[j];
                        a[j] = a[j + 1];
                        a[j + 1] = d;
                    }
                }
            }
            for (i = 1; i < m; i++)//Сортировка массива Б
            {
                for (j = 0; j < m - i; j++)
                {
                    if (b[j] > b[j + 1])
                    {
                        d = b[j];
                        b[j] = b[j + 1];
                        b[j + 1] = d;
                    }
                }
            }
            for (i = 0; i < n; i++) Console.Write(a[i] + " ");
            Console.WriteLine();
            for (i = 0; i < m; i++) Console.Write(b[i] + " ");
            Console.ReadKey();

            int[] c = new int[n + m];
            int count = 0;
            for (i = 0; i < n; i++)
            {
                j = 0;
                while ((j < m) && (a[i] != b[j])) j++;
                if (j == m)
                    c[count++] = a[i];
            }
            for (i = 0; i < m; i++)
            {
                j = 0;
                while ((j < n) && (b[i] != a[j])) j++;
                if (j == n)
                    c[count++] = b[i];
            }
        }
    }
}

распечатку нового массива добавишь сам, ок?

Это сообщение отредактировал(а) Silent - 11.4.2011, 12:52
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0692 ]   [ Использовано запросов: 23 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.