1 / 1 / 0
Регистрация: 30.04.2014
Сообщений: 62

Аргументы командной строки

15.12.2014, 20:34. Показов 1048. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include <iostream>
#include <stdio.h>
#include <fstream>
#include <string.h>
#include <Windows.h>
#include <string>
using namespace std;
 
int main(int argc, char* argv[])
{
 
    setlocale(LC_ALL, "RUS");
    fstream f;
    string a[100];
    int n, c;
    f.open(argv[1]);
                                                                                                                                                                                                            
        
    
    for (int i = 0; i<argc; i++){
 
 
        if (strcmp(argv[i], "up") == 0) {
 
 
            for (int j = 0; j<c; j++)
                for (int k = 0; k<c - 1; k++){
                if (strcmp(a[k].c_str(), a[k + 1].c_str())>0)
                {
 
                    string temp;
                    temp = a[k];
                    a[k + 1] = temp;
                    return(strcmp((char*)m, (char*)m));
                }
                }
            cout << "По возрастанию" << endl;
            for (int j = 0; j<c; j++) cout << a[j] << " ";
            cout << endl;
 
        }
 
        if (strcmp(argv[i], "down") == 0) {
 
 
            for (int j = 0; j<c; j++)
                for (int k = 0; k<c; k++){
                if (strcmp(a[k].c_str(), a[k + 1].c_str())<0)
                {
 
                    string temp;
                    temp = a[k];
                    a[k] = a[k + 1];
                    a[k + 1] = temp;
                }
                return(strcmp((char*)m, (char*)m));
                }
            cout << "по убыванию" << endl;
            for (int j = 0; j<c; j++) cout << a[j] << " ";
            cout << endl;
 
        }
 
 
        if (strcmp(argv[i], "find") == 0) {
            bool f = false;
            for (int l; l<c; l++){
                if (strcmp(argv[i + 1], a[l].c_str()) == 0) {
                    f = true;
                    cout << "Ваше слово '" << argv[i + 1] << "' найдено, под номером " << l + 1;
                }
            }
            if (f == false) cout << "Слово не найдено";
        }
 
 
 
    }
 
}
Проблема состоит в том:
1) Правильный ли код
2) Как загрузить файл для проверки условия

Добавлено через 11 минут
Help
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.12.2014, 20:34
Ответы с готовыми решениями:

Аргументы командной строки
Есть прога, которая считывает файл посимвольно и выводит количество повторений символов в консоль. Открытие файла происходит так: FILE...

Аргументы командной строки
Уважаемые форумчане, растолкуйте, пожалуйста, назначение третьего аргумента &quot;char *const options&quot; в функции GetOptList . Для чего...

Аргументы командной строки
Пытаюсь разобраться с этой штукой. У Дейтела это собственно только дополнение, а не отдельный пункт раздела так что всё написано сжато и с...

5
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
15.12.2014, 20:40
Откуда мы знаем, что ты передаёшь как аргументы и в каком количестве?
0
1 / 1 / 0
Регистрация: 30.04.2014
Сообщений: 62
15.12.2014, 20:44  [ТС]
задача стоит в том, что у нас есть файл в котором записаны рандомно слова нам надо через аргумент их отсортировать по алфавиту. сложилась проблема в том что я не знаю как тот файл открыть через консоль
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
15.12.2014, 20:51
Первый параметр - имя файла, второй - направление сортировки? Значит, argv[1] - имя, argv[2] - up или down.
Дальше считаешь слова куда-нибудь и сортируешь.
0
1 / 1 / 0
Регистрация: 30.04.2014
Сообщений: 62
15.12.2014, 21:36  [ТС]
да все верно. вопрос в том как открыть файл для сортировки?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
15.12.2014, 23:29
Ты уже открыл через open(). Дальше надо куда-то считать слова. Используй, например vector<string>. Сортировать тогда можно через std::sort().
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.12.2014, 23:29
Помогаю со студенческими работами здесь

Аргументы командной строки
Здравствуйте, у меня вопрос, почему программа сбрасывается, так и не выполнив никаких действий? Я знаю , что она возвращает 0 и выходит,...

Аргументы командной строки
int main(int argc,int **argv) Понял только,что argc отвечает за количество аргументов,а argv-массив указателей на строки символов.Но...

Аргументы командной строки
Необходимо открыть файл на чтение, используя аргументы main. Не хотелось бы прописывать путь к файлу, который хотим открыть. Файл помещен в...

Распечатать аргументы командной строки
Если первый аргумент командной строки - опция -а , то распечатать остальные аргументы без их первых символов , а если первой идет опция -r...

Аргументы командной строки (АКС)
Доброго времени суток! Почему при объявлении АКС мы используем указатель на строки ... int main (int argc, char* argv) ... ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

Новые блоги и статьи
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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 —. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru