Форум программистов, компьютерный форум 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++ подробнее

Показать сообщение отдельно
MrCold
852 / 750 / 71
Регистрация: 11.01.2012
Сообщений: 1,942
21.03.2013, 17:52     Работа со списками (Проверить, упорядочены ли числа по возрастанию или по убыванию)
На Си написал ...

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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
 
struct Node
{
    float Data;
    struct Node* Next;
};
struct Node* Head = NULL;
struct Node* Curr = NULL;
 
/*  ------------------------
         Create Node 
----------------------------*/
 
struct  Node* CreateNode()
{
    struct  Node* innode;
    if (NULL == (innode = (struct  Node*)malloc(sizeof(struct  Node))))
    {
        printf("Error in allocated memory");
        exit(1);
    }
    return innode;
};
 
/*  ------------------------
         Create List 
----------------------------*/
void CreateListFromFile(const char * filename)
{
      float fileData = 0;
      struct    Node* addNode = NULL;
      FILE *fp;
       if((fp = fopen( filename, "r")) == NULL)
       {
           printf("Error in opening file.\n");
        exit(1);
    } 
    while ( ! feof(fp))
    {                       
       if( fscanf(fp,"%f",&fileData) != 1)
             break;
       
        addNode = CreateNode();
        addNode->Data = fileData;       
        addNode->Next = Head;
        Head = addNode;
    }        
        fclose(fp);
}
 
/*  ------------------------
         Show List 
----------------------------*/
void ShowList()
{
    Curr = Head;
    while ( Curr )
    {
       printf (" %.2f\n", Curr->Data);
       Curr = Curr->Next;
       
    }
}
/*  ------------------------
         Clear List 
----------------------------*/
 void ClearList()
{
    
   while ( Curr )
    {
        Curr = Head;
        free( Curr);
        Head = Head->Next;
        
    }
}
 /* ------------------------
         Clear List 
----------------------------*/
 int IsSorted() 
 {
   struct  Node* Temp =  CreateNode();
   int size    = 0;
   int counter = 0;
   Temp->Data = 0;
   Curr = Head;
    while ( Curr )
    {
       Temp = Curr;
       Curr = Curr->Next;
       if ( Curr != NULL )
       {
         if ( Temp->Data <= Curr->Data )
           counter++;
         if ( Temp->Data >= Curr->Data )
           counter--;
       }
       size++;
    }  
       free(Temp);
 
    if ( counter == 0 ) 
        return 0;
      return size / counter;
}
 
int main(int argc, char *argv[])
{
    char ch;
    int sorted = 0;
 
    CreateListFromFile("Test.txt");
    ShowList();
    sorted = IsSorted();
        if (sorted == 1) printf ("List sorted in ascending\n");
        else if (sorted == -1) printf ("List sorted in descending order\n");
        else
            printf ("List not sorted \n");
 
        ClearList();
 
        scanf("%c",&ch);
        return 0;
}
 
Текущее время: 17:42. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru