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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.60
Ronflat
0 / 0 / 0
Регистрация: 29.04.2010
Сообщений: 37
#1

довести до ума курсовую - C++

29.04.2010, 17:04. Просмотров 1229. Ответов 23
Метки нет (Все метки)

задание:программное моделирование международной телефоной станции.
указание.на междунородной тел станции картотека абонентов содержащая сведения о телефонах и их владельцах.организованна как линейный список.
прога должна:1.обеспечивать начальное формирование картотеки в виде линейного списка2.производить вывод всей картотеки3.выводить номер телефона и время разговора.4.выводить извещение на оплату телефоного разговора
----------------------------и вот что я уже сделал---------------
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
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <stdlib.h>
#include <iostream>
using namespace std;
 
struct kart 
{
    char order[15]; 
    char* famil;
    char* imia;
    int nomer; 
    int vremia_razg; 
};
void ka1_all(kart *p, int n);
void ka1(kart pz);
int search(kart *p, int n, char *t, int i);
int main()
{
    int n, i;
    printf("\n Number of kart:");
    scanf("%d", &n);
    kart *ka=(kart*)malloc(n *sizeof(kart));
    for (i=0; i<n; i++)
    {
        printf("\n Input order:"); scanf("%s",&ka[i].order);
        printf("\n Input famil:"); scanf("%d",&ka[i].famil);
        printf("\n Input imia:"); scanf("%d",&ka[i].imia);
        printf("\n Input nomer:"); scanf("%d",&ka[i].nomer);
        printf("\n Input vremia_razg:"); scanf("%d",&ka[i].vremia_razg);
    }
    ka1_all(ka, n);
    printf("\n Input searching order:");
    char t[20];
    scanf("%s", t);
    for (int k=0; k<n; k++)
    {
        k=search(ka, n, t, k);
        if (k<n) ka1(ka[k]);
    }
}
void ka1_all(kart *p, int n)
{
    for(int i=0; i<n; i++)
    {
        printf("\n i=%d", i);
        printf("\n order is %s", p[i].order);
        printf("\n famil is %d", p[i].famil);
        printf("\n imia is %d", p[i].imia);
        printf("\n nomer is %d", p[i].nomer);
        printf("\n vremia_razg is %d", p[i].vremia_razg);
    }
}
void ka1(kart p)
{
    printf("\n order is %s", p.order);
        printf("\n famil is %d", p.famil);
        printf("\n imial is %d", p.imia);
        printf("\n nomer is %d\n", p.nomer);
        printf("\n vremia_razg is %d\n", p.vremia_razg);
}
int search(kart *p, int n, char *t, int i)
{
    int j=1;
    for(j=i; j<n; j++)
    {
        if(strcmp(p[j].order, t)==0)
            break;
    }
    return j;
}
-----------------
проблемма:не вводяца буквенные значения в familia и imia/и непойму как реализовать пункт 3 и4.
просьба исправить или сказать как нужно делать
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.04.2010, 17:04     довести до ума курсовую
Посмотрите здесь:

Помагите довести исходник до ума - C++
Здраствуйте дорогой форум! я новичек в этом деле , нашел исходник на c++ для игры warcraft maphack и не могу его откомпилировать ...

в чем ошибка,как довести до ума - C++
Дан массив чисел В. Найти сумму положительных и отрицательных чисел массива с нечетными индексами и количество элементов массива равных...

Не могу довести до ума, не хватает функции - C++
/* c помощью текстового редактора блокнот создать файл, содержащий текст, длина которого не превышает 1000 символов (длина строки...

Довести до ума программу про бинарному дереву - C++
Здравствуйте. Помогите пожалуйста привести до ума задачу: организовать бинарное дерево по заданной последовательности и функцию включения...

Не могу довести до ума..а хотя все эллиментарно...( - C++
Вычислить и вывести на экран в виде таблицы значения функции F на интервале от Xнач до Хкон с шагом dX. Формула -ax-c при...

Довести длину строки до заданной, вставляя пробелы между словами - C++
Довести длинну строки до заданной вставляя пробелы меду словами . Напечатать все слова которые совпадают с ее первым словом. Пожалуйста...

Производный класс сошел с ума! - C++
У базового класса у которого перегружена операция ++(префиксная) есть 2 производных: 1) перегружена префиксная операция -- 2)...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ronflat
0 / 0 / 0
Регистрация: 29.04.2010
Сообщений: 37
29.04.2010, 21:00  [ТС]     довести до ума курсовую #16
C++
1
2
3
4
5
6
7
8
9
10
int search(kart *p, int n, char *t, int i)
{
    int j=1;
    for(j=i; j<n; j++)
    {
        if(strcmp(p[j].order, t)==0)
            break;
    }
    return j;
}
Добавлено через 4 минуты
C++
1
2
3
4
5
6
7
8
9
10
int search(kart *p, int n, int number, int i)
{
    int j=1;
    for(j=i; j<n; j++)
    {
        if(p[j].nomer == number)
            break;
    }
    return j;
}
silent_1991
Эксперт С++
4960 / 3036 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
29.04.2010, 21:02     довести до ума курсовую #17
Ну да))) Первый вариант нужно переделать во второй)))
Ronflat
0 / 0 / 0
Регистрация: 29.04.2010
Сообщений: 37
29.04.2010, 21:27  [ТС]     довести до ума курсовую #18
ну эт я переделал.но к сожелению она ничего неищит все равно(((( без getch() она быстро исчезает и непонятно что делает. а с ней просто ничего непроисходит. т.е вводиш что найти. но она неищит .просто ждет еще одного нажатия и завершается.
Впринципе что б завтра показать что я чет сделал этого хватит))))Но все же,в чем там дело?

Добавлено через 18 минут
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
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <stdlib.h>
#include <iostream>
using namespace std;
 
struct kart 
{
    char order[15]; 
    char famil[15];
    char imia[15];
    int nomer; 
    int vremia_razg; 
};
void ka1_all(kart *p, int n);
void ka1(kart pz);
int search(kart *p, int n, int number, int i);
int main()
{
    int n, i;
    printf("\n Number of kart:");
    scanf("%d", &n);
    kart *ka=(kart*)malloc(n *sizeof(kart));
    for (i=0; i<n; i++)
    {
        printf("\n Input order:"); scanf("%s",&ka[i].order);
        printf("\n Input famil:"); scanf("%s",&ka[i].famil);
        printf("\n Input imia:"); scanf("%s",&ka[i].imia);
        printf("\n Input nomer:"); scanf("%d",&ka[i].nomer);
        printf("\n Input vremia_razg:"); scanf("%d",&ka[i].vremia_razg);
    }
    printf("\n Input searching order:");
int number;
scanf("%d", &number);
for (int k=0; k<n; k++)
{
k=search(ka, n, number, k);
if (k<n) ka1(ka[k]);
}
}
void ka1_all(kart *p, int n)
{
    for(int i=0; i<n; i++)
    {
        printf("\n i=%d", i);
        printf("\n order is %s", p[i].order);
        printf("\n famil is %s", p[i].famil);
        printf("\n imia is %s", p[i].imia);
        printf("\n nomer is %d", p[i].nomer);
        printf("\n vremia_razg is %d", p[i].vremia_razg);
    }
}
void ka1(kart p)
{
    printf("\n order is %s", p.order);
        printf("\n famil is %s", p.famil);
        printf("\n imial is %s", p.imia);
        printf("\n nomer is %d\n", p.nomer);
        printf("\n vremia_razg is %d\n", p.vremia_razg);
}
int search(kart *p, int n, int number, int i)
{
    int j=1;
    for(j=i; j<n; j++)
    {
        if(p[j].nomer == number)
            break;
    }
    
 return j;
}

последний листинг-неищит(
silent_1991
Эксперт С++
4960 / 3036 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
29.04.2010, 21:47     довести до ума курсовую #19
Не знаю, у меня всё ищет. Вот код на Си, который у меня работает корректно:
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
#include <stdio.h>
 
typedef struct
{
    char order[15]; 
    char famil[15];
    char imia[15];
    int nomer; 
    int vremia_razg; 
} kart;
 
void ka1_all(kart *p, int n);
void ka1(kart pz);
int search(kart *p, int n, int number, int i);
 
int main()
{
    kart *ka;
    int number;
    int n;
    int i;
    
    printf("\n Number of kart:");
    scanf("%d", &n);
    
    ka = (kart *)malloc(n * sizeof(kart));
    
    for (i = 0; i < n; i++)
    {
        printf("\n Input order:"); scanf("%s", ka[i].order);
        printf("\n Input famil:"); scanf("%s", ka[i].famil);
        printf("\n Input imia:"); scanf("%s", ka[i].imia);
        printf("\n Input nomer:"); scanf("%d", &ka[i].nomer);
        printf("\n Input vremia_razg:"); scanf("%d", &ka[i].vremia_razg);
    }
    
    printf("\n Input searching number:");
    scanf("%d", &number);
    
    for (i = 0; i < n; i++)
    {
        i = search(ka, n, number, i);
        
        if (i < n)
            ka1(ka[i]);
    }
    
    getch();
    return 0;
}
 
void ka1_all(kart *p, int n)
{
    int i;
    
    for (i = 0; i < n; i++)
    {
        printf("\n i=%d", i);
        printf("\n order is %s", p[i].order);
        printf("\n famil is %s", p[i].famil);
        printf("\n imia is %s", p[i].imia);
        printf("\n nomer is %d", p[i].nomer);
        printf("\n vremia_razg is %d", p[i].vremia_razg);
    }
}
 
void ka1(kart p)
{
    printf("\n order is %s", p.order);
    printf("\n famil is %s", p.famil);
    printf("\n imial is %s", p.imia);
    printf("\n nomer is %d\n", p.nomer);
    printf("\n vremia_razg is %d\n", p.vremia_razg);
}
 
int search(kart *p, int n, int number, int i)
{
    int j = 1;
    
    for(j = i; j < n; j++)
        if(p[j].nomer == number)
            break;
        
 return j;
}
Ronflat
0 / 0 / 0
Регистрация: 29.04.2010
Сообщений: 37
29.04.2010, 21:53  [ТС]     довести до ума курсовую #20
а вы бы немогли перевести его в C++ просто я в С вапше никак
silent_1991
Эксперт С++
4960 / 3036 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
29.04.2010, 21:55     довести до ума курсовую #21
Ну, внииимательно присмотревшись к своему и к моему коду, вы найдёте различия в 2-3 строчках... Их можете переделать обратно. Это по сути маленькие фишки языка Си++, добавленные для удобства, которых не было в Си. Я почти ничего не менял, по сути вы можете оставить всё как есть.
Ronflat
0 / 0 / 0
Регистрация: 29.04.2010
Сообщений: 37
29.04.2010, 22:06  [ТС]     довести до ума курсовую #22
Все спасибо нашел ошипку,моя была ошипка,спасибо вам ОГРОМНОЕ!
PointsEqual
ниначмуроФ
834 / 518 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
29.04.2010, 22:06     довести до ума курсовую #23
Ronflat,

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
#include <iostream>
#include <stdio.h>
#include <conio.h>
 
typedef struct
{
    char order[15];
    char famil[15];
    char imia[15];
    int nomer;
    int vremia_razg;
} kart;
 
void ka1_all(kart *p, int n);
void ka1(kart pz);
int search(kart *p, int n, int number, int i);
 
int main()
{
    kart *ka;
    int number;
    int n;
    int i;
 
    printf("\n Number of kart:");
    scanf("%d", &n);
 
    ka = (kart *)malloc(n * sizeof(kart));
 
    for (i = 0; i < n; i++)
    {
        printf("\n Input order:"); scanf("%s", ka[i].order);
        printf("\n Input famil:"); scanf("%s", ka[i].famil);
        printf("\n Input imia:"); scanf("%s", ka[i].imia);
        printf("\n Input nomer:"); scanf("%d", &ka[i].nomer);
        printf("\n Input vremia_razg:"); scanf("%d", &ka[i].vremia_razg);
    }
 
    printf("\n Input searching number:");
    scanf("%d", &number);
 
    for (i = 0; i < n; i++)
    {
        i = search(ka, n, number, i);
 
        if (i < n)
            ka1(ka[i]);
    }
 
    getch();
    return 0;
}
 
void ka1_all(kart *p, int n)
{
    int i;
 
    for (i = 0; i < n; i++)
    {
        printf("\n i=%d", i);
        printf("\n order is %s", p[i].order);
        printf("\n famil is %s", p[i].famil);
        printf("\n imia is %s", p[i].imia);
        printf("\n nomer is %d", p[i].nomer);
        printf("\n vremia_razg is %d", p[i].vremia_razg);
    }
}
 
void ka1(kart p)
{
    printf("\n order is %s", p.order);
    printf("\n famil is %s", p.famil);
    printf("\n imial is %s", p.imia);
    printf("\n nomer is %d\n", p.nomer);
    printf("\n vremia_razg is %d\n", p.vremia_razg);
}
 
int search(kart *p, int n, int number, int i)
{
    int j = 1;
 
    for(j = i; j < n; j++)
        if(p[j].nomer == number)
            break;
 
 return j;
}
а так
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.04.2010, 22:14     довести до ума курсовую
Еще ссылки по теме:

Доделать надо а ума не хватает - C++
/* 7. Имеется массив записей, расположенных по возрастанию некоторого ключевого поля. Одинаковых ключей нет. Построить из элементов...

Исправить курсовую на си++ - C++
Ребятки помогите исправить курсовую на си++. она полностью написана, но почему то не запускается, сдавать уже надо. в долгу не останусь.

Задали курсовую по С++ и Pascal ! - C++
Как разобраться ? И что надо сделать чтоб выполнить задание? 1. Виконати табуляцію параметрично заданої функції (декартів лист), записати...

В чем делать курсовую с графическим интерфейсом - C++
Нужно сделать курсовую, с графическим интерфейсом. Чтоб там было меню, различные кнопки перехода, картинки, тексты. Так как начал изучать...

Написать курсовую работу на тему: Основы компьютерной графики - C++
Помогите пожалуйста написать курсовую работу по Технологии программирования на тему: Основы компьютерной графики. Основные понятия....


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

Или воспользуйтесь поиском по форуму:
Ronflat
0 / 0 / 0
Регистрация: 29.04.2010
Сообщений: 37
29.04.2010, 22:14  [ТС]     довести до ума курсовую #24
все всем спасибо работает)
Yandex
Объявления
29.04.2010, 22:14     довести до ума курсовую
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru