Форум программистов, компьютерный форум, киберфорум
Наши страницы
C для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
Shell23
0 / 0 / 1
Регистрация: 03.01.2013
Сообщений: 19
1

Десятичные, двоичные и др. ичные формы ряда чисел. Компиляция failed

08.01.2013, 17:42. Просмотров 888. Ответов 5
Метки нет (Все метки)

Напишите программу, печатающую в файл таблицу, строки которой соответствуют десятичным числам от 1 до 25, а в столбцах эти числа выводятся в десятичной, двоичной, шестнадцатеричной и n-ичной системе (n = (номер варианта %15) + 10, такая система разрабатывается самостоятельно в подпрограмме). Столбцы выровнять по правому краю. Вариант №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
//---------------------------------------------------------------------------
#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>
#include <mem.h>
//---------------------------------------------------------------------------
// закоментировать следующие и проверить средством библ. функцией перевода
#define use_my_func
//---------------------------------------------------------------------------
void perevod(int nmbDec, char outBuf[], int outBase){
 static char tmpBuf[128]={0},*ptrBuf,over9='a';
 int tmpVal = 0;
 
 ptrBuf = tmpBuf;
 
 while(1) {
  tmpVal = nmbDec%outBase;
  *ptrBuf++ = tmpVal<=9 ? tmpVal+0x30 : (over9+(tmpVal-10));
  if((nmbDec/=outBase)==0)
   break;
 }
 
 while(--ptrBuf>=tmpBuf) *outBuf++=*ptrBuf;
 
 *outBuf = 0;
}
//---------------------------------------------------------------------------
int main(int argc, char* argv[])
{
 const int  VariantNumber = 9;
 const int  Nm            = VariantNumber%15 +10;
       int  Pos           = 0;
 
 FILE *F;
 char FileName[] = "task1.txt";
 
 char D  [25][10] = {0};
 char B  [25][10] = {0};
 char H  [25][10] = {0};
 char X  [25][10] = {0};
 char Rez[25][42] = {0};
 
 int i;
 for(i=0;i<25;i++) {
  #ifdef use_my_func
  perevod(i+1,D[i],10);
  perevod(i+1,B[i], 2);
  perevod(i+1,H[i],16);
  perevod(i+1,X[i],Nm);
  #else
   // itoa() - библиотечная функция преобразование в систему изчисления основанием от 2 до 36
  itoa(i+1,D[i],10);// DEC
  itoa(i+1,B[i], 2);// BIN
  itoa(i+1,H[i],16);// HEX
  itoa(i+1,X[i],Nm);// XXX
  #endif
 
  memset(Rez[i],' ',sizeof(Rez[i]));
 
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(D[i]);
  memcpy(&Rez[i][Pos],D[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(B[i]);
  memcpy(&Rez[i][10+Pos],B[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(H[i]);
  memcpy(&Rez[i][20+Pos],H[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(X[i]);
  memcpy(&Rez[i][30+Pos],X[i],Pos);
 
  int k;
  for(k=0;k<40;k++)
   if(Rez[i][k]==0)Rez[i][k]=' ';// если 0 - нет данных заполняем пробелами
 
  Rez[i][40]=0xD;// возврат каретки
  Rez[i][41]=0xA;// перевод строки
 }
 
 if((F=fopen(FileName,"w+b"))!=NULL) {
  fwrite(Rez,1,sizeof(Rez),F);
  fclose(F);
 }
 
 return 0;
}
//---------------------------------------------------------------------------
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.01.2013, 17:42
Ответы с готовыми решениями:

Двоичные и десятичные системы исчисления
Здравствуйте , нужен простой вариант функции bintodec. Заранее спасибо.

Перевести десятичные числа в двоичные с точностью до 10–8
Перевести десятичные числа в двоичные с точностью до 10–8. Для полученных двоичных чисел записать...

Преобразовать десятичные числа 121 и 17 в двоичные.
С помощью подпрограммы преобразовать десятичные числа 121 и 17 в двоичные.

Конвертируем двоичные числа в десятичные и наоборот
Здравствуйте Уважаемые форумчане! в одной книге по языку Си есть пример программы для...

С помощью подпрограммы преобразовать двоичные числа в десятичные
С помощью подпрограммы преобразовать двоичные числа 111100101 и 1011 в десятичные по возможности...

5
CVB
99 / 90 / 53
Регистрация: 22.03.2011
Сообщений: 226
09.01.2013, 11:21 2
76 строка, перенести оглавление на верх. и
Цитата Сообщение от Shell23 Посмотреть сообщение
int k;
и эта библиотека не компилировалась.
Цитата Сообщение от Shell23 Посмотреть сообщение
#include <mem.h>
В результат такой.

1. Программа вконце, когда записываешь в файл, и освобожаешь память, то аж тогда ошибка выкидает (на скрине видно)[85-86 строки], т.е. нету места в самом
C
1
char Rez[25][42] = {0};
, у вас же 42 на строку, а Массив заполняется по диагонали(на скрине видно), т.е. в первой строке у вас весь файл (все 25 строк одна за одной), во второй строке уже 24 строки, потом 23 строки, вы засоряли так массив, так что в 42 не влазит. Выйти из проблемы, это написать место 42, например 1000
C
1
 char Rez[25][1000] = {0};
2. Но в файл успевает записать результат(первый скрин).
1
Миниатюры
Десятичные, двоичные и др. ичные формы ряда чисел. Компиляция failed   Десятичные, двоичные и др. ичные формы ряда чисел. Компиляция failed  
Shell23
0 / 0 / 1
Регистрация: 03.01.2013
Сообщений: 19
13.01.2013, 17:24  [ТС] 3
Почему не работает программа?

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
#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>
 
 
int main(int argc, char* argv[])
 
{
 const int  VariantNumber = 9;
 const int  Nm            = VariantNumber%15 +10;
       int  Pos           = 0;
 
 FILE *F;
 char FileName[] = "task1.txt";
 
 char D  [25][10] = {0};
 char B  [25][10] = {0};
 char H  [25][10] = {0};
 char X  [25][10] = {0};
 char Rez[25][1000] = {0};
 
 int i;
 for(i=0;i<25;i++) 
 {
  #ifdef use_my_func
  perevod(i+1,D[i],10);
  perevod(i+1,B[i], 2);
  perevod(i+1,H[i],16);
  perevod(i+1,X[i],Nm);
  #else
   // itoa() - библиотечная функция преобразование в систему изчисления основанием от 2 до 36
  itoa(i+1,D[i],10);// DEC
  itoa(i+1,B[i], 2);// BIN
  itoa(i+1,H[i],16);// HEX
  itoa(i+1,X[i],Nm);// XXX
  #endif
 
  memset(Rez[i],' ',sizeof(Rez[i]));
 
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(D[i]);
  memcpy(&Rez[i][Pos],D[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(B[i]);
  memcpy(&Rez[i][10+Pos],B[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(H[i]);
  memcpy(&Rez[i][20+Pos],H[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(X[i]);
  memcpy(&Rez[i][30+Pos],X[i],Pos);
 
  int k;
  for(k=0;k<40;k++)
   if(Rez[i][k]==0)Rez[i][k]=' ';// если 0 - нет данных заполняем пробелами
 
  Rez[i][40]=0xD;// возврат каретки
  Rez[i][41]=0xA;// перевод строки
 }
 
 if((F=fopen(FileName,"w+b"))!=NULL) 
 {
  fwrite(Rez,1,sizeof(Rez),F);
  fclose(F);
 }
 
 return 0;
}
0
CVB
99 / 90 / 53
Регистрация: 22.03.2011
Сообщений: 226
14.01.2013, 01:09 4
В 55 строке это переместить на самый верх. и Все =) запускается.
Цитата Сообщение от Shell23 Посмотреть сообщение
C
1
int k;
0
Shell23
0 / 0 / 1
Регистрация: 03.01.2013
Сообщений: 19
14.01.2013, 02:29  [ТС] 5
Переместил, не работает. Про таблицу, это я написал)) 56-60 строки же не наместе тогда.

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
#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>
 
int k;
int main(int argc, char* argv[])
 
{
 const int  VariantNumber = 9;
 const int  Nm            = VariantNumber%15 +10;
       int  Pos           = 0;
 
 FILE *F;
 char FileName[] = "task1.txt";
 
 char D  [25][10] = {0};
 char B  [25][10] = {0};
 char H  [25][10] = {0};
 char X  [25][10] = {0};
 char Rez[25][1000] = {0};
 
 int i;
 for(i=0;i<25;i++) 
 {
  #ifdef use_my_func
  perevod(i+1,D[i],10);
  perevod(i+1,B[i], 2);
  perevod(i+1,H[i],16);
  perevod(i+1,X[i],Nm);
  #else
   // itoa() - библиотечная функция преобразование в систему изчисления основанием от 2 до 36
  itoa(i+1,D[i],10);// DEC
  itoa(i+1,B[i], 2);// BIN
  itoa(i+1,H[i],16);// HEX
  itoa(i+1,X[i],Nm);// XXX
  #endif
 
  memset(Rez[i],' ',sizeof(Rez[i]));
 
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(D[i]);
  memcpy(&Rez[i][Pos],D[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(B[i]);
  memcpy(&Rez[i][10+Pos],B[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(H[i]);
  memcpy(&Rez[i][20+Pos],H[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(X[i]);
  memcpy(&Rez[i][30+Pos],X[i],Pos);
 
  
  for(k=0;k<40;k++)
   if(Rez[i][k]==0)Rez[i][k]=' ';// если 0 - нет данных заполняем пробелами
 
  Rez[i][40]=0xD;// возврат каретки
  Rez[i][41]=0xA;// перевод строки
 }
 
 if((F=fopen(FileName,"w+b"))!=NULL) 
 {
  fwrite(Rez,1,sizeof(Rez),F);
  fclose(F);
 }
 
 return 0;
}
0
Миниатюры
Десятичные, двоичные и др. ичные формы ряда чисел. Компиляция failed  
CVB
99 / 90 / 53
Регистрация: 22.03.2011
Сообщений: 226
14.01.2013, 11:28 6
Цитата Сообщение от Shell23 Посмотреть сообщение
56-60 строки
Они заполняют таблицу, но но выводят её. А чтоб выводить значит нужно ещё код. Я дописал и выводит. Но и записывает после вывода в файл. Если не нужно в файл то удалите строки после puts(Rez[i]);

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
#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>
 
 
int main(int argc, char* argv[])
 
{
    
  int k;//на самый врх его
 const int  VariantNumber = 9;
 const int  Nm            = VariantNumber%15 +10;
       int  Pos           = 0;
 
 FILE *F;
 char FileName[] = "task1.txt";
 
 char D  [25][10] = {0};
 char B  [25][10] = {0};
 char H  [25][10] = {0};
 char X  [25][10] = {0};
 char Rez[25][1000] = {0};
 
 int i;
 for(i=0;i<25;i++) 
 {
  #ifdef use_my_func
  perevod(i+1,D[i],10);
  perevod(i+1,B[i], 2);
  perevod(i+1,H[i],16);
  perevod(i+1,X[i],Nm);
  #else
   // itoa() - библиотечная функция преобразование в систему изчисления основанием от 2 до 36
  itoa(i+1,D[i],10);// DEC
  itoa(i+1,B[i], 2);// BIN
  itoa(i+1,H[i],16);// HEX
  itoa(i+1,X[i],Nm);// XXX
  #endif
 
  memset(Rez[i],' ',sizeof(Rez[i]));
 
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(D[i]);
  memcpy(&Rez[i][Pos],D[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(B[i]);
  memcpy(&Rez[i][10+Pos],B[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(H[i]);
  memcpy(&Rez[i][20+Pos],H[i],Pos);
  // Вычисляем позицию для записи в массив(выравниваем по правому краю)
  Pos=10 - strlen(X[i]);
  memcpy(&Rez[i][30+Pos],X[i],Pos);
 
  for(k=0;k<40;k++)//это в матрице делает отступы. Но не выводит её
   if(Rez[i][k]==0)Rez[i][k]=' ';// если 0 - нет данных заполняем пробелами
 
  Rez[i][40]=0xD;// возврат каретки
  Rez[i][41]=0xA;// перевод строки
 }
 
 for(i=0;i<25;i++)//вот это выводит.
     puts(Rez[i]);
 
 if((F=fopen(FileName,"w+b"))!=NULL) //Это записывает в файл. Но не выводит на консоль. Так что небыло кода для вывода на консоль
 {
  fwrite(Rez,1,sizeof(Rez),F);
  fclose(F);
 }
 
 return 0;
}
1
Миниатюры
Десятичные, двоичные и др. ичные формы ряда чисел. Компиляция failed  
14.01.2013, 11:28
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.01.2013, 11:28

С помощью подпрограммы преобразовать двоичные числа 111100101 и 1011 в десятичные
Помогите пожалуйста с задачкой.Дано задание: С помощью подпрограммы преобразовать двоичные числа...

Программа, которая выводит на экран символы и их десятичные и двоичные коды в соответствии с кодовой таблицей
Программа, которая выводит на экран символы и их десятичные и двоичные коды в соответствии с...

Перевод римских чисел в десятичные
Напишите программу перевода римских чисел в десятичные. Алгоритм перевода представлен в следующей...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

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