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

ошибка в задаче на палиндром - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Треугольник со сторонами a.b.с является равносторонним http://www.cyberforum.ru/cpp-beginners/thread837145.html
3)треугольник со сторонами a.b.с является равносторонним
C++ Если числа не равны, то заменить каждое из них одним и тем же числом, равным большему из исходных, а если равны, то заменить числа нулями 2)Даны целые числа m, n. Если числа не равны, то заменить каждое из них одним и тем же числом, равным большему из исходных, а если равны, то заменить числа нулями. http://www.cyberforum.ru/cpp-beginners/thread837144.html
C++ Какая роль std::istream::sentry
Собственно для чего нужен этот класс? Никак не могу понять.
Написать блок-схему к программе (вывод на экран слов, которые начинаются с гласных букв) C++
Ребята, помогите пожалуйста написать алгоритм(блок-схему) к задаче! Буду ОЧЕНЬ признательна, если поможете) Заранее спасибо! Задача:написать программу, которая считывает английский текст с файла и выводит на экран слова, которые начинаются с гласных букв. #include <iostream> #include <string> #include <vector> #include <cstdlib> bool is_glassn(std::string& c) {
C++ В файле-словаре найти и распечатать слова, которые могут быть полностью составлены из других слов словаря http://www.cyberforum.ru/cpp-beginners/thread837118.html
В файле-словаре найти и распечатать слова, которые могут быть полностью составлены из других слов словаря с помощью конкатенации, например: “БАЛКОН” = “БАЛ” + “КОН”; “БАРСУК” = “БАР” + “СУК”. – Для решения задач не использовать стандартные строковые функции.
C++ static class Хочу создать static class, в котором будет находится static переменная, чтобы она была доступна из разных классов. helper.h static class Helper { public: static int globus; }; В другом классе пишу так: подробнее

Показать сообщение отдельно
scotty
28 / 28 / 1
Регистрация: 09.09.2012
Сообщений: 131
14.04.2013, 03:59     ошибка в задаче на палиндром
Ребят помогите пожалуйста. Задачка найти палиндром в массиве. Писал-писал и в итоге в ф-ии последнее условие if (arr_t1==arr_t2) постоянно выводит ложь, не понимаю, почему оно мне врет(((

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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
//Дан целочисленный массив от 0..N и 
//необходимо найти самый длинный палиндром в массиве
 
 
#include <iostream>
#include <conio.h>
 
const int n = 10;
const int m = 100;
int db[n][m];
 
using namespace std;
 
int main()
{
    bool palindrom(int*, int, int);
    cout<<"Please insert size of array: ";
    int i;
    cin>>i;
    int *mas = new int [i];
    int j;
    for (j = 0; j < i; j++) {
        system("cls");
        cout<<" Please enter "<<j + 1<<"-th elements of array: ";
        cin>>mas[j];
    }
    int temp1 = 0;
    int temp2 = 0;
    for (temp1 = 0; temp1 < i; temp1++) {
    
    for (temp2 = temp1 + 1; temp2 < i; temp2++) 
    if (mas[temp1]==mas[temp2]) {
        cout<<"naideno sovpadenie v poziciyah "<<temp1<<" and "<<temp2<<endl;
        palindrom(mas, temp1, temp2);
    }
    }
    getch();
    return 0;
}
 
/**
* ф-ия ищет палиндром в одномерном целочисленном массиве
* передающие данные в й-ию :
* @int *arr - указатель на одномерный целочисленный массив
*             из которого будем выбирать данные для определения палиндрома
* arr[t1] = arr[t2]
* @int t1 - позиция первого числа которое продублировано в массиве
* @int t2 - позиция второго числа которое продублировано в массиве
*
* @int num - длинна масива с дубляжами
* @int arr_t1 - новый массив с дубляжом
* @int arr_t2 - зеркало к arr_t1
* @int i, j - счетчики
**/
bool palindrom(int *arr, int t1, int t2)
{
    int num = t2 - t1 + 1;
    int *arr_t1 = new int[num];
    int *arr_t2 = new int[num];
    int i = 0, j = 0;
    //берем от первого найденного числа до второго
    for (i = t1, j = 0; i < t2 + 1; i++, j++) {
        arr_t1[j] = arr[i];
        cout<<arr_t1[j]<<" "; 
    }
    cout<<endl;
    //делаем зеркальный массив чисел
    for (i = t2, j = 0; i > t1 - 1; i--, j++) {
        arr_t2[j] = arr[i];
        cout<<arr_t2[j]<<" ";
    }
    cout<<endl;
    if (arr_t1==arr_t2) {
        for (i = 0; i < num; i++) {
        cout<<arr_t1[i]<<" ";
        }
        cout<<endl;
        return true;
    } else {
        cout<<"O_o"<<endl;
        return false;
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 00:16. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru