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

Поменять местами серии - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ не запускается программа http://www.cyberforum.ru/cpp-beginners/thread674189.html
#include "stdafx.h" #include<iostream> #include<math.h> using namespace std; int _tmain(int argc, _TCHAR* argv) {bool choise1(int); int choise2(int); int choise3(int); int choise4(int);
C++ Написать рекурсивную функцию вычисления количества цифр натурального числа(исправить код) Написать рекурсивную функцию вычисления количества цифр натурального числа. Я вот написал, но программа считает только первые 9 чисел! В чем проблема? #include<conio.h> #include<stdio.h> int chislo(long a){ if(a<10) return 1; else return chislo(a/10)+1; } http://www.cyberforum.ru/cpp-beginners/thread674175.html
C++ Имеются ли у кого либо алгоритмы для решения функции Аккермана
нужно вывеси матрицу размером 5х5 то есть найти значения 25 элементов вся проблема в диапазонах чисел функция возрастает с бешеной скоростью и не входит ни в один из типов, как обойти эту проблему есть идея реализовать китайскую арифметику, через стеки. что еще можете предложить.
C++ Реализовать класс Complex для работы с комплексными числами
Комплексное число представляются парой действительных чисел (a, b), где a — действительная часть, b — мнимая часть. Реализовать класс Complex для работы с комплексными числами. Обязательно должны присутствовать операции: – сложения add, (a, b) + (c, d) = (a + b, c + d); – вычитания sub, (a, b) − (c, d) = (a − b, c − d); – умножения mul, (a, b) × (c, d) = (ac − bd, ad + bc); – деления dis,...
C++ Для каждой пары чисел вычислить среднее гармоничное этих чисел по формуле http://www.cyberforum.ru/cpp-beginners/thread674150.html
Привет! Нужно написать программу по ссылке! Я вот написал, но не знаю ли я ее правильно написал!! Проверьте кто-то пожалуйста!) Вот условие задачи: Написать программу, которая вводит с клавиатуры пару чисел a и b до тех пор, пока a! = 0 или b! = 0. Для каждой пары чисел вычислить среднее гармоничное этих чисел по формуле: среднее гармоничное = 2 * a * b / (a + b) #include <iostream>
C++ Что изучать после C++ Какую книгу после изучение С++.Советуйте почитать? В смысл,что изучать дальше?MFC...QT.... Я как бы хочу получиьт знания для разработки приложение под Виндовс, под IPhone, Android Короче ,чтобы Software Development'ом заниматься. Спасибо подробнее

Показать сообщение отдельно
MasterRO
37 / 5 / 3
Регистрация: 15.09.2011
Сообщений: 73
18.10.2012, 18:43     Поменять местами серии
Дано два натуральных числа n и k, и последовательность из n чисел. Преобразовать массив, поменяв местами k серию с последней, если серий в массиве меньше чем k, то оставить массив без изменения.

Вот, что у меня получилось:
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
61
62
#include "stdafx.h"
#include <iostream>
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL, "Russian");
    int n,k,i,pk, pe;
    cout<<"Введите n: ";
    cin>>n;
    int a[20], b[20];
    for(i=0; i<n; i++)
    {
        cout<<"Введите а["<<i<<"]: ";
        cin>>a[i];
    }
    cout<<"Введите k: ";
    cin>>k;
    
//ищем серию под номером k и запоминаем позицию первого элемента и ее длину
    int count=0, f, dl=1, l=1; i=0; 
    while((k>count)&&(i<n))
    {   f=0; l=1;
        while(a[i]==a[i+1])
        {
            f=1; l++; pk=i+1-l+1; i++;
        }if(f==1) { dl=l; count++;}
 
        i++;
    }
 
//ищем последнюю серию и запоминаем позицию первого элемента и ее длину
    int dle=1;
    for(i=0; i<n; i++)
    {
        f=0; l=1;
        while(a[i]==a[i+1])
        {
            f=1; l++; pe=i-l+2; i++;
        }if(f==1) { dle=l;}
 
        i++; 
        }
 
//создаем массив, меняя серии местами.
/*      for(i=0; i<pk; i++)
            b[i]=a[i]; 
        for(i=pk; i<pk+dle; i++)
            b[i]=a[pe]; 
        for(i=pk+dle; i<pe; i++)
            {b[i]=a[i];  
        for(i=pe; i<dl+pe; i++)
            b[i]=a[pk];  
        for(i=pe+dl; i<n; i++)
            b[i]=a[i];  
                for(i=0; i<n; i++)
            cout<<b[i]<<" ";  
*/
 
    system("pause");
    return 0;
}
Необходимо поменять серии местами не используя других массивов.......ломаю голову

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