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

Как добавить в вектор содержимое вложенных каталогов - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Сколько съел Винни-Пух на 15-ый День Рождения http://www.cyberforum.ru/cpp-beginners/thread1092244.html
Винни-пух на свое день рождение ведает столько еды сколько съел на двух предыдущих на первых двух днях он съел по 100 шрам нужноузнать сколько он съел на 15-й день рождение
C++ Сдающий карты. "cards_remaining--" одинаково работает и с "--", и без Всем привет, возник вопрос по поводу программы "сдающий карты", программа с книги "С++ без страха", автора не помню, не столь важно) Вот код программы #include <iostream> #include <math.h>... http://www.cyberforum.ru/cpp-beginners/thread1092226.html
C++ Пользователь вводит 8 чисел, вывести числа которые повторяются 2 или больше раз
Я понимаю, в средние века за такой код сжигали на костре. Но я только учусь. Подскажите как сделать правильнее. #include <iostream> using namespace std; int main() {
Ввести матрицу размером 10*5. Для неотрицательных элементов вычислить их произведение C++
Задача: Ввести матрицу размером 10*5. Для не отрицательных элементов вычислить их произведение. вообще не понимаю как это сделать помогите плз разобраться заранее большое спс
C++ Требуется идентификатор - как исправить? http://www.cyberforum.ru/cpp-beginners/thread1092186.html
class Homeworklist { private: int current_size; public: Homeworklist(){current_size = 0;} Homeworklist(string nameof, Date assigned_date_of, Date due_date_of); bool Addhomew(Homework h);...
C++ Не компиллируется функция cout В DevC++ не компиллируется программа с функцией cout. #include <iostream.h> int main() { cout << "0.12345"; return 0; } Как это исправить? подробнее

Показать сообщение отдельно
DU
1483 / 1059 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
09.02.2014, 02:15
вынести код обработки пути в функцию и внутри для директорий вызывать ее реукрсивно.
как-то так:
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
#include <vector>
#include <algorithm>
#include <boost\filesystem.hpp>
using namespace std;
using namespace boost::filesystem;
 
void ProcessPath(const path& p)
{
  if (exists(p))    // does p actually exist?
  {
    if (is_regular_file(p))        // is p a regular file?
      cout << p << " size is " << file_size(p) << '\n';
 
    else if (is_directory(p))      // is p a directory?
    {
      //cout << p << " is a directory containing:\n";
      std::cout << p << std::endl;
 
      typedef vector<path> vec;             // store paths,
      vec v;                                // so we can sort them later
 
      copy(directory_iterator(p), directory_iterator(), back_inserter(v));
 
      sort(v.begin(), v.end());             // sort, since directory iteration
                                            // is not ordered on some file systems
 
      /*
      for (vec::const_iterator it(v.begin()), it_end(v.end()); it != it_end; ++it)
      {
        cout << "   " << *it << '\n';
      }
      */
 
      for (vec::const_iterator it(v.begin()), it_end(v.end()); it != it_end; ++it)
      {
        ProcessPath(*it);
      }
    }
    else
      cout << p << " exists, but is neither a regular file nor a directory\n";
  }
  else
    cout << p << " does not exist\n";
}
 
int main(int argc, char* argv[])
{
  /*
    setlocale(LC_ALL,"rus");
    if (argc < 2)
    {
        cout << "Usage: tut4 path\n";
        return 1;
    }
 
    path p (argv[1]);   // p reads clearer than argv[1] in the following code
    */
  path p = "d:\\tmp\\test\\";
 
  try
  {
    ProcessPath(p);
    /*
    if (exists(p))    // does p actually exist?
    {
      if (is_regular_file(p))        // is p a regular file?
        cout << p << " size is " << file_size(p) << '\n';
 
      else if (is_directory(p))      // is p a directory?
      {
        cout << p << " is a directory containing:\n";
 
        typedef vector<path> vec;             // store paths,
        vec v;                                // so we can sort them later
 
        copy(directory_iterator(p), directory_iterator(), back_inserter(v));
 
        sort(v.begin(), v.end());             // sort, since directory iteration
                                              // is not ordered on some file systems
 
        for (vec::const_iterator it(v.begin()), it_end(v.end()); it != it_end; ++it)
        {
          cout << "   " << *it << '\n';
        }
      }
      else
        cout << p << " exists, but is neither a regular file nor a directory\n";
    }
    else
      cout << p << " does not exist\n";
      */
  }
 
  catch (const filesystem_error& ex)
  {
    cout << ex.what() << '\n';
  }
 
  return 0;
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru