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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Cоздание таблицы ключевых слов и поиск в ней http://www.cyberforum.ru/cpp-beginners/thread8147.html
Не могли кто-нибудь написать программку:Cоздать таблицу ключевых слов , проходить по строке и создает в выходном массиве ссылки на позицию. Номер в таблице ключевых слов. У меня даже есть код но там ошибки выдает. Для профи это займет 20-30 минут. Я просто начинающий...
C++ Реализовать булевую функцию как реализовать булевую функцию, то есть, функцию, которая возвращает true or false? например, есть функция определение взаимопорядка следования чисел a и b (выясняет, кто из них больше) и если a>=b, то она должна вернуть тру, а если наоборот - фолз http://www.cyberforum.ru/cpp-beginners/thread8135.html
C++ Символы и строки.
Помогите пожалуйста с решением задачи. Вводится последовательность символов. Формировать новую строку, состоящую из символов исходной строки, в которой вначале идут символы с нечетными значениями кодов, а потом с четными.
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>
C++ Определить, есть ли в тексте указанное слово, и заключить его в квадратные скобки http://www.cyberforum.ru/cpp-beginners/thread8084.html
Дан многострочный текст. Определить, есть ли в нем указанное слово и заключить его в квадратные скобки.
C++ помогите с прогами Помогите с программами,или хотябі обьясните что нужно делать плиз:'( 1.Исходный текст записан на странице с числом символов в строке L. Переписать его на страницу с числом символов в строке M.Слова не разрывать. Считать, что текст помещается на странице целиком. 2.Поиск по шаблону: определить номер позиции в исходной строке, начиная с которой в строке содержиться шаблон S1*S2,где... подробнее

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

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

16.05.2008, 20:48. Просмотров 1152. Ответов 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))
        );
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru