Аватар для Bacaramba
0 / 0 / 0
Регистрация: 04.05.2012
Сообщений: 48
1

Немного муторности: переписать готовые решения

22.11.2012, 20:04. Показов 1356. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Я тупо не успеваю это сделать, есть тонна другой работы. Надеюсь на понимание.

Есть 6 супер халявных задач на массивы. К ним есть (!) готовые решения. Нужно туда напихать указатели. Каким боком не важно, главное чтобы они косвенно участвовали в коде, в решении.

1
Кликните здесь для просмотра всего текста
Сначала задано число N - количество элементов в массиве, N100. Далее через пробел записаны N чисел - элементы массива. Все числа по модулю не превосходят 10000. Выведите все элементы массива с четными индексами (то есть A[0], A[2], A[4], ...).

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <stdio.h>
int main()
{
    int i=0, n=0, b=0;
    int a[10000] = {0};
    scanf("%d", &n);
    for(i=0 ; i<n; i++)
    {
        scanf("%d", &b);
        a[i] = b;
    }
 
    for(i=0 ; i<n; i++)
    {
        if(i%2 == 0)
        {
            printf("%d ", a[i]);
        }
    }
    return 0;
}


2
Кликните здесь для просмотра всего текста
Сначала задано число N - количество элементов в массиве. Далее через пробел записаны N чисел - элементы массива. Необходимо вывести все четные элементы массива (то есть те элементы, которые являются четными числами).

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <stdio.h>
int main()
{
    int i=0, n=0, b=0;
    int a[10000] = {0};
    scanf("%d", &n);
    for(i=0 ; i<n; i++)
    {
        scanf("%d", &b);
        a[i] = b;
    }
 
    for(i=0 ; i<n; i++)
    {
        if(a[i]%2 == 0)
        {
            printf("%d ", a[i]);
        }
    }
    return 0;
}


3
Кликните здесь для просмотра всего текста
Сначала задано число N - количество элементов в массиве, N10000.
Далее через пробел записаны N чисел - элементы массива. Все числа по модулю не превосходят 109. Выведите одно число – количество положительных элементов в массиве.

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <stdio.h>
int main()
{
    int i=0, n=0, b=0, c=0;
    int a[10000] = {0};
    scanf("%d", &n);
    for(i=0 ; i<n; i++)
    {
        scanf("%d", &b);
        a[i] = b;
    }
 
    for(i=0 ; i<n; i++)
    {
        if(a[i] > 0)
        {
            c++;
        }
    }
 
    printf("%d", c);
    return 0;
}


4
Кликните здесь для просмотра всего текста
Сначала задано число N - количество элементов в массиве. Далее через пробел записаны N чисел - элементы массива. Необходимо вывести количество элементов массива, которые больше предыдущего элемента в этом массиве.

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
#include <stdio.h>
int main()
{
    int i=0, n=0, b=0, c=0;
    int a[10000] = {0};
    scanf("%d", &n);
    for(i=0 ; i<n; i++)
    {
        scanf("%d", &b);
        a[i] = b;
    }
 
    for(i=0; i<n; i++)
    {
        if(a[i] < a[i+1])
        {
            c++;
        }
 
        if(a[i] < 0 && i == n-1)
        {
            c--;
        }
    }
 
    printf("%d", c);
    return 0;
}


5
Кликните здесь для просмотра всего текста
Сначала задано число N - количество элементов в массиве. Далее через пробел записаны N чисел - элементы массива. Массив содержит только ненулевые числа. Программа должна вывести YES, если есть два соседних элемента с одинаковыми знаками, и NO – иначе.

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
#include <stdio.h>
int main()
{
    int i=0, n=0, b=0, c=0, d=0;
    int a[10000] = {0};
    scanf("%d", &n);
    for(i=0 ; i<n; i++)
    {
        scanf("%d", &b);
        a[i] = b;
    }
 
    for(i=0; i<n; i++)
    {
        if(a[i] > 0 && a[i-1] > 0)
        {
            c++;
        }
 
        if(a[i] < 0 && a[i-1] < 0)
        {
            d++;
        }
    }
 
    if(c > 0)
    {
        printf("YES");
    }
    else
    {
        if(d > 0)
        {
            printf("YES");
        }
        else
        {
            printf("NO");
        }
    }
 
    return 0;
}


6
Кликните здесь для просмотра всего текста
Сначала задано число N — количество элементов в массиве (1N100). Далее через пробел записаны N чисел — элементы массива. Необходимо вывести количество элементов массива, которые строго больше обоих своих соседей.

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <stdio.h>
int main()
{
    int i=0, n=0, b=0, c=0, d=0;
    int a[10000] = {0};
    scanf("%d", &n);
    for(i=0 ; i<n; i++)
    {
        scanf("%d", &b);
        a[i] = b;
    }
 
    for(i=0; i<n-2; i++)
    {
        if(a[i] < a[i+1] && a[i+1] > a[i+2])
        {
            c++;
        }
    }
        printf("%d", c);
 
    return 0;
}


P.S.
Я код писал год назад на начале изучения си, поэтому есть дибильнейшие методы, отсутствие брейков и т. п.

Спасибо.
0
22.11.2012, 20:04
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.11.2012, 20:04
Ответы с готовыми решениями:

Готовые библиотеки для решения систем уравнений
Методом Гаусса. Приведением к диагональному виду. Разрядность 32 бита, при обращении элементов главной диагонали в ноль возвращается FALSE.

Система доставки обновлений алгоритм/готовые решения - ищу
Доброго времени суток. Планируем разработать систему доставки обновлений для программы. Наша программа написана на Qt. Её, со всеми...

Готовые SCSS-решения
Изучаю sass, почитал теорию, посмотрел базисы, небольшое применение нашел в своих проектах, но какой то глобальной панацеи к сожалению,...

6
 Аватар для I.M.
576 / 559 / 47
Регистрация: 16.12.2011
Сообщений: 1,389
22.11.2012, 21:04 2
Bacaramba, все обращения к элементам массива вида a[i] замените на *(a+i)
0
 Аватар для Bacaramba
0 / 0 / 0
Регистрация: 04.05.2012
Сообщений: 48
22.11.2012, 21:11  [ТС] 3
Пхах.

А вообще как можно иначе?

Добавлено через 33 секунды
Просто мне нужно было создавать указатели, а потом их распихивать.
0
 Аватар для I.M.
576 / 559 / 47
Регистрация: 16.12.2011
Сообщений: 1,389
22.11.2012, 21:17 4
что значит создавать и распихивать указатели?
C++
1
2
3
int a[100];
for (int* i = a; i != a+100; ++i)
   *i = 42;
0
 Аватар для Bacaramba
0 / 0 / 0
Регистрация: 04.05.2012
Сообщений: 48
22.11.2012, 21:36  [ТС] 5
Ну например как я понял, например в №1 так:
создать для n *pn, сканить и выводить только по *pn.

Я просто реально занят другими предметами сейчас.
0
 Аватар для I.M.
576 / 559 / 47
Регистрация: 16.12.2011
Сообщений: 1,389
22.11.2012, 21:46 6
Bacaramba, я написал уже два варианта, как работу с массивом можно свести к работе с указателем. Выбирайте любой и встраивайте в свои проги
1
 Аватар для Bacaramba
0 / 0 / 0
Регистрация: 04.05.2012
Сообщений: 48
22.11.2012, 21:58  [ТС] 7
Спасибо, это я уже просто из интереса спрашивал.
0
22.11.2012, 21:58
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.11.2012, 21:58
Помогаю со студенческими работами здесь

Есть ли готовые решения?
Есть ли готовые решения для распознавания самой стандартной, простой капчи? Вот пример : И если нету, дайте ссылки на статьи по...

Есть ли готовые решения?
Что нужно: узнать версию ОС, версию сборки, какой сервис пак, разрядность; какие комплектующие используются; серийники комплектующих...

Есть ли подобные готовые решения?
Хотелось бы реализовать такое: у нас транспортная компания, занимающаяся перевозками пассажиров. У некоторых есть пластиковые карты, на...

Готовые решения написания специализированной CMS
День добрый! Обращаюсь за советом потому как занимался до этого времени исключительно серверными приложениями на Java. Значит речь идет о...

Примеры для программы, готовые решения
Привет всем !!! Есть задача. Нужно сделать график, выбор параметра, календарь. При выборе даты в календаре, выборе параметра,...


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

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

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Опции темы

Новые блоги и статьи
Использование кэша Laravel - полный гайд
bytestream 18.02.2025
Кэширование - один из наиболее эффективных способов повышения производительности веб-приложений. В современном мире, где скорость загрузки страниц напрямую влияет на удержание пользователей и. . .
Создаем REST API в Laravel с аутентификацией и Passport
bytestream 18.02.2025
Разработка современных веб-приложений все чаще требует создания надежного и хорошо структурированного API. REST API стал стандартом де-факто для построения взаимодействия между клиентской и серверной. . .
Пайплайны в Laravel - полный гайд
bytestream 18.02.2025
Разработка современных веб-приложений часто требует обработки сложных процессов, состоящих из множества последовательных шагов. Например, при создании системы комментариев может потребоваться. . .
Как правильно использовать @required в Symfony
bytestream 18.02.2025
При разработке приложений на Symfony мы часто сталкиваемся с необходимостью внедрения зависимостей. Фреймворк предоставляет несколько способов управления этим процессом, и одним из таких инструментов. . .
Система безопасности в Laravel: возможности и примеры
Wired 18.02.2025
Каждый день появляются новые виды атак и уязвимостей, которые могут поставить под угрозу конфиденциальные данные пользователей и функционирование всей системы. В этом контексте выбор надежного. . .
Давайте сравним Django и Laravel
Wired 18.02.2025
Django и Laravel - два мощных инструмента, которые часто сравнивают между собой. Оба фреймворка предлагают разработчикам богатый набор возможностей для создания масштабируемых веб-приложений, но. . .
Laravel или React - что лучше?
Wired 18.02.2025
В разработке веб выбор правильного инструмента часто определяет успех всего проекта. Особенно интересным представляется сравнение Laravel и React - двух популярных технологий, которые часто. . .
Laravel 11: новые возможности, гайд по обновлению
Wired 18.02.2025
Laravel 11 - это новая масштабная версия одного из самых популярных PHP-фреймворков, выпущенная в марте 2024 года. Эта версия продолжает традицию внедрения передовых технологий и методологий. . .
Миграции в Laravel
Wired 18.02.2025
Разработка веб-приложений на Laravel неразрывно связана с управлением структурой базы данных. При работе над проектом часто возникает необходимость вносить изменения в схему базы данных - добавлять. . .
Аутентификация в Laravel
Wired 18.02.2025
В современном мире веб-разработки безопасность пользовательских данных становится критически важным аспектом любого приложения. Laravel, как один из самых популярных PHP-фреймворков, предоставляет. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru