Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/22: Рейтинг темы: голосов - 22, средняя оценка - 4.86
2 / 2 / 0
Регистрация: 04.03.2014
Сообщений: 75

Вывести на экран в текущем каталоге имена тех каталогов, которые в себе не содержат подкаталогов

19.11.2014, 17:30. Показов 4427. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.. Выдали данное задание на С++ под linux
Разработать программу, которая выводит на экран в текущем каталоге имена тех каталогов, которые в себе не содержат подкаталогов.
Вариантов решения нет вообще , т.к с такими заданиями не сталкивался, может ктото интересовался данным вопросом или есть наброски буду рад
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.11.2014, 17:30
Ответы с готовыми решениями:

Вывести на экран в текущем каталоге имена тех каталогов, которые в себе не содержат подкаталогов
Здравствуйте.. Выдали данное задание на С++ под linux Разработать программу, которая выводит на экран в текущем каталоге имена тех...

В родительском каталоге посчитать количество каталогов и вывести имена каталогов, используя суперблок
Здравствуйте! Собственно часть моего задания написано в шапке темы. Полностью же мое задание звучит так: В родительском каталоге...

Поиск каталогов, которые в себе содержат каталоги
#!/bin/bash SPATH=$1 SPATH=${SPATH:-./} IFS=$'\n' if ]: then echo "Katalog ne sushestvuet: '${SPATH}'" exit 1 fi for d in...

3
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
19.11.2014, 18:33
Bash
1
2
man opendir
man 2 stat
Кликните здесь для просмотра всего текста
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/stat.h>
#include <dirent.h>
 
#ifdef WIN32
const char dir_delim = '\\';
#else
const char dir_delim = '/';
#endif
 
int count_subdir(char* dname) {
    DIR*             dir;
    struct dirent* entry;
    struct stat       st;
 
    char *cur_ent, *last;
    int   count = 0;
 
    cur_ent = calloc(1024, sizeof(*cur_ent));
    dir = opendir(dname);
    if (dir) {
        while(entry = readdir(dir)) {
            if(strcmp(entry->d_name, ".") == 0) continue;
            if(strcmp(entry->d_name, "..") == 0) continue;
            strcpy(cur_ent, dname);
            strcat(cur_ent, entry->d_name);
            stat(cur_ent, &st);
            if(S_ISDIR(st.st_mode)) {
                ++count;
            }
        }
        closedir(dir);
    }
    else
        perror(dname);
    free(cur_ent);
    return count;
}
 
int main(int argc, char** argv)
{
    struct dirent* entry;
    struct stat st;
    char *cur_dir, *cur_ent, *last;
    cur_dir = calloc(1024, sizeof(*cur_dir));
    cur_ent = calloc(1024, sizeof(*cur_ent));
    strcpy(cur_dir, argv[0]);
    last = cur_dir + strlen(cur_dir);
    while(last > cur_dir) {
        if(*last == dir_delim) break;
        *last = '\0';
        --last;
    }
    DIR* dir = opendir(cur_dir);
    if (dir) {
        while(entry = readdir(dir)) {
            if(strcmp(entry->d_name, ".") == 0) continue;
            if(strcmp(entry->d_name, "..") == 0) continue;
            strcpy(cur_ent, cur_dir);
            strcat(cur_ent, entry->d_name);
            stat(cur_ent, &st);
 
            last = cur_ent + strlen(cur_ent) - 1;
            if(*last != dir_delim) {
                *(last + 1) = dir_delim;
                *(last + 2) = '\0';
            }
            if(S_ISDIR(st.st_mode)) {
                if(count_subdir(cur_ent)==0)
                    puts(cur_ent);
            }
        }
        closedir(dir);
    }
    else
        perror(cur_dir);
    free(cur_dir);
    free(cur_ent);
    return 0;
}
0
0 / 0 / 0
Регистрация: 31.03.2015
Сообщений: 12
31.03.2015, 16:06
Цитата Сообщение от Cra3y Посмотреть сообщение
Bash
1
2
man opendir
man 2 stat
Кликните здесь для просмотра всего текста
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/stat.h>
#include <dirent.h>
 
#ifdef WIN32
const char dir_delim = '\\';
#else
const char dir_delim = '/';
#endif
 
int count_subdir(char* dname) {
    DIR*             dir;
    struct dirent* entry;
    struct stat       st;
 
    char *cur_ent, *last;
    int   count = 0;
 
    cur_ent = calloc(1024, sizeof(*cur_ent));
    dir = opendir(dname);
    if (dir) {
        while(entry = readdir(dir)) {
            if(strcmp(entry->d_name, ".") == 0) continue;
            if(strcmp(entry->d_name, "..") == 0) continue;
            strcpy(cur_ent, dname);
            strcat(cur_ent, entry->d_name);
            stat(cur_ent, &st);
            if(S_ISDIR(st.st_mode)) {
                ++count;
            }
        }
        closedir(dir);
    }
    else
        perror(dname);
    free(cur_ent);
    return count;
}
 
int main(int argc, char** argv)
{
    struct dirent* entry;
    struct stat st;
    char *cur_dir, *cur_ent, *last;
    cur_dir = calloc(1024, sizeof(*cur_dir));
    cur_ent = calloc(1024, sizeof(*cur_ent));
    strcpy(cur_dir, argv[0]);
    last = cur_dir + strlen(cur_dir);
    while(last > cur_dir) {
        if(*last == dir_delim) break;
        *last = '\0';
        --last;
    }
    DIR* dir = opendir(cur_dir);
    if (dir) {
        while(entry = readdir(dir)) {
            if(strcmp(entry->d_name, ".") == 0) continue;
            if(strcmp(entry->d_name, "..") == 0) continue;
            strcpy(cur_ent, cur_dir);
            strcat(cur_ent, entry->d_name);
            stat(cur_ent, &st);
 
            last = cur_ent + strlen(cur_ent) - 1;
            if(*last != dir_delim) {
                *(last + 1) = dir_delim;
                *(last + 2) = '\0';
            }
            if(S_ISDIR(st.st_mode)) {
                if(count_subdir(cur_ent)==0)
                    puts(cur_ent);
            }
        }
        closedir(dir);
    }
    else
        perror(cur_dir);
    free(cur_dir);
    free(cur_ent);
    return 0;
}
Cra3y, А не могли бы Вы закомментить код? Непонятны некоторые моменты
0
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
31.03.2015, 18:05
Цитата Сообщение от vascon Посмотреть сообщение
А не могли бы Вы закомментить код?
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
101
102
103
104
105
106
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/stat.h>
#include <dirent.h>
 
 
// символ разделитель директорий
#ifdef WIN32
const char dir_delim = '\\'; // для Windows
#else
const char dir_delim = '/'; // для *nix
#endif
 
/**
функция считает количество поддиректорий, в папке, указанной ее параметром
*/
int count_subdir(char* dname) {
    DIR*             dir; // дескриптор директории
    struct dirent* entry; // элемент каталога(файл/папка)
    struct stat       st; // атрибуты элемента
 
    char *cur_ent; // полное имя текущей записи (/папка/до/элемента/имя)
    //char *last;  // не нужен
    int   count = 0; // счетчик поддиректорий
 
    cur_ent = calloc(1024, sizeof(*cur_ent)); // выделяем память для имени
    dir = opendir(dname); // получаем дескриптор директории
    if (dir) { // если удалось открыть
        // получаем следующий элемент
        while(entry = readdir(dir)) {
            // пропускаем записи "." и ".."
            if(strcmp(entry->d_name, ".") == 0) continue;
            if(strcmp(entry->d_name, "..") == 0) continue;
            // получаем полное имя пекущей записи
            strcpy(cur_ent, dname);
            strcat(cur_ent, entry->d_name);
            // получаем атрибуты текущей записи
            stat(cur_ent, &st);
            if(S_ISDIR(st.st_mode)) { // если текущая запись - папка
                ++count; // увеличим счетчик
            }
        }
        closedir(dir); // закрываем дескриптор
    }
    else // выводим ошибку
        perror(dname);
    free(cur_ent); // освободить память
    return count;
}
 
int main(int argc, char** argv)
{
    struct dirent* entry; // текущая запись
    struct stat st; // атрибуты
    char *cur_dir, // текущая директория
         *cur_ent, // имя текущей записи
         *last;    // указатель на последний символ
    // выделяем память
    cur_dir = calloc(1024, sizeof(*cur_dir));
    cur_ent = calloc(1024, sizeof(*cur_ent));
    // копируем имя исполняемого файла
    strcpy(cur_dir, argv[0]);
    last = cur_dir + strlen(cur_dir); // получаем указатель на '\0' в cur_dir
    // затираем символы до разделителя
    while(last > cur_dir) {
        if(*last == dir_delim) break;
        *last = '\0';
        --last;
    }
    // получаем дескриптор
    DIR* dir = opendir(cur_dir);
    if (dir) {
        // получаем записи
        while(entry = readdir(dir)) {
            // пропускаем записи "." и ".."
            if(strcmp(entry->d_name, ".") == 0) continue;
            if(strcmp(entry->d_name, "..") == 0) continue;
            // получаем полное имя пекущей записи
            strcpy(cur_ent, cur_dir);
            strcat(cur_ent, entry->d_name);
            // получаем атрибуты текущей записи
            stat(cur_ent, &st);
 
            // добавляем разделитель к имени, если его там нет
            last = cur_ent + strlen(cur_ent) - 1;
            if(*last != dir_delim) {
                *(last + 1) = dir_delim;
                *(last + 2) = '\0';
            }
            if(S_ISDIR(st.st_mode)) { // если директория
                if(count_subdir(cur_ent)==0) // и нет поддиректорий
                    puts(cur_ent); // выводим имя
            }
        }
        closedir(dir); // закрываем дескриптор
    }
    else // выводим ошибку
        perror(cur_dir);
    // освободить память
    free(cur_dir);
    free(cur_ent);
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
31.03.2015, 18:05
Помогаю со студенческими работами здесь

Вывести имена подкаталогов из текущего каталога содержащие в себе подкаталоги
Разработать программу, которая выводит на экран имена тех каталогов, которые находятся в текущем каталоге и содержат в себе подкаталоги. ...

Строка: Вывести на экран из строки индификаторов, все индификаторы, которые не содержат в себе цифр.
#include&lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;ctype.h&gt; #define M 21 //количество символов в слове #define N 35 ...

Вывести имена всех файлов и подкаталогов в заданном каталоге, принадлежащих пользователю с заданным именем
Которая выводит имена всех файлов и подкаталогов в заданном каталоге, принадлежащих пользователю с заданным именем и общее число всех...

Проверить наличие в текущем каталоге файлов одинакового размера и вывести их имена, если такие файлы имеются
Здрасти. Задача: проверить наличие в текущем каталоге файлов одинакового размера. Если такие файлы есть – вывести их имена. get-childitem...

Вывести количество файлов с указанными именами, которые имеются в текущем каталоге ...
Помогите пожалуйста решить задачу: даны имена четырех файлов. Вывести количество файлов с указанными именами, которые имеются в текущем...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru