Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > IT форум > Помощь студентам
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 09.09.2013, 18:29   #1
fkty
Форумчанин
 
Регистрация: 22.05.2013
Сообщений: 245
По умолчанию найти сумму произведений списка

Дан список из n целых неотрицательных чисел a1,a2,...an.Найти:a1*a2+a2*a3+...+a n-1*an.
Только начали изучать С++ и не получается переделать программу с Паскаля на С++.
Код:
Uses Crt;
Type
  PList = ^TList;
  TList = record
    info : integer;
    next : PList;
  end;

Var
  Head: PList;
  s,n,i:integer;
{процедура создает список}
Procedure MakeList(var Head:PList;n:integer);

Var
k,i:integer;
q,p:Plist;


Begin {MakeList}
    randomize;
    new(Head);
    head^.next:=nil;
    p:=head;
     for i:=1 to n do
     begin
      new(q);
      q^.info:= random(10);
      q^.next:=nil;
      p^.next:=q;
      p:=q;
  end;
end;{MakeList}

Procedure PrintList(Head:Plist); {процедура выводит список на экран*}
Var
  p:Plist;

Begin {PrintList}
  p:=head^.next;
  while p<>nil do
  begin
    write(p^.info:4);
    p:=p^.next;
  end;
  writeln;
end;{PrintList}

{процедура находит сумму }
Procedure SumList(head:Plist; var s:integer);
Var
  a,b:integer;
  q,p:Plist;

 Begin {SumList}
  s:=0;b:=1; a:=1;
  p:=head^.next;
  b:=p^.info;
  p:=p^.next;
  while p<>nil do
  begin
    a:=p^.info;
    s:=s+(a*b);
    b:=a;
    p:=p^.next;
  end;
  write('сумма равна* s= ');
  write(s);
 end;{ SumList }


Begin {program}
ClrScr;
  write('введите количество элементов');
  writeln;
  readln(n);
  MakeList(Head,n);
  writeln('исходный список');
  PrintList(head);
  SumList(head,s);
  readkey;
end.{program}
fkty вне форума Ответить с цитированием
Старый 10.09.2013, 14:00   #2
was3110
Форумчанин
 
Аватар для was3110
 
Регистрация: 25.04.2010
Сообщений: 254
По умолчанию

бесплатно это делать скучно. Учиться тут нечему.
помогать студентам - моя вторая профессия
was3110 вне форума Ответить с цитированием
Старый 10.09.2013, 14:48   #3
Stilet
Белик Виталий :)
Старожил
 
Аватар для Stilet
 
Регистрация: 23.07.2007
Сообщений: 57,097
По умолчанию

Могу предложить за основу это: http://www.programmersforum.ru/showp...8&postcount=25
I'm learning to live...
Stilet вне форума Ответить с цитированием
Старый 10.09.2013, 14:51   #4
GreenWizard
мальчик-помогай =)
Форумчанин
 
Регистрация: 16.09.2010
Сообщений: 522
По умолчанию

давно не программировал (лето же было), вот что вышло:
Код:
#pragma hdrstop
#pragma argsused
//---------------------------------------------------------------------------
#include <iostream>
#include "conio.h"
#include "math.h"
#include "stdlib.h"
//---------------------------------------------------------------------------

struct TList {
  int Info;
  TList *Next;
};
typedef TList *PList;
//---------------------------------------------------------------------------

PList NewListNode(){
  PList Result = new TList;
  Result->Info = 0;
  Result->Next = NULL;
  return Result;
}

void MakeList(PList *Head, int n){
  if(n > 0){
    randomize();
    *Head = NewListNode();
    (*Head)->Info = rand() % 10;

    PList A, B;
    A = *Head;
    while(n > 1){
      n--;
      B = NewListNode();
      B->Info = rand() % 10;
      A->Next = B;
      A = B;
    }
  }
}

void PrintList(PList List){
  std::cout << "List: ";
  while(List != NULL){
    std::cout << List->Info << " ";
    List = List->Next;
  }
  std::cout << "\n";
}

int SumList(PList List){
  int n = 0;
  while(List != NULL){
    n += List->Info;
    List = List->Next;
  }
  return n;
}

void FreeList(PList *List){
  PList Head = *List;
  while(Head != NULL){
    PList Tmp = Head->Next;
    delete Head;
    Head = Tmp;
  }
  *List = NULL;
}

int main(int argc, char* argv[])
{
  PList List;
  int n;
  std::cout <<  "n = ";
  std::cin >> n;
  MakeList(&List, n);
  PrintList(List);
  std::cout <<  "Sum = " << SumList(List) << "\n";
  getch();
  FreeList(&List);
  return 0;
}
//---------------------------------------------------------------------------
пробуй) могут быть проблемы с инклюдями и директивами, но это уже смотря какая у тебя версия сиплюшек
кстати, в коде на Паскале была пара ошибок... исправил их и добавил новые =) шутка, надеюсь))

Последний раз редактировалось GreenWizard; 10.09.2013 в 14:59.
GreenWizard вне форума Ответить с цитированием
Старый 10.09.2013, 16:58   #5
fkty
Форумчанин
 
Регистрация: 22.05.2013
Сообщений: 245
По умолчанию

спасибо,пишет что randomize не найден,это надо какую то библиотеку подключать?
fkty вне форума Ответить с цитированием
Старый 10.09.2013, 17:17   #6
GreenWizard
мальчик-помогай =)
Форумчанин
 
Регистрация: 16.09.2010
Сообщений: 522
По умолчанию

да, попробуй вызвать справку и глянуть где эта ф-ия описана
GreenWizard вне форума Ответить с цитированием
Старый 10.09.2013, 18:18   #7
fkty
Форумчанин
 
Регистрация: 22.05.2013
Сообщений: 245
По умолчанию

добавила библиотеки и у брала строчку с randomize(ее как я поняла вообще не надо),но программа всегда выводит одни и те же числа и считает сумму не правильно
fkty вне форума Ответить с цитированием
Старый 10.09.2013, 18:24   #8
BDA
МегаМодератор
СуперМодератор
 
Аватар для BDA
 
Регистрация: 09.11.2010
Сообщений: 7,289
По умолчанию

Вместо randomize() напишите srand(time(NULL)) (без этого всегда будут одинаковые числа) и подключите time.h.
Пишите язык программирования - это форум программистов, а не экстрасенсов. (<= это подпись )
BDA вне форума Ответить с цитированием
Старый 10.09.2013, 18:32   #9
fkty
Форумчанин
 
Регистрация: 22.05.2013
Сообщений: 245
По умолчанию

спасибо,а как переделать накопление суммы?здесь считается a1+a2+...+an,а надо a1*a2+a2*a3+...+a n-1*an.
fkty вне форума Ответить с цитированием
Старый 10.09.2013, 19:53   #10
BDA
МегаМодератор
СуперМодератор
 
Аватар для BDA
 
Регистрация: 09.11.2010
Сообщений: 7,289
По умолчанию

Попробуйте так:
Код:
int SumList(PList List){
    int s = 0, a = 0;
    while(List != NULL) {
        s += a * List->Info;
        a = List->Info;
        List = List->Next;
    }
    return s;
}
Пишите язык программирования - это форум программистов, а не экстрасенсов. (<= это подпись )
BDA вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Найти сумму irina.yurl Паскаль, Turbo Pascal, PascalABC.NET 2 25.02.2013 23:12
Три задачи - Найти сумму натуральных чисел; Протабулировать функцию; вычислить сумму kolya1114 Паскаль, Turbo Pascal, PascalABC.NET 3 01.12.2012 19:01
Pascal. Найти сумму отрицательных и сумму положительных элементов линейного массива. badname47 Паскаль, Turbo Pascal, PascalABC.NET 1 07.02.2012 06:29
Pascal в последовательность произведений найти первое произведение, не превосходящее по величине В IIyX Помощь студентам 5 15.03.2011 12:41
Массив! Найти сумму произведений цифр perojenko Помощь студентам 3 22.06.2009 11:48