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

не правильно копирует ( - C++

Восстановить пароль Регистрация
 
//Александр
 Аватар для //Александр
6 / 6 / 0
Регистрация: 15.04.2010
Сообщений: 151
26.09.2010, 20:05     не правильно копирует ( #1
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
#include <iostream>
#include <clocale>
#include <conio.h>
#include <string.h>
using namespace std;
struct AEROFLOT
{
    char name[10];
    int number;
    char type[10];
};
 
void sort_name ( AEROFLOT aeroflot[7])
{   char temp_type[10];
    char temp_name[10];
    int temp_number;
    int j,i,g;
 
    for( g=0;g<7;g++)
        for(i=0;i<=5;i++)
        {
          if(aeroflot[i].name[0]>aeroflot[i+1].name[0])
          {
        for(j=0; j<=10; j++)
    {               
       temp_name[j]=aeroflot[i].name[j];    
        temp_type[j]=aeroflot[i].type[j];
         temp_number=aeroflot[i].number;
       aeroflot[i].name[j]=aeroflot[i+1].name[j];
        aeroflot[i].type[j]=aeroflot[i+1].type[j];
         aeroflot[i].number=aeroflot[i+1].number;
       aeroflot[i+1].name[j]=temp_name[j];
        aeroflot[i+1].type[j]=temp_type[j];
         aeroflot[i+1].number=temp_number;
 
     }
    
          }
        }
        
}
int poisk(AEROFLOT aeroflot[7],char *n)
{ int a[10];
    int i,temp;
    temp=0;
    for (i=0; i<7; i++)
        if(!strcmp(aeroflot[i].type, n))
        
         return (i);
         
         return (-1);
        
}
 
 
 
AEROFLOT add(AEROFLOT aeroflot[7],AEROFLOT f)
{int i;
for (i=0;i<7;i++)
 
    if (aeroflot[i].name[0]=='\0')
 
    { strcpy(aeroflot[i].name,f.name);
      aeroflot[i].number=f.number;
      strcpy(aeroflot[i].type,f.type);
    }
cout << aeroflot[i].name <<endl;
cout << aeroflot[i].number <<endl;
cout << aeroflot[i].type <<endl;
return aeroflot[i];
}
 
 
 
 
int main()                          
{
    setlocale(LC_ALL, "rus");
    AEROFLOT  f;
    AEROFLOT aeroflot[7];
    int i,j,g,temp;
    char n[10];
    temp=0;
        for (i=0;i<7;i++)
            
    {
        cout << "введите название пункта назначения \n";
        cin  >> f.name;
        cout << "введите номер рейса \n";
        cin  >> f.number;                                                
        cout << "введите тип самолета \n";
        cin  >> f.type;
        add(aeroflot,f);
    }
    
        
    {
    sort_name (aeroflot);
    i=0;
    cout << "введите тип нужного Вам самолета\n";
    
    cin  >> n;
    g=0;
    
 
    if (poisk(aeroflot,n)!=-1)
        cout << "Aircraft of this type do not"; else
    {
            cout << "\n";
            cout << "название пункта назначения  ";
            cout << aeroflot[poisk(aeroflot,n)].name; 
            cout << "\n";
            cout << "номер  ";
            cout <<aeroflot[poisk(aeroflot,n)].number;
            
    }
    
    
    
    getch();
    }}
нужно чтобы вводимая мною информация передавалась в функцию add е автоматически заполнялась в свободную ячейку. когда поставил на вывод в add увидел что выводит другие символы. подскажите может я не верно копирую или что не так .
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Reiji Cross
 Аватар для Reiji Cross
26 / 26 / 1
Регистрация: 14.05.2010
Сообщений: 57
26.09.2010, 20:24     не правильно копирует ( #2
Добавлено через 4 минуты
вообще по коду функция add 7 раз к ряду записывает в массив одни и те же значения, и выводит данные 7-го элемента
//Александр
 Аватар для //Александр
6 / 6 / 0
Регистрация: 15.04.2010
Сообщений: 151
26.09.2010, 20:29  [ТС]     не правильно копирует ( #3
подскажите пожалуйста как это исправить просто я первый раз работаю с структурами и не совсем понимаю как с ними обращаться.
//Александр
 Аватар для //Александр
6 / 6 / 0
Регистрация: 15.04.2010
Сообщений: 151
26.09.2010, 20:36  [ТС]     не правильно копирует ( #4
вот то что прога выводит когда я ввожу данные
Миниатюры
не правильно копирует  (  
Reiji Cross
 Аватар для Reiji Cross
26 / 26 / 1
Регистрация: 14.05.2010
Сообщений: 57
26.09.2010, 20:53     не правильно копирует ( #5
для начала объявите массив который будет хранить записи и текущее кол-во элементов в массиве как глобальные переменные, и передавайте по одной записи в add. А также цикл в функции add совсем не нужен.

Добавлено через 9 минут
А еще хотелось бы увидеть само задание
//Александр
 Аватар для //Александр
6 / 6 / 0
Регистрация: 15.04.2010
Сообщений: 151
26.09.2010, 21:05  [ТС]     не правильно копирует ( #6
Описать структуру с именем AEROFLOT, содержащую следующие поля:
• название пункта назначения рейса;
• номер рейса;
• тип самолёта.
Написать программу, выполняющую следующие действия:
• ввод с клавиатуры данных в массив, состоящий из семи структур типа AEROFLOT; записи должны быть упорядочены размещены в алфавитном порядке по названиям пунктов назначения;
• вывод на экран пунктов нахначения и номеров рейсов, обсулживаемых самолётом, тип которого введён с клавиатуры;
• если таких рейсов нет, выдать на дисплей соответствующее сообщение.
Reiji Cross
 Аватар для Reiji Cross
26 / 26 / 1
Регистрация: 14.05.2010
Сообщений: 57
26.09.2010, 21:11     не правильно копирует ( #7
Вот ваша программа написанная только для функции add
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
#include <iostream>
#include <clocale>
#include <conio.h>
#include <string.h>
 
 
using namespace std;
struct AEROFLOT
{
    char name[10];
    int number;
    char type[10];
};
 
AEROFLOT aeroflot[7];
int count = 0;
 
 
AEROFLOT add(AEROFLOT f)
{
 
    if (aeroflot[count].name[0]=='\0')
 
{ strcpy(aeroflot[count].name,f.name);
aeroflot[count].number=f.number;
strcpy(aeroflot[count].type,f.type);
}
cout << aeroflot[count].name <<endl;
cout << aeroflot[count].number <<endl;
cout << aeroflot[count].type <<endl;
return aeroflot[count];
}
 
 
 
 
int main()                          
{
    setlocale(LC_ALL, "rus");
 
    int i,j,g,temp;
    char n[10];
    temp=0;
    AEROFLOT  f;
    for (i=0;i<7;i++)
 
    {
        cout << "введите название пункта назначения \n";
        cin >> f.name;
        cout << "введите номер рейса \n";
        cin  >> f.number;                                                
        cout << "введите тип самолета \n";
        cin >> f.type;
        add(f);
        count++;
    }
 
 
 
    getch();
}
Добавлено через 47 секунд
Правильность не проверял, но должно работать
//Александр
 Аватар для //Александр
6 / 6 / 0
Регистрация: 15.04.2010
Сообщений: 151
26.09.2010, 21:24  [ТС]     не правильно копирует ( #8
большое спасибо смысл понял ща все исправлю
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.09.2010, 21:42     не правильно копирует (
Еще ссылки по теме:

C++ Функция memcpy не копирует байты равные больше $80
Своя функция strcat. Копирует мусор C++
C++ Функция strcpy() не копирует строку

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Nwq
33 / 33 / 2
Регистрация: 24.09.2010
Сообщений: 140
26.09.2010, 21:42     не правильно копирует ( #9
Цитата Сообщение от //Александр Посмотреть сообщение
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
#include <iostream>
#include <clocale>
#include <conio.h>
#include <string.h>
using namespace std;
struct AEROFLOT
{
    char name[10];
    int number;
    char type[10];
};
 
void sort_name ( AEROFLOT aeroflot[7])
{   char temp_type[10];
    char temp_name[10];
    int temp_number;
    int j,i,g;
 
    for( g=0;g<7;g++)
        for(i=0;i<=5;i++)
        {
          if(aeroflot[i].name[0]>aeroflot[i+1].name[0])
          {
        for(j=0; j<=10; j++)
    {               
       temp_name[j]=aeroflot[i].name[j];    
        temp_type[j]=aeroflot[i].type[j];
         temp_number=aeroflot[i].number;
       aeroflot[i].name[j]=aeroflot[i+1].name[j];
        aeroflot[i].type[j]=aeroflot[i+1].type[j];
         aeroflot[i].number=aeroflot[i+1].number;
       aeroflot[i+1].name[j]=temp_name[j];
        aeroflot[i+1].type[j]=temp_type[j];
         aeroflot[i+1].number=temp_number;
 
     }
    
          }
        }
        
}
int poisk(AEROFLOT aeroflot[7],char *n)
{ int a[10];
    int i,temp;
    temp=0;
    for (i=0; i<7; i++)
        if(!strcmp(aeroflot[i].type, n))
        
         return (i);
         
         return (-1);
        
}
 
 
 
AEROFLOT add(AEROFLOT aeroflot[7],AEROFLOT f)
{int i;
for (i=0;i<7;i++)
 
    if (aeroflot[i].name[0]=='\0')
 
    { strcpy(aeroflot[i].name,f.name);
      aeroflot[i].number=f.number;
      strcpy(aeroflot[i].type,f.type);
    }
cout << aeroflot[i].name <<endl;
cout << aeroflot[i].number <<endl;
cout << aeroflot[i].type <<endl;
return aeroflot[i];
}
 
 
 
 
int main()                          
{
    setlocale(LC_ALL, "rus");
    AEROFLOT  f;
    AEROFLOT aeroflot[7];
    int i,j,g,temp;
    char n[10];
    temp=0;
        for (i=0;i<7;i++)
            
    {
        cout << "введите название пункта назначения \n";
        cin  >> f.name;
        cout << "введите номер рейса \n";
        cin  >> f.number;                                                
        cout << "введите тип самолета \n";
        cin  >> f.type;
        add(aeroflot,f);
    }
    
        
    {
    sort_name (aeroflot);
    i=0;
    cout << "введите тип нужного Вам самолета\n";
    
    cin  >> n;
    g=0;
    
 
    if (poisk(aeroflot,n)!=-1)
        cout << "Aircraft of this type do not"; else
    {
            cout << "\n";
            cout << "название пункта назначения  ";
            cout << aeroflot[poisk(aeroflot,n)].name; 
            cout << "\n";
            cout << "номер  ";
            cout <<aeroflot[poisk(aeroflot,n)].number;
            
    }
    
    
    
    getch();
    }}
нужно чтобы вводимая мною информация передавалась в функцию add е автоматически заполнялась в свободную ячейку. когда поставил на вывод в add увидел что выводит другие символы. подскажите может я не верно копирую или что не так .
Много ошибок. Функция add работает неправильно и вы делаете aeroflot[i].name[0]=='\0' но перед этим не инициализируете нулями. Сделайте в main AEROFLOT aeroflot[7] = {0};, второй параметр в add нет смысла передавать по значению.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
int add(AEROFLOT aeroflot[7],AEROFLOT f)
{
    int i;
    for (i = 0; i < 7 ;i++)
    {
        if (aeroflot[i].name[0] == '\0')
        {
            strcpy(aeroflot[i].name, f.name);
            aeroflot[i].number = f.number;
            strcpy(aeroflot[i].type, f.type);
            
            cout << aeroflot[i].name <<endl;
            cout << aeroflot[i].number <<endl;
            cout << aeroflot[i].type <<endl;
            
            return i;
        }
    }
    return -1;
}
Yandex
Объявления
26.09.2010, 21:42     не правильно копирует (
Ответ Создать тему
Опции темы

Текущее время: 09:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru