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

Сложение чисел ! недопуск на екзамен ! - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 22, средняя оценка - 4.64
medVet
0 / 0 / 0
Регистрация: 24.01.2010
Сообщений: 9
24.01.2010, 12:04     Сложение чисел ! недопуск на екзамен ! #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
#include <conio.h>
#include <iostream.h>
#include <stdlib.h>
#include <string.h>
char perevorot(char *x);
void main()
{  clrscr();
char a[100], b[100], Temp[100], f[100], *as, *bn; int x,c,v,len1,len2,k,i,one=0,pos=0;
cin>>a>>b;
 len1=strlen(a); len2=strlen(b); if (len1>len2) k=len1; else k=len2;
perevorot(a);
perevorot(b);
for(i=0;i<=k;i++)
{
*bn=b[i]; *as=a[i];
x=atoi(as); c=atoi(bn);
v=x+c+one;
if(i==k && v==0) k=k-1;
if(v>9) {one=1;v=v-10; f[i]=v; } else {f[i]=v; one=0; }
}
//perevorot(f);
i=k; pos=0;
while (i>=0)
{
Temp[pos]=f[i];
pos++;i--;
}
for(i=0;i<=k;i++)
f[i]=Temp[i];
for(i=0;i<=k;i++)
 cout<<(f[i]+0);
getch(); return;
}
char perevorot(char* x)
 {
char Temp[100], *as; int k, i,pos=0;
k=strlen(x);
i=k-1;
while (i>=0)
{
Temp[pos]=x[i];
pos++; i--;
}
for(i=0;i<k;i++)
x[i]=Temp[i];
return *x;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.01.2010, 12:04     Сложение чисел ! недопуск на екзамен !
Посмотрите здесь:

C++ Сложение двух чисел
Сложение больших чисел C++
сложение двух чисел в С C++
после завтра екзамен! C++
Сложение чисел C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.01.2010, 08:37     Сложение чисел ! недопуск на екзамен !
Еще ссылки по теме:

Сложение больших чисел C++
сложение чисел C++
C++ Написать программу которая выводит сумму чисел от a до b. Сложение чисел выполнять в процедуре

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

Или воспользуйтесь поиском по форуму:
CyBOSSeR
Эксперт C++
 Аватар для CyBOSSeR
2294 / 1664 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
25.01.2010, 08:37     Сложение чисел ! недопуск на екзамен ! #21
medVet, вариант с исправленным недочетом вывода на экран:
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
#include <iostream>
#include <assert.h>
 
char* Sum(const char* first, const char* second)
{
  assert(first );
  assert(second);
 
  int first_len  = static_cast<int>(strlen(first ));
  int second_len = static_cast<int>(strlen(second));
  int sum_len    = (first_len > second_len ? first_len : second_len) + 1;
 
  char* sum = new char[sum_len + 1];
 
  sum[sum_len] = '\0';
 
  int first_index  = first_len  - 1;
  int second_index = second_len - 1;
  int sum_index    = sum_len    - 1;
 
  int rest = 0;
 
  while(first_index >= 0 && second_index >= 0){
    int tmp = (first[first_index] - static_cast<int>('0')) + 
      (second[second_index] - static_cast<int>('0')) + rest;
 
    sum[sum_index] = static_cast<char>(tmp % 10) + '0';
 
    rest = tmp / 10;
 
    --first_index;
    --second_index;
    --sum_index;
  }
 
  while(first_index >= 0){
    int tmp = first[first_index] - static_cast<int>('0') + rest;
 
    sum[sum_index] = static_cast<char>(tmp % 10) + '0';
 
    rest = tmp / 10;
 
    --first_index;
    --sum_index;
  }
 
  while(second_index >= 0){
    int tmp = second[second_index] - static_cast<int>('0') + rest;
 
    sum[sum_index] = static_cast<char>(tmp % 10) + '0';
 
    rest = tmp / 10;
 
    --second_index;
    --sum_index;
  }
 
  sum[sum_index] = static_cast<char>(rest) + '0';
 
  // Избавление от лишних нулей
  int first_non_zero_index = -1;
 
  for(int i = 0; i < sum_len; ++i)
    if(sum[i] != '0'){
      first_non_zero_index = i;
      break;
    }
 
  if(first_non_zero_index == 0)
    return sum;
 
  if(first_non_zero_index == - 1){
    delete [] sum;
 
    char* result = new char[2];
 
    result[0] = '0';
    result[1] = '\0';
 
    return result;
  }
 
  int result_len = sum_len - first_non_zero_index;
 
  char* result = new char[result_len + 1];
 
  for(int i = 0; i < result_len; ++i)
    result[i] = sum[i + first_non_zero_index];
 
  result[result_len] = '\0';
 
  delete [] sum;
 
  return result;
}
 
int main()
{
  char first[]  = "234";
  char second[] = "81";
 
  char* sum = Sum(first, second);
 
  std::cout << sum << std::endl;
 
  delete [] sum;
 
  return 0;
}
Протестируй все тщательно.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Yandex
Объявления
25.01.2010, 08:37     Сложение чисел ! недопуск на екзамен !
Ответ Создать тему
Опции темы

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