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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C] Одномерные массивы (с исп-ем функций) 
V
    Опции темы
feanaro
Дата 10.1.2007, 11:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Сортировка массива по убыванию. 
Пытался сделать с функциями. Ошибка, си вылетает. Вот код:
Код

#include <stdio.h>
#include <conio.h>

int vvod (int *mas[20],int i,int n);
int sort (int *mas[20],int i,int j,int n,int a);
int vivod (int *mas[20],int i,int n);

void main(void)
{
int n,i,j,a;
int mas[20];
clrscr();
vvod (mas,i,n);
sort (mas,i,j,n,a);
mas[i]=vivod (mas,i,n);
getch();
}

int vvod (int *mas[20],int i,int n)
{
printf("vvedite kol-vo elementov massiva\n");
scanf("%d",&n);
while (n>20)
{
printf("previshen predel kol-va elementov. vvedite zanovo:\n");
scanf("%d",&n);
}
printf("vvedite elementi massiva\n");
for (i=0;i<n;i++)
{
scanf("%d",&mas[i]);
}
return mas[i];
}

int sort (int *mas[20],int i,int j,int n,int a)
{
for (i=0;i<n-1;i++)
{
for (j=0;j<n-i-1;j++)
{
if (mas[j]<mas[j+1])
{
a=mas[j];
mas[j]=mas[j+1];
mas[j+1]=a;
}
}
}
return mas[i];
}

int vivod (int *mas[20],int i,int n)
{
for (i=0;i<n;i++)
{
printf("\n%d",mas[i]);
printf(" ");
}
return mas[i];
}

видимо, какое-то несоответствие типов. 
(не ругайтес, я новичок))
прошу помощи.
 smile 
PM MAIL   Вверх
Kuvaldis
Дата 10.1.2007, 12:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


механик-вредитель
***


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

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



feanaro
Код

int vvod (int *mas[20],int i,int n);

Разберись с правильной передачей параметров
у тебя одномерный массив сортируется, значит в параметрах будет или
int mas[20];
или
int* mas


То, как сделал ты, делают для двумерных массивов


--------------------
Помни - когда ты спишь, враг не дремлет
Спи чаще и дольше, изматывай врага бессоницей
PM MAIL ICQ   Вверх
Rockie
Дата 10.1.2007, 13:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1143
Регистрация: 23.4.2006

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



Код

#include <stdio.h>

#define N 20

int mas[N];
int n = N;

void vvod ()
{
    int i = 0;
    printf("vvedite kol-vo elementov massiva\n");
    scanf("%d",&n);

    while(n>N)     // если введенный размер массива больше, чем зарезервировано в N
    {
        // сообщаем об этом и выходим
        printf("previshen predel kol-va elementov. vvedite zanovo:\n");
        scanf("%d",&n);

    }

        // считываем элементы
    
    printf("vvedite elementi massiva\n");
    for (i=0;i<n;i++)
    { 
        scanf("%d",&mas[i]);
    }

}

void sort ()
{
    int j, a;
    while(1)                
    {
        int flag = 0;      // флаг условия Айверсона 
        for (j=0;j<n-1;j++)
        {
            if (mas[j]<mas[j+1])
            {
                a=mas[j];
                mas[j]=mas[j+1];
                mas[j+1]=a;
                flag=1;    // флаг условия Айверсона, если он равен 1, 
                           // значит какие-то элементы поменялись местами
            }
        }
        if(flag==0) break; // если элементы не менялись местами - масиив отсортирован
    }
}


void vivod ()
{
    int i = 0;
    for (i=0;i<n;i++)
    {
        printf("%d ",mas[i]);
    }
}


int main()
{

    vvod ();
    sort ();
    vivod ();

    return 0;
}





--------------------
Чтобы иметь большой гардероб - надо иметь большой гардероб.
PM   Вверх
feanaro
Дата 11.1.2007, 19:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



KuvaldisRockie,
Благодарю. Разобрался. 

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

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


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

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

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

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


 




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


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

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