Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
Другие темы раздела
C (СИ) Отформатировать текстовый файл, абзацный доступ N пробелов доброго времени суток всем форумчанам) в общем я тут в первый раз учусь на 1ом курсе. в школе слабенько изучали паскаль. поступил на факультет информатики и вычислительной техники что... в переменных объявляешь переменную N - т.е. кол-во пробелов(отступ), открываешь 1 файл на чтение(твой файл), 2 на запись. По сути то что редактируется в 1 файле выполняется во 2ом, что бы проверять.... https://www.cyberforum.ru/ c-beginners/ thread274648.html C (СИ) Найти среднеарифметическое значение всех членов матрицы Доброго времени суток,задали в универе задачу,долго думал,пробывал решить в итоге ничего не получаеться. Задача-Дана прямоугольная матрица размером m на n(размер не должен превышать 10x10).Найти... #include <iostream> #include <ctime> #include <cstdlib> using namespace std; int main() { setlocale(0,"Rus"); srand(time(0)); int i,j,n,m,total=0; https://www.cyberforum.ru/ c-beginners/ thread274910.html
C (СИ) Найти и удалить n наименьших элементов массива
Дорогие форумчане, напишите пожалуйста программу буду благодарен...)) В массиве, все элементы которого различны, найти и удалить n наименьших элементов, сохраняя порядок следования остальных... Кроме как делать по одному n раз ничего не придумал. void main() { int A={5,4,3,2,1,9,8,7,6};int qA=9; int n=4; int jt; int ja; int nmin; for(jt=0;jt<n;jt++)
C (СИ) Найти минимальный по модулю элемент матрицы Дана матрица размером N x N. Найти минимальный по модулю элемент матрицы. Переставить строки и столбцы матрицы таким образом, чтобы минимальный по модулю элемент был расположен на пересечении К-ой... #include <stdio.h> #include <stdlib.h> # include <conio.h> # include <time.h> # define n 6 int main() { int a; int i, j, min, mi, mj, k; https://www.cyberforum.ru/ c-beginners/ thread275048.html
C (СИ) Найти первый член последовательности, для которого выполнено условие https://www.cyberforum.ru/ c-beginners/ thread274954.html
Найти первый член последовательности, для которого выполнено условие /an-an-1/<e, если последовательность образована по закону: an=(1-1/2!)(1+1/3!)…(1+(-1)^n/(n+1)!) ПОМОГИТЕ НЕ МОГУ ОБЬЯВИТЬ... #include <stdio.h> #include <conio.h> #include <math.h> main() { double x,an,am,e,f=1.; int n=1; printf ("vizislenie X1 posledovatelnosti,\n"); printf ("dla kotorogo vipolneno...
C (СИ) Кодирование Рида-Соломона https://www.cyberforum.ru/ c-beginners/ thread275159.html
Реализовать программу кодировая и декодирования согласно целочисленной версии алгоритма Рида-Соломона! Добавлено через 33 минуты может у кого заволялся исходный код прошу помочь!
C (СИ) Быстрая сортировка. Потеря элемента В программе есть две реализации быстрой сортировки- одна взята из местного фака,ещё одна из английского вики-учебника. По не совсем понятным причинам в обоих теряется один элемент, может кто-нибудь... выполните программу в пошаговом режиме и скажите, на каком именно месте вылетает ошибка https://www.cyberforum.ru/ c-beginners/ thread275223.html C (СИ) Упорядочить массив удалив нули со сдвигом влево ненулевых элементов
Нужно написать программу при помощи простейших и не замысловатых операторов. Дан одномерный массив.Упорядочить массив удалив нули со сдвигом влево ненулевых элементов. #include<stdio.h> int main(){ int mas={4,0,-5,0,6,7,0,0,-9,11}, size=sizeof(mas)/sizeof(*mas), *a=mas, *b=mas; for(; a!=mas+size; ++a){ if(*b=*a)++b; } for(a=mas;...
Оператор case - исправит ошибку в коде C (СИ)
#include <stdio.h> #include <conio.h> #include <string.h> char a,d; main () { printf ("\n Введите букву" ); scanf("%c",&a); switch (a) #include <stdio.h> #include <conio.h> #include <string.h> #include <locale.h> char a,d; int main () { setlocale(LC_ALL,".1251");
C (СИ) Из строк все цифры переписать в новый файл https://www.cyberforum.ru/ c-beginners/ thread275204.html
Создать текстовый файл из 5 строк, прочитать созданный файл, 1. Из строк все цифры переписать в новый файл. #include <stdio.h> #include <vcl.h> #include <conio.h> #include <string.h> #pragma... Вот скриншот, не могу понять почему цифры повторяются? По идее должно было получиться: 12345
C (СИ) UTF-8
Здравствуйте! В общем разбираюсь я тут с UTF-8. Имеет место быть следующая функция: int getNextWord(_TCHAR *sTarget, FILE *filePointer) { int iReadCount = 0; _TCHAR cCountCharacter =... В общем проблему решил, но вопросы остались. По умолчанию локаль в моей программе называется "С". Её нужно сменить на _tsetlocale(LC_ALL, _T("Russian_Russia.1251")); Так все работает...
C (СИ) В группе найти студентов с одинаковыми фамилиями
Здраствуйте! У меня две задачки (вроде бы не трудные) : 1.В группе найти студентов с одинаковыми фамилиями. Мой код таков: #include <conio.h> #include <stdio.h> #include <string.h> void main... #include<stdio.h> #include<conio.h> #include<string.h> main() { char str; int i,o=0; clrscr(); puts(str); gets(str);
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
13.04.2011, 02:33 0

Создать текстовый файл из 5 строк, прочитать созданный файл - C (СИ) - Ответ 1547316

13.04.2011, 02:33. Показов 8732. Ответов 3
Метки (Все метки)

Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Я думаю как-то так:

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
#include <stdio.h>
 
int main()
{
    FILE *fout, *fin;
    int i;
 
    const char strnum = 5, * const_str[ ] =
    {
        "1) first string",
        "second (2) string",
        "300 202 014",
        "Error 404: page not found",
        "A fatal exception OE has occurred at 0028:C02A0948 IN VXD VWIN32"
    };
 
    fout = fopen( "./out.txt", "w" );
 
    if( !fout )
    {
        fputs( "error opening ./out.txt for writing", stderr );
        return 1;
    }
 
    for( i = 0; i < strnum; i++ )
    {
       fputs( const_str[i], fout ); // пишем строки в файл
       fputs( "\n", fout ); // перенос строки
    }
 
    fclose( fout );
 
    puts( "Initial file written: ./out.txt" );
 
    fin = fopen( "./out.txt", "r" );
 
    if( !fin )
    {
        fputs( "error opening ./out.txt for reading", stderr );
        return 2;
    }
 
    fout = fopen( "./out2.txt", "w" );
 
    if( !fout )
    {
        fclose( fin );
        fputs( "error opening ./out2.txt for writing", stderr );
        return 2;
    }
 
    while( !feof( fin ) )
    {
        int ch = fgetc( fin ); // читаем символ из файла
 
        if( isdigit( ch ) ) // если прочтённый символ - цифра
            fputc( ch, fout ); // пишем её в файл
    }
 
    fclose( fout );
    fclose( fin );
 
    puts( "Numeric file written: ./out2.txt" );
 
    return 0;
}
Хотя, судя по vcl.h в списке заголовочников, можно было и на C++...

Добавлено через 53 минуты
Вот более красивый вариант - понимает дробные и отрицательные числа и каждое число выводит на своей строке.

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
107
108
109
110
111
112
113
114
#include <stdio.h>
 
inline char isDot( char ch )
{
    return ch == '.' || ch == ',';
}
 
inline char isDash( char ch )
{
    return ch == '-';
}
 
 
int main()
{
    FILE *fout, *fin;
    int i;
 
    const char strnum = 5, * const_str[ ] =
    {
        "1) first string - the very first one.",
        "second (2) string",
        "300 -202.08 14,485-15,2,4 .45 014, numeric one",
        "Error 404: page not found",
        "A fatal exception OE has occurred at 0028:C02A0948 IN VXD VWIN32"
    };
 
    fout = fopen( "./out.txt", "w" );
 
    if( !fout )
    {
        fputs( "error opening ./out.txt for writing", stderr );
        return 1;
    }
 
    for( i = 0; i < strnum; i++ )
    {
       fputs( const_str[i], fout ); // пишем строки в файл
       fputs( "\n", fout ); // перенос строки
    }
 
    fclose( fout );
 
    puts( "Initial file written: ./out.txt" );
 
    fin = fopen( "./out.txt", "r" );
 
    if( !fin )
    {
        fputs( "error opening ./out.txt for reading", stderr );
        return 2;
    }
 
    fout = fopen( "./out2.txt", "w" );
 
    if( !fout )
    {
        fclose( fin );
        fputs( "error opening ./out2.txt for writing", stderr );
        return 2;
    }
 
    while( !feof( fin ) )
    {
        char num[16] = {0};
        char dash = 0, dot = 0;
 
        // поиск первой цифры
        num[0] = fgetc( fin );
 
        dash = isDash( num[0] );
        dot = isDot( num[0] );
 
        if( !isdigit( num[0] ) && !dot && !dash )
           continue;
 
        //первая цифра найдена
        //чтение оставшейся части числа
        for( i = 1; i < 16; i++ )
        {
            num[i] = fgetc( fin );
 
            dot += isDot( num[i] );
            dash += isDash( num[i] );
 
            //printf( "dot = %i, dash = %i, smb = %c\n", dot, dash, num[i] );
 
            if( isDash( num[i] ) || ( !isdigit( num[i] ) && !isDot( num[i] ) ) || dot > 1 )
            {
               // если посередине числа лишняя точка или минус
               if( isDash( num[i] ) || isDot( num[i] ) )
                  fseek( fin, -1, SEEK_CUR ); // отмотать курсор назад - нам нужно прочитать этот символ ещё раз, вдруг он - часть следующего числа?
 
               num[i] = 0;
               break;
            }
        }
 
        // если у нас есть число (даже если это "-.156", что = "-0.156")
        if( isdigit( num[0] ) || isdigit( num[1] ) || isdigit( num[2] ) )
        {
           fputs( num, fout ); //вывод числа
           fputs( "\n", fout ); // перенос строки
        }
        // просто могут быть варианты вроде ".\n" или ",\n" или "-\n" - это не числа.
    }
 
    fclose( fout );
    fclose( fin );
 
    puts( "Numeric file written: ./out2.txt" );
 
    return 0;
}
Возможно, можно красивее - башка не варит.

Удачи.

Добавлено через 46 минут
Можно ещё лучше:

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
#include <stdio.h>
 
int main()
{
    FILE *fout, *fin;
    int i;
 
    const char strnum = 5, * const_str[ ] =
    {
        " 1) first string - the very first one.",
        "second (2) string",
        "300 -202.08 14,485-15,2,4 .45 014, numeric one",
        "Error 404: page not found",
        "A fatal exception OE has occurred at 0028:C02A0948 IN VXD VWIN32"
    };
 
    fout = fopen( "./out.txt", "w" );
 
    if( !fout )
    {
        fputs( "error opening ./out.txt for writing", stderr );
        return 1;
    }
 
    for( i = 0; i < strnum; i++ )
    {
       fputs( const_str[i], fout ); // пишем строки в файл
       fputs( "\n", fout ); // перенос строки
    }
 
    fclose( fout );
 
    puts( "Initial file written: ./out.txt" );
 
    fin = fopen( "./out.txt", "r" );
 
    if( !fin )
    {
        fputs( "error opening ./out.txt for reading", stderr );
        return 2;
    }
 
    fout = fopen( "./out2.txt", "w" );
 
    if( !fout )
    {
        fclose( fin );
        fputs( "error opening ./out2.txt for writing", stderr );
        return 2;
    }
 
    fseek( fin, 0, SEEK_SET );
 
    while( !feof( fin ) )
    {
        // поиск начала числа
        float num = 0.0f;
        char ch = fgetc( fin );
        char dig = isdigit( ch );
 
        if( ch == '-' || ch == '.' || dig )
           fseek( fin, -1, SEEK_CUR ); // первый символ нужно перечитать ещё раз
        else if( !dig )
           continue;
 
        // чтение числа
        if( fscanf( fin, "%f", &num ) )
        {
           char buff[16];
           sprintf( buff, "%f", num ); //сформировать строку вывода
 
           // отрезать нули справа
           for( i = strlen(buff); i >= 0; i-- )
           {
               if( buff[i] == '.' )
               {
                  buff[i] = 0;
                  break;
               }
               else if( buff[i] == '0' || !isdigit(buff[i]) )
                  buff[i] = 0;
               else
                  break;
           }
 
           fputs( buff, fout ); //вывод числа
           fputs( "\n", fout ); // перенос строки
        }
    }
 
    fclose( fout );
    fclose( fin );
 
    puts( "Numeric file written: ./out2.txt" );
 
    return 0;
}

Не по теме:

Вот что бессонница с человеком делает...



Вернуться к обсуждению:
Создать текстовый файл из 5 строк, прочитать созданный файл C (СИ)
2
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.04.2011, 02:33
Готовые ответы и решения:

Создать текстовый файл из 5 строк, прочитать созданный файл и получить новый файл
Создать текстовый файл из 5 строк, прочитать созданный файл и получить новый файл. Переписать в новый файл все строки, заменив все...

Создать текстовый файл F1 не менее, чем из 10 строк и записать в него информацию
Всем привет, задание такое: Создать текстовый файл F1 не менее, чем из 10 строк и записать в него информацию. Скопировать из файла F1 в...

Создать текстовый файл F1 не менее, чем из 10 строк и записать в него информацию
Создать текстовый файл F1 не менее, чем из 10 строк и записать в него информацию. Скопировать в файл F2 только те строки из F1, которые...

3
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.04.2011, 02:33
Помогаю со студенческими работами здесь

Прочитать текстовый файл
Прочитать текстовый файл КОД: #include &lt;conio.h&gt; #include &lt;stdio.h&gt; int main() { FILE *FP; printf(&quot;enter name...

Прочитать большой текстовый файл > 1Гб
Пытаюсь прочитать большой текстовый файл. 1Гб и более! Строки без пробелов, разделены &quot;\n&quot; Пример файла: &quot;line1\n ...

Создать текстовый файл F1. Скопировать в файл F2 только те строки из F1, которые заканчиваются символом "А"
Создать текстовый файл F1 не менее, чем из 10 строк и записать в него информацию. Скопировать в файл F2 только те строки из F1, которые...

Исходный текстовый файл скопировать в результирующий текстовый файл, удалив слова менее N1 символов
Не так давно я просил помощь в написании программы на си: Исходный текстовый файл скопировать в результирующий текстовый файл, удалив слова...

В текстовый файл вывести первые 12 строк «треугольника Паскаля»
В текстовый файл вывести первые 12 строк «треугольника Паскаля». В этом «треугольнике» крайние числа равны 1, а каждое внутреннее –...

0
Новые блоги и статьи
Java Record или Kotlin Data Class: что лучше для неизменяемых данных
Wired 04.03.2025
Java Record и Kotlin Data Class - средства для работы с неизменяемыми структурами данных, каждое из которых предлагает свой уникальный подход к решению этой задачи. История их появления весьма. . .
Создание производительны­­х API с Java и gRPC
Wired 04.03.2025
В разработке производительность и масштабируемость микросервисных приложений играют ключевую роль. Традиционные REST API, несмотря на свою популярность и простоту, не всегда способны обеспечить. . .
Что нового в JDK 24
Wired 04.03.2025
JDK 24 знаменует собой значительный скачок в развитии Java, внося фундаментальные улучшения в производительность, безопасность и удобство разработки. Релиз включает множество революционых изменений,. . .
Разработка блокчейн с использованием Java: смарт-контракты и dApp
Wired 04.03.2025
Современная блокчейн-разработка на Java предоставляет разработчикам широкий спектр возможностей. В отличие от Solidity, который ограничен экосистемой Ethereum, Java позволяет создавать как. . .
WebAssembly в Kubernetes
stackOverflow 03.03.2025
В современной экосистеме облачных технологий WebAssembly (Wasm) становится все более значимым компонентом, предлагая уникальный подход к выполнению кода в распределенных системах. Эта технология. . .
GitHub Actions или Jenkins: Выбираем CI/CD платформу
stackOverflow 03.03.2025
Непрерывная интеграция и развертывание (CI/ CD) изменили подход к разработке программного обеспечения, превратив его в бесшовный процесс от написания кода до развертывания в продакшн. GitHub Actions и. . .
Автоматизация тестирования Pull Request в Kubernetes: Интеграция с GitHub Actions и GKE
stackOverflow 03.03.2025
Масштабные проекты с использованием Kubernetes требуют надежной системы тестирования изменений перед их внедрением в продакшн-среду. Традиционный подход с ручной проверкой Pull Request не справляется. . .
Tестирование Pull Request в Kubernetes с помощью vCluster
stackOverflow 03.03.2025
При работе с микросервисной архитектурой критически важно обеспечить качественное тестирование каждого изменения перед его слиянием в основную кодовую базу. Однако тестирование Pull Request в. . .
Использование пакета Context в Golang
bytestream 03.03.2025
Управление параллельными процессами в современных приложениях - сложная задача, особенно когда речь идет о микросервисной архитектуре и распределенных системах. Пакет context в Go - это гибкое. . .
WebAssembly и Go: Работа с DOM и обработка ошибок
bytestream 03.03.2025
WebAssembly представляет собой технологию, позволяющую запускать низкоуровневый код в браузере практически на нативной скорости. Особенно интересные возможности открываются при использовании. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru