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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 47, средняя оценка - 4.79
МартинИ
 Аватар для МартинИ
0 / 0 / 0
Регистрация: 21.03.2009
Сообщений: 3
21.03.2009, 18:49     Найти порядковые номера двух соседних чисел, сумма которых максимальна. #1
7.79. Дана последовательность целых чисел Х1, Х2,..., Хn где n >= 3. Найти:
в) порядковые номера двух соседних чисел, сумма которых максимальна. Если таких пар чисел несколько, то найти номера чисел первой такой пары;

7.116. Даны 20 чисел, образующие неубывающую последовательность. Несколько чисел, идущие подряд, равны между собой. Найти количество таких чисел. Сколько различных чисел имеется в последовательности?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.03.2009, 18:49     Найти порядковые номера двух соседних чисел, сумма которых максимальна.
Посмотрите здесь:

C++ Среди чисел найти все, у которых сумма первых двух равна сумме последних двух
Вычислить сумму чисел, порядковые номера которых являются числами Фибоначчи. C++
Найти два соседних элемента массива, сумма которых максимальна C++
C++ Найти непрерывный участок из 10 элементов, сумма которых максимальна
C++ Определить порядковые номера первой пары одинаковых соседних символов
C++ Вычислить сумму чисел, порядковые номера которых являются простыми числами.
Найти порядковые номера двух соседних элементов массива, сумма которых максимальна C++
C++ Вычислить сумму чисел, порядковые номера которых являются числами Фибоначчи
Найти сумму элементов массива, порядковые номера которых - простые числа C++
C++ Вычислить сумму чисел последовательности, порядковые номера которых являются числами Фибоначчи
Найти два соседних элемента массива, сумма которых минимальна C++
C++ Найти в массиве три последовательных элемента, сумма которых максимальна

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
МартинИ
 Аватар для МартинИ
0 / 0 / 0
Регистрация: 21.03.2009
Сообщений: 3
23.03.2009, 18:52  [ТС]     Найти порядковые номера двух соседних чисел, сумма которых максимальна. #2
вот на задачу 7.79 написала код... так ошибку выдат... не могу поять в чем проблема =(((
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
#include<stdio.h>
#include<conio.h>
#include<math.h>
int x[10],n,i,p,s,a,b,max=100;
int main()
 
 
{
clrscr();
int x[10],n,i,p,s,a,b,max=100;
printf("/n Vvedit znachennya n: ");
scanf("/n %d",&n);
while(n<3){
puts("/n Chyslo n povyno buty >=3");
printf("/n Vvedit znachennya n: ");
scanf("/n %d",&n);}
printf("/n Vvedit 1 chyslo poslidovnosti: ");
scanf("/n %d",&p);
 
for(i=1;i<n;++){
printf("/n Vvedit nastupne chyslo x: ");
scanf("/n %d",&x[i]);
s=p+x[i];
p=x[i];if(s>max){
max=s;
a=i-1;b=i;} }
printf("/n Rezultat - 1 chyslo=%d, 2 chslo=%d",&a,&b);
printf("/n Ih suma: %d",&max);
}
arhiman
Сообщений: n/a
23.03.2009, 19:04     Найти порядковые номера двух соседних чисел, сумма которых максимальна. #3
Задача 7.79
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
#include <iostream>
int main()
{
  int n, maxsum;
  std::cin>>n;
  if ((n-1)<3)
    return 1;
  int X[n-1];
  for (int i=0; i<n; i++)
    std::cin>>X[i];
  maxsum=X[0]+X[1];
  for (int i=0; i<(n-1); i++)
  {
    if ((X[i]+X[i+1])>maxsum)
    maxsum=X[i]+X[i+1];
  }
  int k=0;
  while (maxsum !=(X[k]+X[k+1]))
  {
    k++;
  }
  std::cout<<k<<" "<<k+1;
  return 0;
}
МартинИ
 Аватар для МартинИ
0 / 0 / 0
Регистрация: 21.03.2009
Сообщений: 3
23.03.2009, 20:55  [ТС]     Найти порядковые номера двух соседних чисел, сумма которых максимальна. #4
Вот рабочий код на эту задачу:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
  #include<stdio.h> 
#include<conio.h>   
int main() { 
int x[100],n,i,max,k=0;   
do  {  
printf("Vvedite n (>3): ");  
scanf("%d",&n);  } 
while(n<3);   for(i=0;i<n;i++)  {   
printf("Vvedite chislo x[%d]: ",i);   
scanf("%d",&x[i]);
 if(i==1) 
   max = x[0]+x[1];   
 else if(i>1)    {     
if(x[i]+x[i-1]>max)      {       
k=i-1;       
max = x[i]+x[i-1];      
}    
}  
}
 printf("x[%d] = %d, x[%d] = %d,  
Summa = %d\n",k,x[k],k+1,x[k+1],max);   getch(); 
}
Задачи на рекурсию

10.44. Написать рекурсивную функцию нахождения цифрового корня данного числа. Цифровой корень данного числа получается следующим образом. Если сложить все цифры данного числа, затем все цифры найденной суммы и повторять этот процесс, то в результате будет получено однозначное число (цифра), которая и называется цифровым корнем данного числа.

10.53. Написать рекурсивную процедуру для ввода с клавиатуры последовательности чисел и вывода ее на экран в обратном порядке (окончание последовательности – при вводе нуля).
Yandex
Объявления
23.03.2009, 20:55     Найти порядковые номера двух соседних чисел, сумма которых максимальна.
Ответ Создать тему
Опции темы

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