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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 22, средняя оценка - 4.64
medVet
0 / 0 / 0
Регистрация: 24.01.2010
Сообщений: 9
#1

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

24.01.2010, 12:04. Просмотров 2694. Ответов 20
Метки нет (Все метки)

Нужно написать функцию, которая позволяет сложить ( + ) два целых положительных числа, без ограничения на величину чисел.

Завтра нужно сдать, а то недопуск на экзамен, я набрасал прогу, вроде выводит результат, но что-то мне ,кажеться, я там нахомутал....
В общем нужно ваша помощь, гляньте что не так? (
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++):

Написать программу которая выводит сумму чисел от a до b. Сложение чисел выполнять в процедуре - C++
Где ошибка? #include &lt;iostream&gt; #include &lt;iomanip&gt; #include &lt;cmath&gt; using namespace std; int Sum (int x, int y) { int S; ...

Вычислить сумму двух длинных бинарных чисел, используя сложение чисел в двоичной системе счисления - C++
Задано положительное и отрицательное число в двоичной системе.Составить программу вычисления суммы этих чисел, используя сложения чисел в...

после завтра екзамен! - C++
и так условие трёх задач 1)найти мин и макс элементы массива А и расположить элементы между ними по убыванию; 2)найти суму А левой...

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

сложение чисел - C++
Доброго времени суток! вопрос вроде простой но я не могу понять объясните как сложить числа вот код программы if (x==a) { i = 4;...

Сложение чисел - C++
Добрый вечер! Помогите пожалуйста новичку. Есть файл mas.txt, необходимо сложить все числа и вывести на консоль:wall: Числа записаны...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
medVet
0 / 0 / 0
Регистрация: 24.01.2010
Сообщений: 9
24.01.2010, 18:33  [ТС] #16
Genius Ignat, то что я напрограмил вроде работает, но после нескольких использований перестает верно считать, спасает перезапуск среды Борланд. непойму в чем трабл.
Мне по заданию нужно создать функцию, которой бы передавалось два масива чисел типа char а она возвращала суму елементов первого и второго.
valeriikozlov
Эксперт C++
4669 / 2495 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
24.01.2010, 20:33 #17
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]; 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;
}
Вот так попробуйте.
Цитата Сообщение от medVet Посмотреть сообщение
два целых положительных числа, без ограничения на величину чисел.
Ограничения все равно есть.
medVet
0 / 0 / 0
Регистрация: 24.01.2010
Сообщений: 9
25.01.2010, 03:36  [ТС] #18
valeriikozlov, неправильно считает.

Добавлено через 6 часов 30 минут
почти написал: но опять трабл. Функция slogenie возвращает масив g со значением сумы двух чисел, но при задействования к ней функции подсчета елементом strlen - она выдает количество символов до первого встречающегося нуля, например: число в масиве g =102324 strlen выдаст 1 ,вопрос как сделать что-бы выдало 6 (т.е действительное количество)?
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 <conio.h>
#include <iostream.h>
#include <stdlib.h>
#include <string.h>
 
char* slogenie(char *a, char *b, char *f);
 
void main()
{char s[100],d[100],g[100];
clrscr();
cin>>s>>d;
slogenie(s,d,g);  cout<<"\n";
int k;
k=strlen(g); cout<<" k= "<<k<<"  ";     вот сдесь 
for(int i=0;i<10;i++)
cout<<g[i]+0;
getch();
 
  }
 char* slogenie(char *a,char *b,char *f)
 
{
char perevorot(char *x);
char Temp[100], *as, *bn; int x,c,v,len1,len2,k,i,one=0,pos=0;
len1=strlen(a); len2=strlen(b); if (len1>len2) k=len1; else k=len2;
perevorot(a);
perevorot(b);
for(i=0;i<=k;i++)
{
x=(a[i]-48); c=(b[i]-48);  if(a[i]==0) x=0; if(b[i]==0) c=0;
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; }
}
i=k; pos=0;
while (i>=0)
{
Temp[pos]=f[i];
pos++;i--;
}
for(i=0;i<=k;i++)
f[i]=Temp[i];// f[k+1]='\0';
for(i=0;i<=k;i++)
cout<<(f[i]+0);
 
return f;
}
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;
}
CyBOSSeR
Эксперт C++
2300 / 1670 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
25.01.2010, 04:36 #19
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
#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';
 
  return sum;
}
int main()
{
  char first[]  = "234";
  char second[] = "81";
 
  char* sum = Sum(first, second);
 
  std::cout << sum << std::endl;
 
  delete [] sum;
 
  return 0;
}
Единственный недочет - при необходимости добавляет символ 0 в начало результата - как в примере.
В коде присутствуют излишние переменные (которые, поколдовав, можно убрать), оставленные для наглядности.
Результат: http://codepad.org/B9VBRd9x
Надеюсь не слишком поздно написал.
valeriikozlov
Эксперт C++
4669 / 2495 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
25.01.2010, 06:11 #20
Цитата Сообщение от medVet Посмотреть сообщение
Функция slogenie возвращает масив g со значением сумы двух чисел, но при задействования к ней функции подсчета елементом strlen - она выдает количество символов до первого встречающегося нуля, например: число в масиве g =102324 strlen выдаст 1 ,вопрос как сделать что-бы выдало 6 (т.е действительное количество)?
Проблемма решаема:
Цитата Сообщение от medVet Посмотреть сообщение
{char s[100],d[100],g[100];
clrscr();
for(int i=0; i<100; i++)// до начала использования масссива g[] заполняем его каким-нибудь символом, например 's'
g[i]='s';
cin>>s>>d;
slogenie(s,d,g); cout<<"\n";
int k;
// а здесь теперь подсчет
k=0;
while(g[k]!='s')
k++;
// теперь в k должно быть полное кол-во символов-цифр
//k=strlen(g); cout<<" k= "<<k<<" "; вот сдесь
for(int i=0;i<10;i++)
CyBOSSeR
Эксперт C++
2300 / 1670 / 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;
}
Протестируй все тщательно.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.01.2010, 08:37
Привет! Вот еще темы с ответами:

Сложение двух чисел - C++
Написать программу сложения двух чисел на Visual c++. Вот мой код. #include &quot;stdafx.h&quot; #include &lt;stdio.h&gt; #include &lt;conio.h&gt; ...

Сложение двух чисел - C++
Сложение двух чисел. Как, если оба числа в диапазоне от 0 до 2*10^9 ? Если складывать 2*10^9 + 2*10^9 то long int не справляется((

Сложение двоичных чисел - C++
Ввести два действительных двоичных числа, представленных как символьные строки, и найти их сумму. Помогите, может кто сталкивался с...

Сложение short чисел - C++
Посчитайте сумму чисел 17233 и 21413, при условии что вы работаете со знаковыми 16 битными числами, представленными дополнением до 2. ...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
25.01.2010, 08:37
Ответ Создать тему
Опции темы

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