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

Упрощение программного кода - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Работа со строками char http://www.cyberforum.ru/cpp-beginners/thread712393.html
Например у меня есть строка "арпарвправпрвпа собака вававапа" . Как мне выделить (найти) это слово в строке?
C++ getline: ошика синтаксиса Нужно чтобы функция получала поток и из него тянула текст. Скорее всего буду потом подсовывать такой функции поток stringstream. Проблема: getline отказывается компилироваться, говорит что неправильные аргументы, хотя вроде правильно же всё указал: TextHelper(const istream& is) { string str; size_t strPos; sentenceDelimeters="!?"; char delim = '.'; while(!is.eof()) {... http://www.cyberforum.ru/cpp-beginners/thread712391.html
Определить сумму квадратов и кол-во введенных чисел.при A i+1>A i C++
Помогите решить задачу,очень нужно!!!!
C++ Программа с массивом
Здраствуйте, мне дали программу с массивом, помогите мне её исправить и дополнить. Задание было таковым: Дан массив целых чисел. Найти максимальный элемент массива и его порядковый номер. Сама программа: #include <iostream> using namespace std; int main() { int a, MAX, Num;
C++ Дописать в файл 5 случайных чисел и вывести на экран его содержимое http://www.cyberforum.ru/cpp-beginners/thread712384.html
Если не сложно, то помогите, пожалуйста, написать программу такого рода: Составить программу, которая дописывает в файл из предыдущей задачи 5 случайных чисел и выводит на экран содержимое файла Сам код предыдущей задачи был таков: #include "stdafx.h" #include <iostream> #include <stdio.h> {File *Ch; int x,i; Ch=fopen("Ch.txt", "w");
C++ Структура, список Дан файл, содержащий сведения о сотрудниках. Структура записи файла: -табельный номер; -фамилия и инициалы сотрудника; -должность; -зарплата. Программа должна выводить. -список сотрудников, по заданной должности; -список сотрудников с min зарплатой. Вот мой код, да вот только беда не работает он. подробнее

Показать сообщение отдельно
Renxcer
0 / 0 / 0
Регистрация: 01.11.2012
Сообщений: 7
28.11.2012, 19:46     Упрощение программного кода
Всем здравствуйте а можно ли упростить вот этот код:
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
#include "stdafx.h"
#include <iostream>
#include <locale>
#include <stdlib.h>
#include <time.h> 
#include <algorithm>
#include <functional>
#include <numeric>
#include <iterator>
#include <limits>
 
struct R { int operator()() const
{
    setlocale(LC_ALL,"rus");
    return rand() % 21 - 10; } };
    template <typename Iterator>
Iterator next(Iterator it)
{ 
    std::advance(it, 1); 
    return it;
} 
template <typename Iterator>
void print(Iterator begin, Iterator end)
{
    typedef std::ostream_iterator<typename std::iterator_traits<Iterator>::value_type> O;
std::copy(begin, end, O(std::cout, " ")); 
std::cout << std::endl;
} 
template <typename Iterator, typename F>
void find(Iterator begin, Iterator end, F f) 
{ 
    typedef typename std::iterator_traits<Iterator>::value_type T;
struct { T sum; Iterator begin, end; } 
max = { std::numeric_limits<T>::min(), begin, end };
std::cout <<"Все последовательности: " << std::endl; 
print(max.begin, max.end); 
for (; (begin = std::find_if(begin, end, f)) != end;)
{ 
    Iterator seq_end = std::find_if(next(begin), end, std::not1(f)); 
    T sum = std::accumulate(begin, seq_end, T());
if (sum > max.sum) { max.sum = sum; max.begin = begin; max.end = seq_end; }
begin = seq_end; } if
(max.sum != std::numeric_limits<T>::min()) 
{ std::cout << "Последовательность с максимальной суммой: " << std::endl;
print(max.begin, max.end); 
} 
  else std::cout << "Последовательность не имеющая положительных чисел" << std::endl; }
int main() { std::locale::global(std::locale("")); 
srand((unsigned) time(NULL)); 
int arr[20]; std::generate(arr,arr + sizeof(arr) / sizeof(arr[0]), R()); ::find(arr, arr + sizeof(arr) / sizeof(arr[0]), std::bind2nd(std::greater<int>(), 0));
system("pause");
return 0; }
Чтоб он выглядел более сжатее

Добавлено через 1 минуту
Цель программмы найту ту последовательных чисел сумма которых будет максимальна
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 20:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru