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

Работа со списками (Проверить, упорядочены ли числа по возрастанию или по убыванию) - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Зацикливание Функции http://www.cyberforum.ru/cpp-beginners/thread814461.html
После подсчёта спрашивать : "Повторить ? (y/n)", если "y" то в начала цикла с запросом сколько часов..если "n" то выход #include "iostream" #include "iomanip" #include "math.h" float calculateCharges(float); using namespace std; int _tmain(int argc, _TCHAR* argv) {
C++ Из заданных множеств X1,X2,X3 получить множество Y и его мощность Помогите написать программу.%-) Ниже прикреплён сам файл с уравнениями. За ранее спасибо. http://www.cyberforum.ru/cpp-beginners/thread814437.html
C++ Вводится строка. Все буквы в строке преобразовать в заглавные
Написать программу, которая принимает от пользователя одну или две строки, в зависимости от задачи. Решать задачи рекомендуется двумя способами: 1) объявляя строки как массивы символов 2) использовать шаблон string Вводится строка. Все буквы в строке преобразовать в заглавные.
C++ Работа с текстовым файлом (название файлы через переменную)
доброго времяни суток,подскажите хочу ввести в кансоль переменную типа строка,а затем создать и открыть файл название каторого есть эта переменная,возможно ли такое?если да в чем ошибся? cin >> s5; f=fopen("%s","w",s5);
C++ Только в циклах с++ в (коде блокс) Заранее благодарен! http://www.cyberforum.ru/cpp-beginners/thread814414.html
Дано целое число K наборов ненулевых целых чисел. Ка- ждый набор содержит не менее двух элементов, признаком его завершения является число 0. Для каждого набора выполнить следующее действие: ес- ли элементы набора возрастают, то вывести 1; если элементы набора убы- вают, то вывести –1; если элементы набора не возрастают и не убывают, то вывести 0.
C++ Цикл: Вывести на экран все различные элементы набора данных по возрастанию Дано целое число N и набор из N целых чисел, упорядоченный по возрастанию. Данный набор может содержать одинаковые элементы. Вывести в том же порядке все различные элементы данного набора. c++ подробнее

Показать сообщение отдельно
YuRich48
0 / 0 / 0
Регистрация: 25.02.2013
Сообщений: 18
21.03.2013, 10:56     Работа со списками (Проверить, упорядочены ли числа по возрастанию или по убыванию)
Прошу помощи! Задача звучит так:"Дан список вещественных чисел. Проверить, упорядочены ли числа по возрастанию или по убыванию." Причем алгоритм проверки на упорядоченность необходимо выделить в отдельную функцию. До этого выделения все работало идеально, но потом просто беда... Вот код, подскажите, где моя ошибка
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include "stdafx.h"
#include <stdio.h>
#include <windows.h>
#include <conio.h>
#include <stdlib.h>
#include <iostream>
 
struct spisok
{
    int data;
    spisok *next; 
};
spisok *pHead=NULL;  
spisok *pPrev=NULL; 
spisok *q =pHead;
spisok *p=NULL;
        
 
/*Описание функции*/int func() 
    {
        int flag;
        int i=1,h=0,g=0;
        while((q->next) != NULL)
        {
            if ((q->data)==(q->next->data))
                q = q->next;
            else
            {
                if (h==0)
                {
                    if ((q->data)<(q->next->data))
                        h=2;
                    else
                        h=1;
                }
                if (h==1)
                {
                    if ((q->data)<(q->next->data))
                    {
                        g=1;
                        h=2;
                        flag=0;
                        //printf("\nChisla ne uporyadocheni");
                        q->next->next=NULL;
                    }
                }
                else 
                    if ((q->data)>(q->next->data))
                    {
                        g=1;
                        h=1;
                        flag=0;
                        //printf("\nChisla ne uporyadocheni");
                        q->next->next=NULL;
                    }
            }
            q = q->next;
        }
        if (g==0)
            {
                if (h==1) flag=-1;
                    //printf("\nChisla uporyadocheni po ubivaniyu");
                else flag=1;
                    //printf("\nChisla uporyadocheni po vozrastaniyu");
            }
    return flag;
    }
 
/*Тело программы*/int main(int argc, _TCHAR* argv[])
{
    SetConsoleOutputCP(1251); 
 
    FILE *f;
    f=fopen("input.txt","r");
    int n=0, ad = 0;
    float x;
    printf ("Spisok elementov\n");
    while (!feof(f))
    {
        fscanf (f,"%f",&x);
        printf (" %f\n",x);
        spisok *q = new spisok; 
        if(pHead == NULL)
            pHead = q;
        else
            pPrev->next = q;
        q->data = x;
        q->next = NULL;
        pPrev = q;
        ad = func(q);
    }
    if (ad==0){ printf("Chisla ne uporyadocheni");}
    if (ad==1) printf("Chisla uporyadocheni po vozrastaniyu");
    if (ad==-1) printf("\nChisla uporyadocheni po ubivaniyu");
    fclose (f);
    getch ();
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 06:01. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru