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

Помогите оптимизировать код - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Декодирование звука http://www.cyberforum.ru/cpp-beginners/thread8095.html
Пожалуйста помогите написать прогу которая будет читать зарание записаный аудио файл тонового набора тедефонного номера, и преобразовать его в числовой вид, или подскажите где найти инфу об этом? Спасибо!
C++ Перегрузка операторов и полиморфизм Есть массив указателей Data* в каждой ячейке которого указатель на string,int или float Никак не получается перегрузить оператор + так чтобы string+string оставался string int+float оставался float int+int -int string+int/float-string Заранее спасибо,буду рад любой помощи а то уже всю голову изломал код #ifndef Data_Lst_H #define Data_Lst_H #include<iostream> #include<string> http://www.cyberforum.ru/cpp-beginners/thread8094.html
C++ Определить, есть ли в тексте указанное слово, и заключить его в квадратные скобки
Дан многострочный текст. Определить, есть ли в нем указанное слово и заключить его в квадратные скобки.
Интерпретация морского боя C++
Интерпретация морского боя. Доброго времени суток. Без долгих вступлений к сути проблемы. Нужно в короткие сроки написать программу морской бой на С++, отличающуюся от оригинала 2 вещами: 1.Пушка стреляет не точно в заданный квадрат, а с равной долей вероятности поражает элемент квадрата 3х3, центром которого была выбранная пользователем/компьютером точка. 2.После промаха пользователя на...
C++ Регулярные выражения. Конечные автоматы. Распознаватель http://www.cyberforum.ru/cpp-beginners/thread7991.html
Возможность использовать функции Abs, Tan в выражениях помогите... вот пример программы: // Calculator // 1. Gramma // Expr ::= // Expr + Term // Expr - Term // Term
C++ Выпуклая оболочка Дан эталонный проект "Выпуклая оболочка" // Pol.cpp : Defines the entry point for the console application. // //#include "stdafx.h" #include <iostream.h> #include <math.h> //Klass, opisyvauchiy tochku (Point) na ploskosti (R2) class R2Point подробнее

Показать сообщение отдельно
insi
Сообщений: n/a

Помогите оптимизировать код - C++

16.05.2008, 20:48. Просмотров 1144. Ответов 1
Метки (Все метки)

Помогите пожалуйста разобраться, хотелось бы чтобы это прграммка наконец-то заработала. Задача такая:

Одномерный массив целых чисел, размер которго задается с клавиатуры. Запрограммировать следующие действия с массивом:
1. циклически сдвигать на К позиций влево;
2. выяснить, упорядочены ли элементы массива по невозрастанию или неубыванию;
3. если в исходном массиве количество положительных значений меньше, чем отрицательных, то создавать новый массив для отрицательных значений, в противном случае - создавать массив для положительных значений и переписывать в него соответствующие значения исходного массива.

В приложении необходимо:
1. Для временного хранения наборов значений использовать только временные динамические массивы;
2. Программирование заданных действий производить с использованием указателей;
3. Вывод результатов оформлять в виде таблицы;
4. Создать пользовательсике функции;
5. В приложении необходимо обеспечить возможность выбора конкретного действия;
6. В приложении необходимо обеспечить возможность повторного выполнения задания без перезапуска приложения;



Код:
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
     int N;
    cin>>N;
    int *pm=new int[N];
// arr = указатель на первый элемент массива
// N = количество элементов в массиве
// shift = куда и на сколько двигать
// проверки на валидность отсутствуют
template <typename T>
void rotate(T* arr, size_t N, typename std::iterator_traits<T>::difference_type shift)
{
    if (shift < 0)
        shift = N+shift;
    std::rotate(arr, arr+shift, arr+N);
}
// Невозрастающая
template <typename T>
bool nonincreasing(T* arr, size_t N)
{
    return std::adjacent_find(arr, arr+N, std::less<T>()) == arr+N;
}
 
// Неубывающая
template <typename T>
bool nondecreasing(T* arr, size_t N)
{
    return std::adjacent_find(arr, arr+N, std::greater<T>()) == arr+N;
}
// двойной проход
template <typename T>
std:: pair<size_t, size_t> posneg_count(T* arr, size_t N)
{
    return std::make_pair(
        std::count_if(arr, arr+N, std::bind2nd(std::less<T>(), 0)),
        std::count_if(arr, arr+N, std::bind2nd(std::greater<T>(), 0))
        );
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 04:33. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru