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

Рекурсия в коде

06.12.2022, 16:26. Показов 1491. Ответов 1

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста изменить код, с учетом того, что файлы ищутся(и изменяются) не только в текущем каталоге, но и во всех его подкаталогах (любой степени вложенности).Фиктивные каталоги нужно игнорировать.
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
#include <stdio.h>
#include <sys/types.h>
#include <dirent.h>
 
int main() {
    DIR* dir;
    struct dirent* file;
    dir = opendir("/home/vladislav123/test");
    int i;
    if (dir != NULL) {
        while ((file = readdir(dir)) != NULL){
                char *file_name;   
                char new_file_name[100];
                int flag = 0;
                file_name = file->d_name;
                if (file_name == "main.c") {
                    flag = -1;
                }
                if (flag ==0) {
                    int indexIN = 0;
                    int indexOUT = 0;
                    while (file_name[indexIN] != '\0')
                    {
                        if (file_name[indexIN] >= '0' && file_name[indexIN] <= '9')
                            indexIN++;
                        else
                        {
                            new_file_name[indexOUT] = file_name[indexIN];
                            indexIN++;
                            indexOUT++;
                        }
                    }
                    new_file_name[indexOUT] = '\0';
                    i=rename(file_name, new_file_name);
                    printf(" %d ",i);
                }
        }
    }
    closedir(dir);
    return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.12.2022, 16:26
Ответы с готовыми решениями:

С++ рекурсия, задача найти ошибку в коде
#include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; int Count(char c, string s, int i) { if (i==s.length()) // условие...

Это рекурсия используется в коде?
Класс с именем MathComplex, объекты которого будут хранить комплексные числа. Комплексные числа - это... В математике комплексным...

По какому параметру идет рекурсия в приведенном коде
Фибоначи: по какому параметру идет рекурсия в этом коде? float a0, a1; int n,i=2 void fib(float a00,float a11) { float x=0; ...

1
Почетный модератор
 Аватар для Humanoid
11553 / 4348 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
06.12.2022, 21:03
Не проверял (даже не пробовал компилировать), но что-то вроде такого
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 <dirent.h>
#include <linux/limits.h>
#include <stdio.h>
#include <sys/types.h>
 
void recursive_scan(char *dir_name)
{
  DIR *dir = opendir(dir_name);
  struct dirent* file;
 
  if (!dir)
    return;
 
  printf("Scan directory '%s'\n", dir_name);
  while ((file = readdir(dir)) != NULL) {
    if (file->d_type == DT_DIR) {
      char full_path[PATH_MAX]; // либо можно высчитывать необходимый размер через strlen(dir_name)+strlen(file->d_name)+2 и выделять память через malloc() с последующим освобождением через free()
      snprintf(full_path, PATH_MAX, "%s/%s", dir_name, file->d_name);
      recursive_scan(full_path);  // рекурсивно вызываем эту же функцию на сканирование следующей директории
    }
  }
  closedir(dir);
}
 
int main()
{
  recursive_scan("/home/vladislav123/test");
}
C
1
2
file_name = file->d_name;
if (file_name == "main.c") {
Так нельзя сравнивать строки... вы сравниваете указатели, а они обязательно будут отличаться, т.к. "main.c" - это ваша константа, а file_name получен от функции readdir(). Содержимое может быть одинаковое, но хранится в разных участках памяти, поэтому указатели будут разные. Строки можно сравнивать через функцию strcmp()
C
1
2
3
if (!strcmp(file_name, "main.c")) {
  // строки одинаковые
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.12.2022, 21:03
Помогаю со студенческими работами здесь

Объясните, как работает рекурсия в коде, по нахождению НОД
int nod(int x, int y) { if(x == 0) return y; else if(y == 0) return x; else if(x == y) return x; ...

Рекурсия. Рекурсия с мемоизацией. (полная версия в печатном варианте, работа со словами и строками)
Прошу помочь, может было у кого похожее задание, пока выгружу и продолжу выполнять. Буду благодарен любой помощи. Входной текст состоит...

Рекурсия. Рекурсия с мемоизацией
Добрый день. Задача такова: У нас есть массив для длины строки (пусть будет M=20). У нас есть некие длины слов (колличество не важно пусть...

Рекурсия. Рекурсия с мемоизацией.
Добрый день. Задача такова: У нас есть массив для длины строки (пусть будет M=20). У нас есть некие длины слов (колличество не важно пусть...

рекурсия, косвенная рекурсия
Помогите пожалуйста написать программу: рекурсия, косвенная рекурсия. 1) Написать программу для определения четно или нет количество...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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