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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Помогите решить задачу с массивом, задача не сложная 
:(
    Опции темы
b44
Дата 19.5.2006, 14:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



дан целочисленый массив размера n, продублировать в нем все четные числа в этом же массиве.

Получается что размер массива увеличивается в двое. Напишите пожалуйста код

Добавлено @ 14:56 
пожалуйста если что моя ася 290100815 
PM MAIL   Вверх
GremlinProg
Дата 19.5.2006, 15:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2706
Регистрация: 9.8.2005
Где: Тюмень

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



Код

for(int j,c = 0,i = n;i--;)
  if(!(m[i]&0x00000001))
    c++;

m = realloc(m,(n+c)*sizeof(int));

for(j=0,i = n;i--;)
  if(!(m[i]&0x00000001)){
     m[n+(j++)] = m[i];
  }


Добавлено @ 15:07 
а ведь мог бы и сам решить! 


--------------------
"Гений всегда разумнее, чем умнее. Ум — это машина, разум — водитель этой машины."
PM WWW ICQ   Вверх
Earnest
Дата 19.5.2006, 15:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Экс. модератор
Сообщений: 5962
Регистрация: 17.6.2005
Где: Рязань

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



Для домашних заданий, курсовых, существует "Центр Помощи"

Тема перенесена!  


--------------------
...
PM   Вверх
Solomon
Дата 19.5.2006, 15:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 471
Регистрация: 23.1.2006
Где: Украина Киев

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



b44


Цитата(b44 @  19.5.2006,  14:54 Найти цитируемый пост)
продублировать в нем все четные числа в этом же массиве.

Т.е. n+1 елементу присвоить значение первого четного числа, n+2 - второго и т.д? Павильно я понял?

Если я правильно понял то вот
Код

#include <iostream.h>

int A[100]; //Максимальный размер масива я взял 100 и +100 для дополнения массива.
int n=200; 
    int j=0;

void main()
{

    while(n>100)
    {
        //Введем размер массива
        cout<<"Vvedite razmer"; 
        cin>>n;
    }

    cout<<"Vvedite masiv";
    //Введем сам масив
    for(int i=0;i<n;i++) 
    {
        cin>>A[i];
    }

    for(int i=0;i<n;i++)
    {
        if(A[i]%2==0) 
        {
            A[i+n-1]=A[i];
            j++;
        }
    }

    // И выводим получившийся масив на экран
    for(int i=0;i<(n+j);i++) 
    {
        cout<<A[i]<<" ";
    }
}


Добавлено @ 15:22 
GremlinProg, ну ты конечно загнул. Я так понял это задание из учебного заведения. Поверь если он принесет такой ответ как у тебя его учителя пошлют куда подалие.
 я понимаю что у меня туповато написано зато будет понятно всем принцип работы...


p.s. Ну и медленно я пишу smile
пока первое сообщение писал, уже перенесли тему и один раз успели ответить. Ужас.  smile

Добавлено @ 15:26 
Или я неправильно понял. Может если A[i] - четное A [i+1]=A[i] а следущие елементы здвинуть. Объясните мне условие, если я заблуждаюсь  smile 
 smile  


--------------------
Если не идти до конца к поставленным целям и не пытатся их достигнуть, каким бы тяжелым не казался путь, то лучше и не ставь их перед собой, но тот кто не ставит перед собой труднодоступные цели, никогда не ощутит эйфорию настоящей победы... победы над миром...
Соломон 2008
PM MAIL ICQ GTalk YIM   Вверх
b44
Дата 19.5.2006, 16:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



надо делать сдвиг, например массив 1,34,46,7 прога должжна вывести 1, 34,34,46,46,7
пожалуйста исправь написаный мной код

#include<iostream.h>
#include<conio.h>
#include<stdlib.h>
#define n 5
void main()
{
randomize();
clrscr();
int a[2*n];
int j=0;
for(int x=0; x<n; x++)
{
a[x]=random(10)+5;
cout<<a[x]<<' ';
}
cout<<endl;
    for(int i=0; i<n;i++)
    {
    if(a[i]%2==0)
    {
        a[i+n-1]=a[i];
        j++;
    }
    }
    for(i=0; i<(n+j); i++)
    {
    cout<<a[i]<<' ';
    }
getch();

PM MAIL   Вверх
Solomon
Дата 19.5.2006, 17:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 471
Регистрация: 23.1.2006
Где: Украина Киев

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



Воть...
Код

#include<iostream.h>
#include<conio.h>
#include<stdlib.h>

#define n 5
void main()
{
    int a[2*n];
    int j=1;
    for(int x=0; x<n; x++)
    {
        a[x]=rand()%10+8;
        cout<<a[x]<<' ';
    }
    cout<<endl;

    for(int i=0; i<n;i++)
    {
        if(a[i]%2==0)
        {
            for(int h=n+j;h>i;h--)
            {
                   a[h]=a[h-1];
            }
            j++;    
            i++;
        }
    }

    for(i=0; i<n+j-1; i++)
    {
        cout<<a[i]<<' ';
    }
    //getch();



кстати ты с каким С работаешь. Где ты выдрал функции randomize() и clrscr() ???? 


--------------------
Если не идти до конца к поставленным целям и не пытатся их достигнуть, каким бы тяжелым не казался путь, то лучше и не ставь их перед собой, но тот кто не ставит перед собой труднодоступные цели, никогда не ощутит эйфорию настоящей победы... победы над миром...
Соломон 2008
PM MAIL ICQ GTalk YIM   Вверх
b44
Дата 19.5.2006, 17:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



я пишу на Turbo с++

подскажите почему он не дублирует последние два числа если они четные

#include<iostream.h>
#include<conio.h>
#include<stdlib.h>
#define n 5
void main()
{
randomize();
clrscr();
    int a[2*n];
    int j=1;
    for(int x=0; x<n; x++)
    {
    a[x]=random(10)+8;
    cout<<a[x]<<' ';
    }
    cout<<endl;

    for(int i=0; i<n;i++)
    {
    if(a[i]%2==0)
    {
        for(int h=n+j;h>i;h--)
        {
           a[h]=a[h-1];
        }
        j++;
        i++;
    }
    }
    for(i=0; i<n+j-1; i++)
    {
    cout<<a[i]<<' ';
    }
    getch();
}
 
PM MAIL   Вверх
Solomon
Дата 19.5.2006, 17:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 471
Регистрация: 23.1.2006
Где: Украина Киев

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



b44, Даже незнаю, у меня вроде норально работало...
зайди в аську я тебе написал, может что предумаем.... 


--------------------
Если не идти до конца к поставленным целям и не пытатся их достигнуть, каким бы тяжелым не казался путь, то лучше и не ставь их перед собой, но тот кто не ставит перед собой труднодоступные цели, никогда не ощутит эйфорию настоящей победы... победы над миром...
Соломон 2008
PM MAIL ICQ GTalk YIM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

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


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

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

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

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


 




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


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

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