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

средствами API реализовать - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Помогите пожалуйста написать программу в Microsoft Visual Studio 2010 (С++) http://www.cyberforum.ru/cpp-beginners/thread543590.html
Условие программы: Найти количество элементов, расположенных между минимальным и максимальным элементами массива.
C++ Как вводить в массивы переменные, различную символьную информацию Всем доброго времени суток. Совсем недавно начал изучать самостоятельно язык C++ и уже появляются различного рода вопросы. Сейчас сижу на массивах. Тема как для меня лично сложная, не знаю ли, будет еще сложней какая-нибудь тема, но нужна сейчас именно помощь по массивам. Задач в учебнике много и я думаю по каждой будет появляться вопросы и чтобы не плодить много тем, буду спрашить все вопросы... http://www.cyberforum.ru/cpp-beginners/thread543573.html
C++ задача на С++.(обработка строк)
Число записано в виде строки.Вывести самую большую цифру числа.Желательно поподробней ))
Наследование C++
Подскажите,пожалуйста,новичку в чем ошибка.Создал класс человек,создал класс студент,кот.наследует имя от класса человек.Может я тут чего лишнего налепил.Как-то с переменными типа int наследование понимаю,а вот с добавлением char,что-то не фурычит. Не судите строго.:) #include <iostream> #include <conio.h> #include <locale> using namespace std; class human { protected:
C++ Даны сведения о результатах аттестаци http://www.cyberforum.ru/cpp-beginners/thread543515.html
Добрый вечер. Помогите решить. Даны сведения о результатах аттестации: ФИО студента, название пяти предметов и баллы, полученные по каждому предмету. Вывести фамилии студентов, аттестованных по всем предметам.
C++ Динамический массив Добрый день! Подскажите, как сделать, чтобы массив выводился как матрица, а не строчкой? Где закралась ошибка? #include <iostream> #include <ctime> #include <conio.h> using namespace std; void main() { подробнее

Показать сообщение отдельно
AlieNear
24 / 0 / 2
Регистрация: 29.05.2012
Сообщений: 4
29.05.2012, 18:28     средствами API реализовать
Ну как-то так. Делал ради интереса, поэтому форматирование сделал, как мне кажется, более наглядным.

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
#include <iostream>
#include <stdio.h>
#include <windows.h>
#include <string.h>
 
using namespace std;
 
string path;
_WIN32_FIND_DATAA opts;
 
const char* GetErrorMessage() {
  char *error_message;
  FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER |
                FORMAT_MESSAGE_FROM_SYSTEM |
                FORMAT_MESSAGE_IGNORE_INSERTS,
                NULL, GetLastError(),
                MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
                (LPTSTR) &error_message, 0, NULL);
  return error_message;
}
 
void waitForClose(FILE * f) {
    while (fclose(f)==-1) {
        cout<<"\nFile cannot be closed!\n";
        system("pause");
    }
}
 
bool dirExists(const string& dirName) {
    DWORD ftyp = GetFileAttributesA(dirName.c_str());
    if (ftyp == INVALID_FILE_ATTRIBUTES)
        return false;
    if (ftyp == FILE_ATTRIBUTE_DIRECTORY)
        return true;
    return false;
}
 
double FindAndWrite(FILE *file, string path, int depth) {
    double g_size=0;
    HANDLE hFoundFile;
    _WIN32_FIND_DATAA tmp;
    hFoundFile=FindFirstFile((path+"*").c_str(), &tmp); // skipping the "." dir
    FindNextFile(hFoundFile, &tmp);                     // skipping the ".." dir
    FindNextFile(hFoundFile, &opts);
    for (int i=1; i<depth; ++i, fprintf(file,"\t"));
    fprintf(file, "+ %s\n", path.c_str());
        do {
            if (dirExists(path+opts.cFileName)) {
                g_size+=FindAndWrite(file, path+opts.cFileName+"\\", depth+1);
                continue;
            }
            for (int i=0; i<depth; ++i, fprintf(file,"\t"));
            fprintf(file, "- %-30.20s%s%lu kByte\n", opts.cFileName, " | ", opts.nFileSizeLow/1024);
            g_size+=opts.nFileSizeLow/1024;
        }
        while (FindNextFile(hFoundFile, &opts));
        for (int i=1; i<depth; ++i, fprintf(file,"\t"));
        fprintf(file, "Total:\t%.2f kByte\n", g_size);
        FindClose(hFoundFile);
        return g_size;
}
 
void exec() {
    FILE * file;
    file=fopen((path+"sum.txt").c_str(), "w");
    FindAndWrite(file, path, 1);
    waitForClose(file);
}
 
int main() {
    cout<<"Enter path with ending \\: "; cin>>path;
    exec();
    system("pause");
    return 0;
}
Пример вывода:
Код
+ d:\tmp\test\
	- 123.jpg                        | 487 kByte
	+ d:\tmp\test\313\
		- 313                            | 0 kByte
	Total:	0.00 kByte
	+ d:\tmp\test\ajpg\
		- 1.jpg                          | 641 kByte
		- dfgbsdfgsdg.jpg                | 0 kByte
		- sdfgadsfga.jpg                 | 0 kByte
		- sorted-jpg.txt                 | 0 kByte
	Total:	641.00 kByte
	- error.txt                      | 0 kByte
	- sorted-text.txt                | 0 kByte
	- sum.txt                        | 0 kByte
	+ d:\tmp\test\txt\
		+ d:\tmp\test\txt\asdfas\
			+ d:\tmp\test\txt\asdfas\asdf\
				- 123.jpg                        | 487 kByte
			Total:	487.00 kByte
		Total:	487.00 kByte
		- sdgsdgdfag.txt                 | 39 kByte
		- sfdg.txt                       | 0 kByte
		- sum.txt                        | 0 kByte
	Total:	526.00 kByte
Total:	1654.00 kByte
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru