Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.78
oper24
1 / 1 / 0
Регистрация: 12.07.2010
Сообщений: 55
#1

Функция - C++

17.09.2010, 14:20. Просмотров 1205. Ответов 22
Метки нет (Все метки)

Нужно написать ф-цию которая упорядоченный массив выводит в случайном порядке?
Не могу понять алгоритм перестановки элементов???
Вот что у меня получилось:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#include <windows.h>
#include <iostream>
#include<time.h>
#include<stdlib.h>
using namespace std;
 
void mix(int mas[], int size)
{
    int temp;
    for(int i=0; i<size; i++)
    {   
        temp=mas[i];
        mas[i]=mas[20-1];
        mas[20-1]=temp; 
            
    }
    
 
 
}
 
 
 
 
void main ()
{
    
    SetConsoleOutputCP(1251);
    HANDLE h = GetStdHandle(STD_OUTPUT_HANDLE);
    SetConsoleTextAttribute(h,2);
    srand ((unsigned int) time (NULL));
    
    cout<<"\t\tИсходный массив из 20 эдементов:"<<endl;
    cout<<endl;
    const int size=20;
    int mas[size]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20};
        for(int i=0; i<size; i++)
            cout<<mas[i]<<", ";
        cout<<endl;
        cout<<"_____________________________________________________________________";
        cout<<"\n\n";
 
        mix(mas, size);
        for(int i=0; i<size; i++)
            cout<<mas[i]<<endl;
        
 
 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.09.2010, 14:20
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Функция (C++):

Функция удаления текста в скобках [2], непосредственно функция + 12кб вложений - C++
Доброго времени суток, случилось так, что пришлось работать с с-строками (лаба, угу), в которой нужно удалить весь текст в скобках,...

Перегрузка операций: friend-функция или функция-член класса - C++
Здравствуйте, меня интересует вопрос, в чем разница при перегрузке операторов через operator и friend. Вот к примеру такой код. class...

Функция sqrt: существует более одного экземпляра. Функция перегруженная - C++
#include &lt;iostream&gt; #include &lt;math.h&gt; #include &lt;iomanip&gt; using namespace std; int main(){ float s, p; int c, a; s=0; ...

какую библиотеку надо подключать чтоб работала функция _getch() и функция cin.get() - C++
какую библиотеку надо подключать чтоб работала функция _getch() и функция cin.get()

Чистая виртуальная функция функция не имеет оператора переопределения - C++
Пишу программу для записи заметок. Есть 2 класса: Page и Note. Note наследуется от Page. Page.h #pragma once ...

что за функция такая strstr? или это не функция? - C++
void search(sp *list){ sp *prt = list; char f,r; cout&lt;&lt;Rus(&quot;введите текст&quot;)&lt;&lt;endl; cin&gt;&gt;f; cout&lt;&lt;Rus(&quot;введите выходной...

22
ForEveR
В астрале
Эксперт С++
7979 / 4738 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
17.09.2010, 17:18 #16
oper24, Да. Но в массиве. А не просто с бухты барахты.
А цикл тут нафига я тоже не понимаю. Достаточно просто
x=rand()%size;
А дальше уже сравнение с элементами массива в цикле. Как только нашел либо возвращай, либо просто пиши его. И прекращай цикл.
0
oper24
1 / 1 / 0
Регистрация: 12.07.2010
Сообщений: 55
17.09.2010, 17:27  [ТС] #17
Цитата Сообщение от Lavroff Посмотреть сообщение
oper24, Найти без проблем.

C++
1
2
3
4
5
6
7
8
9
int temp=1+rand()%size;
for(int i=0; i<size; ++i)
{
    if(mas[i]==temp)
    {
         std::cout<<i;
         break;
    }
}
В данном примере на экран ты выводишь индекс элемента
C++
1
cout<<i;
, а чтобы вывести число надо
C++
1
cout<<temp;
0
ForEveR
В астрале
Эксперт С++
7979 / 4738 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
17.09.2010, 17:29 #18
oper24, Я прекрасно знаю что я вывожу номер элемента оО. Спасибо кэп. Но ведь кажется именно номер элемента тебе надо найти для последующей сортировки.
0
oper24
1 / 1 / 0
Регистрация: 12.07.2010
Сообщений: 55
17.09.2010, 17:36  [ТС] #19
Цитата Сообщение от Lavroff Посмотреть сообщение
oper24, Я прекрасно знаю что я вывожу номер элемента оО. Спасибо кэп. Но ведь кажется именно номер элемента тебе надо найти для последующей сортировки.
=)))) Я просто для себя уточнил,спасибо,но надо вывести число и его индекс,
C++
1
//вывод числа cout<<temp; правильно
0
ForEveR
В астрале
Эксперт С++
7979 / 4738 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
17.09.2010, 17:38 #20
oper24, да пожалуйста.

C++
1
2
3
4
5
6
7
8
9
int temp=1+rand()%size;
for(int i=0; i<size; ++i)
{
    if(mas[i]==temp)
    {
         std::cout<<temp<<' '<<i<<'\n';
         break;
    }
}
0
oper24
1 / 1 / 0
Регистрация: 12.07.2010
Сообщений: 55
17.09.2010, 17:41  [ТС] #21
Ну вот теперь понятно, осталось только сортировку сделать,да ну и напряжно я только 2 месяца учусь.
0
ForEveR
В астрале
Эксперт С++
7979 / 4738 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
17.09.2010, 17:56 #22
oper24, С сортировкой тоже проблем нет...

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
for(int i=0; i<ind; ++i)
{
    for(int j=i; j<ind; ++j)
    {
        if(mas[i]<mas[j])
        {
             int temp=mas[i];
             mas[i]=mas[j];
             mas[j]=temp;
        }
     }
}
for(int i=ind+1; i<size; ++i)
{
    for(int j=i; j<size; ++j)
    {
         if(mas[i]>mas[j])
         {
              int temp=mas[i];
              mas[i]=mas[j];
              mas[j]=temp;
         }
    }
}
Ну это так. Примерный вариант.
0
easybudda
Модератор
Эксперт CЭксперт С++
9683 / 5633 / 956
Регистрация: 25.07.2009
Сообщений: 10,812
17.09.2010, 18:42 #23
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
int shake(const void * a, const void * b){
    return rand() - rand();
}
 
int asc(const void * a, const void * b){
    return *(int*)a - *(int*)b;
}
 
int desc(const void * a, const void * b){
    return *(int*)b - *(int*)a;
}
 
int * find(int val, int * arr, int size){
    return ( size == 0 ) ? NULL : ( *arr == val ) ? arr : find(val, ++arr, --size);
}
 
int main(void){
    int * arr, * ptr, value, i, size;
 
    srand(time(NULL));
 
    printf("Number of elements: ");
    if ( scanf("%d", &size) != 1 || size < 1 ){
        fprintf(stderr, "Wrong input!\n");
        exit(1);
    }
    if ( ( arr = (int*)malloc(sizeof(int) * size) ) == NULL ){
        perror("malloc");
        exit(1);
    }
    printf("Sorted:\n");
    for ( i = 0; i < size; ++i )
        printf("%02d ", ( arr[i] = i + 1));
    qsort(arr, size, sizeof(int), shake);
    printf("\nUnsorted:\n");
    for ( i = 0; i < size; ++i )
        printf("%02d ", arr[i]);
 
    value = rand() % size + 1;
 
    if ( ( ptr = find(value, arr, size) ) == NULL ){
        fprintf(stderr, "Can't find value %d in array!\n", value);
        free(arr);
        exit(1);
    }
    printf("\nArray[%d] = %d\n", ptr - arr, value);
    qsort(arr, ptr - arr, sizeof(int), desc);
    qsort(ptr + 1, size - ( ptr + 1 - arr ), sizeof(int), asc);
    printf("Descendant before, ascendant after:\n");
    for ( i = 0; i < size; ++i )
        printf("%02d ", arr[i]);
    printf("\n");
 
    free(arr);
    exit(0);
}
1
17.09.2010, 18:42
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.09.2010, 18:42
Привет! Вот еще темы с ответами:

Создать производный класс, в котором реализована функция умножения вектора на число и функция сложения двух векторов - C++
Write программу с использованием класса Вектор (не без помощи форумчанина), но необходимо создать производный класс, в котором реализована...

Функция заполняющая массив и функция вывода массива - C++
Напишите две функции. Первая функция заполняет массив, вторая функция выводит массив на экран

Нужно сделать, чтобы программа состояла из 3 функций, тоесть 1-ая функция ввода массива, 2-ая основная функция, 3-я- вывод массива - C++
Есть программа #include &lt;iostream&gt; #include &lt;algorithm&gt; const int N = 5; int handSet(void) { int a; std::cout...

Функция возвращающая абсолютное разницу первого и второго параметров и функция типа int, возвращающая минимальное из трех целых чисел - C++
Разработать заданные согласно условия функции и сделать в главной программе по два вызова этих функций с различными параметрами. Для...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
23
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru