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

Обмен двух элементов в спике - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Нужно перевести код с паскаля в С++ http://www.cyberforum.ru/cpp-beginners/thread902479.html
1)Дан текст, имеющий вид: “d1- d2+d3 - … ”, где di – цифры (n>1). Вычислить записанную в тексте алгебраическую сумму. 2)Дан текст, имеющий вид: “d1+- d2+- …+- dn”, где di – цифры (n>1). Вычислить записанную в тексте алгебраическую сумму. Ребят нужно срочно решить на С++ , вот код на паскале. 1) uses crt; var s:string; sum,d,i,e,sign:integer; begin
C++ Квадратная матрица, переставить строки местами Задана вещественная квадратная матрица(вводится с клавиатуры). Переставить строку с максимальным элементом на главной диагонали со строкой с заданным номером m (вводится с клавиатуры) Спасибо. http://www.cyberforum.ru/cpp-beginners/thread902444.html
C++ Создать список слов из файла и подсчитать количество повторения этих слов
Здравствуйте. Помогите написать такую программу: в файле храниться текст. Нужно составить список слов из этого текста и посчитать частоту его повторения в тексте ({1поле: само слово} {2поле: кол-во повторений этого слова}). Результат записать в файл. Заранее огромное спасибо!
массив строк с++ C++
есть массив строк char array={ "tom","15", "bob","20", "bill","25" }; Дальше я делаю выборку по возрасту if(atoi(array)>x) cout... (с этим проблем нет) как добавить в массив еще и фамилию? Нужно, по хорошему, делать структуру, но можно наверное как-то массивом обойтись?
C++ Объяаление #ifndef STRING_H_ http://www.cyberforum.ru/cpp-beginners/thread902424.html
Вот мы объявляем #include <iostream> #ifndef STRING_H_ #define STRING_H_ Уже не редко встречаю такое включение string.h Просто хотел бы уточнить.Я так понимаю с++ компилятор сам преобразует string.h в define STRING_H_ Заранее спасибо.
C++ pflfxf/VISUAL с++ Найти произведение матриц ЗАДАЧА. Найти произведение матриц A(m,n) и B(n,k). Таблица спецификаций № Идентификатор переменной или функции Назначение в программе Тип 1 A(i, j) Исходный массив-1 Вещественный 2 B(i, j) Исходный массив-2 Вещественный 3 C(i, j) ... подробнее

Показать сообщение отдельно
LifeWind
 Аватар для LifeWind
4 / 4 / 1
Регистрация: 13.09.2012
Сообщений: 36
15.06.2013, 14:08     Обмен двух элементов в спике
Здравствуйте, вот задача: дан список из n элементов a1, a2, .. an. Поменять местами первый из минимальных и последний из положительных элементов списка. Вопрос вот в чем: как поменять эти элементы в списке? Пробовал, не получается, если только обменять их данные, но это не подходит по заданию, так как нужно обменять сами элементы. Напишите пожалуйста правильно.
Вот код:
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
#include <iostream>
#include <iomanip>
using namespace std;
 
struct list
{
int info;
list *next, *pred;
};
 
//makelist формирует двухсвязный список с двумя сторожами
void makelist(list *&head, list *&tail)
{
head=new list;
tail=new list;
head->next=tail;
tail->pred=head;
int k,n;
cout<<"Введите количество элементов: "<<endl;
cin>>n;
cout<<"Вводите числа: "<<endl;
for(int i=0;i<n;i++)
{
    cin>>k;
    list*p=new list;
    p->info=k;
    p->next=tail;
    p->pred=tail->pred;
    tail->pred=p;
    p->pred->next=p;
}
return;
}
 
void printlist(list *head, list *tail) //вывод списка на экран
{
list *a=head;
while(a!=tail->pred)
{
cout<<a->next->info<<" ";
a=a->next;
}
cout << endl;
return;
}
 
void min(list *head, list *tail)//находит первый минимальный и последний положительный и меняет местами
{
    list *a=head->next;
    list *b=tail->pred;
    list *m, *p, *t;
    p=a;
    m=a;
    while(a!=tail)
    {
        if(a->info < m->info)
        m=a;
        if(a->info > 0)   
        p=a;
        a=a->next;
    }
    cout << m->info << endl << p->info <<endl;
    t=new list;  
    t->info=m->info;//вот здесь я просто меняю местами их info, а нужно поменять сами элементы местами
    m->info=p->info;
    p->info=t->info;
 
    return;
}
 
void main()
{  
    setlocale(LC_ALL, "Russian" );
    list * head, * tail;
    makelist(head,tail);
    printlist(head,tail);
    cout << endl;
    min(head,tail);
    printlist(head,tail);
    return;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 10:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru