Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 4.88/2010: Рейтинг темы: голосов - 2010, средняя оценка - 4.88
В астрале
Эксперт С++
8022 / 4779 / 654
Регистрация: 24.06.2010
Сообщений: 10,550
1

Задачи для тренировки и лучшего понимания

15.07.2010, 05:53. Просмотров 407183. Ответов 1272
Метки нет (Все метки)

Ребят. Кто-нибудь может дать задачу для тренировки? Приблизительно по всему курсу С++. Буду благодарен за сложную задачу, но которую способен сделать новичок-любитель. Затраты сил-времени не важно. Главное, чтобы это было интересно и не слишком рутинно. + Если найдется человек который даст задачу просьба помогать с кодом, который я буду себя скидывать. Не переписывать за меня, но указывать на ошибки и желательно объяснять. Заранее спасибо.

Список задач, решение которых присутствует в данной теме:
43
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
15.07.2010, 05:53
Ответы с готовыми решениями:

Элементарные программы, для лучшего понимания языка...
Здравствуйте. Вот сегодня решил что пора изучать с++. Есть пару задач. Начал решать и уже на первой...

Задачи для тренировки и лучшего понимания языка
Предлагаю в этой теме размещать задачи, которые помогут новичкам (и не только) более детально...

Литература для лучшего понимания сути программирования
Привет! Подскажите литературу, которая поможет разобраться в сути самого процесса программирования,...

Набор задачь для тренировки и улучшения понимания программирования
Добрый вечер всем. Если кто знает модскажите где можно найти подобный набор задачь...

1272
Эксперт С++
3210 / 1459 / 73
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
29.07.2010, 14:09 281
Цитата Сообщение от nikkka Посмотреть сообщение
а чё нить по проще нельзя
можно. но не интересно

например:
удалить повторяющиеся числа и отсортировать, минимальным кол-вом кода.

Цитата Сообщение от nikkka Посмотреть сообщение
я не такой умный
а я думал ты дефка
0
Мат в 32 хода
236 / 171 / 18
Регистрация: 10.09.2009
Сообщений: 1,096
29.07.2010, 14:41 282

Не по теме:

niXman, фу блин, фотку менять надо :D



Добавлено через 44 секунды

Не по теме:

а Ника = Николай.

0
Эксперт С++
3210 / 1459 / 73
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
29.07.2010, 14:42 283
решение есть?
0
В астрале
Эксперт С++
8022 / 4779 / 654
Регистрация: 24.06.2010
Сообщений: 10,550
29.07.2010, 14:54  [ТС] 284
niXman, удалить повторяющиеся числа в тройке или во всем массиве?
0
Эксперт С++
3210 / 1459 / 73
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
29.07.2010, 14:57 285
Цитата Сообщение от Lavroff Посмотреть сообщение
удалить повторяющиеся числа в тройке или во всем массиве?
ты про какую задачу?
0
В астрале
Эксперт С++
8022 / 4779 / 654
Регистрация: 24.06.2010
Сообщений: 10,550
29.07.2010, 14:58  [ТС] 286
niXman,

например:
удалить повторяющиеся числа и отсортировать, минимальным кол-вом кода.

Ибо первое задание я вообще не представляю как сделать.
0
Эксперт С++
3210 / 1459 / 73
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
29.07.2010, 15:10 287
Цитата Сообщение от Lavroff Посмотреть сообщение
например:
удалить повторяющиеся числа и отсортировать, минимальным кол-вом кода.
да, во всем массиве.

Цитата Сообщение от Lavroff Посмотреть сообщение
Ибо первое задание я вообще не представляю как сделать.
мне очень понравилось и задание, и решение.

Добавлено через 11 минут
аууу....
хоть кто-то покажет решение?
0
1545 / 911 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
29.07.2010, 16:07 288
ахах)

На счет удаления повторов, решение получилось помоему больше чем стандартное =)
Но все-таки выложу, может кому полезно будет, да и буду рад выслушать замечания.

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
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
 
int main (void)
{
    const int SIZE=10;
    int MAS[SIZE]={1,6,4,2,9,6,1,7,5,2};
    std::vector <int> vec (MAS, MAS+SIZE);
    // output before 
    std::cout << "Before: " << std::endl;
    std::copy (vec.begin(), vec.end(), std::ostream_iterator <int> (std::cout, " "));
    std::cout << std::endl;
 
    std::sort (vec.begin(), vec.end());
    std::vector <int> :: iterator it=vec.begin();
    int cnt=std::count (vec.begin(), vec.end(), *it);
    for (it, cnt; it!=vec.end(); it++, cnt=std::count (vec.begin(), vec.end(), *it) )
        if (cnt-1)
            vec.erase (vec.begin()+(it - vec.begin())+1, vec.begin()+(it - vec.begin())+cnt);
    // output after
    std::cout << "After: " << std::endl;
    std::copy (vec.begin(), vec.end(), std::ostream_iterator <int> (std::cout, " "));
    std::cout << std::endl;
 
    return 0;
}
Добавлено через 45 минут
Опа-па.
Додумал, так быстрее и красивее.

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
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
 
int main (void)
{
    const int SIZE=10;
    int MAS[SIZE]={1,6,4,2,9,6,1,7,5,2};
    std::vector <int> vec (MAS, MAS+SIZE);
    std::vector <int> :: iterator it;
    // output before
    std::cout << "Before: " << std::endl;
    std::copy (vec.begin(), vec.end(), std::ostream_iterator <int> (std::cout, " "));
    std::cout << std::endl;
    //
    std::sort (vec.begin(), vec.end());
    it=std::unique (vec.begin(), vec.end());
    // output after
    std::cout << "After: " << std::endl;
    std::copy (vec.begin(), it, std::ostream_iterator <int> (std::cout, " "));
    std::cout << std::endl;
 
    return 0;
}
0
Эксперт С++
3210 / 1459 / 73
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
29.07.2010, 16:09 289
вот мое: http://liveworkspace.org/code/... 7e53d80ca9
1
Эксперт С++
3204 / 1731 / 435
Регистрация: 03.05.2010
Сообщений: 3,867
29.07.2010, 16:18 290
Цитата Сообщение от nikkka Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream> 
int main()
{
    int n;
    std::cin>>n;
    bool is=false;
    for (int i=0;i<1000000;i++)
        {if((1+((i*(i-1))/2))==n) {is=true;  break;}}
    if(is) std::cout<<"1\n";
    else std::cout<<"0\n";
    system("PAUSE");
    return 0;
}
Что-то у меня эта программа кроме нуля ничего не выводит.
0
В астрале
Эксперт С++
8022 / 4779 / 654
Регистрация: 24.06.2010
Сообщений: 10,550
29.07.2010, 16:32  [ТС] 291
У niXman короче всего. У него хороший способ


C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
 
int main() {
   const int src_s = 50;
   
   std::vector<int> src;
   
   for(int i=0;i<src_s;++i)
   {
       src.push_back(1+rand()%10);
   }
   std::vector<int>::iterator it;
   std::sort(src.begin(), src.end());
   it=std::unique(src.begin(), src.end());
   std::copy(src.begin(), it, std::ostream_iterator<int> (std::cout, " "));
   
   return 0;
}
0
1545 / 911 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
29.07.2010, 16:41 292
Да, короче на 1 строку.

У меня на этот код выходит ошибка:
error: `ivec' must be initialized by constructor, not by `{...}'
0
Эксперт С++
3210 / 1459 / 73
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
29.07.2010, 16:42 293
Цитата Сообщение от Lavroff Посмотреть сообщение
std::sort(src.begin(), src.end());
* *it=std::unique(src.begin(), src.end());
* *std::copy(src.begin(), it, std::ostream_iterator<int> (std::cout, " "));
тоже гуд
0
1545 / 911 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
29.07.2010, 16:42 294
Lavroff, ваше решение идентично моему.
0
Эксперт С++
3210 / 1459 / 73
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
29.07.2010, 16:42 295
Цитата Сообщение от neske Посмотреть сообщение
У меня на этот код выходит ошибка
какой компилятор? версия?
0
fasked
29.07.2010, 16:43
  #296

Не по теме:

Цитата Сообщение от niXman Посмотреть сообщение
какой компилятор? версия?
очевидно не MSVS2010 или gcc 4.5.0

0
В астрале
Эксперт С++
8022 / 4779 / 654
Регистрация: 24.06.2010
Сообщений: 10,550
29.07.2010, 16:44  [ТС] 297
neske, Идентично. Пытался разные варианты,пока алгоритмы в книжке просматривал. Есть несколько, но этот короче всех вроде как.

П.С. Такая инициализация вектора возможна только в 10 VS или gcc 4.5.0+
0
1545 / 911 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
29.07.2010, 16:45 298
Цитата Сообщение от niXman Посмотреть сообщение
тоже гуд
Мое решение прошло мимо ваших глаз?
0
Эксперт С++
3210 / 1459 / 73
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
29.07.2010, 16:49 299
Цитата Сообщение от Lavroff Посмотреть сообщение
Такая инициализация вектора
не только вектора, и не только контейнеров. драфт-стандарт: http://www.open-std.org/jtc1/s... /n2672.htm


Цитата Сообщение от neske Посмотреть сообщение
Мое решение прошло мимо ваших глаз?
нет же. просто ждал остальных вариантов. пока ждал, про ваш вариант забыл
0
В астрале
Эксперт С++
8022 / 4779 / 654
Регистрация: 24.06.2010
Сообщений: 10,550
29.07.2010, 17:38  [ТС] 300
niXman, По tuple решение не скинете? интересно посмотреть
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.07.2010, 17:38

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Проверить на правильность и закомментировать весь код для лучшего понимания
Всем здравствуйте. Условие задачи - Заданная матрица целых чисел размером (N, N). Найти среднее...

Нужны задачи для тренировки
Киньте задачки на классы......а то в самоучителе, по которому я учу Сишку....приведены задачки,...

Нужны задачи для тренировки
Здравствуйте киньте пожалуйста задания по с++ для человека начинающего изучать Turbo с++

Нужны задачи для тренировки
Вот не давно был школьный этап по программирование в школе(олимпиады). Меня закинули на городскую,...


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

Или воспользуйтесь поиском по форуму:
300
Закрытая тема Создать тему
Опции темы

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