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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
web-magician
-6 / 11 / 1
Регистрация: 11.02.2011
Сообщений: 227
#1

Исправить ошибку в коде для сравнения строк - C++

08.01.2014, 15:47. Просмотров 823. Ответов 23
Метки нет (Все метки)

что-то не получается вот с этим:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <string>
using namespace std;
int main ()
{
setlocale (LC_ALL,"Rus");
char s[20];
for(int i=0;i<20;i++)
cin>>s;
if (s=='Привет')
cout<<"Привет"<<endl; // тут не знаю,что сделать для задержки если нужно
return 0
}
как исправить? есть ошибка или сам ход построения кода не верен но затея всем надеюсь понятна
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.01.2014, 15:47     Исправить ошибку в коде для сравнения строк
Посмотрите здесь:

Исправить ошибку в коде C++
Исправить ошибку в коде с++ C++
C++ Исправить ошибку в коде
C++ исправить ошибку в коде
C++ Исправить ошибку в коде.
исправить ошибку в коде C++
Исправить ошибку в коде C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
web-magician
-6 / 11 / 1
Регистрация: 11.02.2011
Сообщений: 227
09.01.2014, 15:36  [ТС]     Исправить ошибку в коде для сравнения строк #21
Цитата Сообщение от alsav22 Посмотреть сообщение
Видимо, у меня 10-я.

Чтобы остановка в конце кода сработала (cin.get()), извлекается '\n' из потока. Можно в две строки записать:
C++
1
2
cin>>s;
cin.get();
все понятно и не знал,что так можно,думал только так cin.get()
kravam
быдлокодер
1695 / 874 / 44
Регистрация: 04.06.2008
Сообщений: 5,338
09.01.2014, 16:28     Исправить ошибку в коде для сравнения строк #22
Цитата Сообщение от web-magician Посмотреть сообщение
нельзя сделать это все интуитивно понятным...есть писанный код программы которая работает через консоль прописал туда к примеру название песни или с расширением для более точного поиска или просто без расширения и чтобы программа искала и выводила найденный результат на экран и еще можно чтобы записывала в файл,а в файл в свою очередь сделать перезаписывающим через ios::app и будет оставаться последний искомый файл...при запуске программы можно сделать сразу считывание из файла и вывода на экран чтобы был виден последний искомый файл. если бы я все это смог бы сделать не просил бы помощи и заранее извиняюсь за возможные глупые вопросы и пожелания так как я только новичок в этом деле.
Ну так делай. Поизучай чего-нибудь. Научись рекурсивно выводить имена файлов и папок, могу дать исходники.
web-magician
-6 / 11 / 1
Регистрация: 11.02.2011
Сообщений: 227
11.01.2014, 21:29  [ТС]     Исправить ошибку в коде для сравнения строк #23
Цитата Сообщение от kravam Посмотреть сообщение
Ну так делай. Поизучай чего-нибудь. Научись рекурсивно выводить имена файлов и папок, могу дать исходники.
если не затруднит дай пожалуйста.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.01.2014, 22:40     Исправить ошибку в коде для сравнения строк
Еще ссылки по теме:

C++ Исправить ошибку в коде
Multiset: исправить ошибку в коде C++
Описание класса для определения одномерных массивов строк. Исправить ошибку C++
C++ Исправить ошибку в коде. С++
C++ Исправить ошибку в коде

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

Или воспользуйтесь поиском по форуму:
kravam
быдлокодер
1695 / 874 / 44
Регистрация: 04.06.2008
Сообщений: 5,338
11.01.2014, 22:40     Исправить ошибку в коде для сравнения строк #24
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
#include <windows.h>
#include <stdio.h>
 
long int rez= 0;
 
void GetFileList(LPTSTR sPath);
 
int main(){
 SetConsoleCP(1251);
 SetConsoleOutputCP(1251);
 
 
 
//Поскольку sPath и sExt и sEXT одинаковы во всех вызовах GetFileList, их можно было бы сделать
//глобальными, но я так оставил. 
//Сюда пишешь папку, в которой надо вести поиск
        char sPath[MAX_PATH]= "E:\\vso_moio";
 
 
 
//Обратить  внимание на размер массива!
        GetFileList(sPath);
//Портит всё дело: Если перенаправлять в файл с консоли, то полуачается, что в консол ведут 
//запись два разных потока- тот,который нужент и этот,который записывает "Для продлжения нажмите любую
//клавишу" и эта надпись вклинивается в серёдку и портит всё дело
      printf("rez= %d\n", rez);
  //system ("PAUSE");
      getchar ();
}
 
void GetFileList(LPTSTR sPath) {
 
 WIN32_FIND_DATA pFILEDATA;
 
 HANDLE hFile = FindFirstFile(strcat(sPath,"\\*.*"),&pFILEDATA);
 
//!!!!!!!!!!!!!!!!!!!!!!!!!!!!Необходимо именно здесь прописывать длину пути!!!!!!!!!!!!!!!!!!!!!!!
// sPath[strlen(sPath) - strlen(strstr(sPath,"*"))] = '\0';
//Если пропишем после if (как предлагает Юра), то тогда, если вдруг натыкаемся на системную директорию
// или файл, то FindFirstFile возвращает -1. Следовательно, всё, что выплнняется по условию
//(hFile!=INVALID_HANDLE_VALUE) не выолнится и в частности, не будет поставлен конец строки!
//А это значит, что по выходу из  рекурсивной функции GetFileList в том месте, где мы восстанавливаем
//Длину, она будет восстановлена неправильно
 
//22.11.12 00:02
//Да и вообще нахрен оно надо, лучше так записать:
//по-любому звёздочка есть в строке, мы же делали конкантекацию строк выше!     
 *(strstr(sPath,"*.*"))= '\0';
 
 if (hFile!=INVALID_HANDLE_VALUE)    {
  char * chBuf;
  //sPath[strlen(sPath) - strlen(strstr(sPath,"*.*"))] = '\0';
  do {
   //Пропускаем . и ..
   if (strlen(pFILEDATA.cFileName) == 1 &&  strchr(pFILEDATA.cFileName,'.') !=NULL)
    if (FindNextFile(hFile,&pFILEDATA) == 0)
      break;
   if (strlen(pFILEDATA.cFileName) == 2 && strstr(pFILEDATA.cFileName,"..") !=NULL)
    if(FindNextFile(hFile,&pFILEDATA) == 0)
      break;
     //Если нашли директорию, запускаем поиск в ней рекурсивный поиск
   if(pFILEDATA.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) {
     
 
 
     strcat(sPath,pFILEDATA.cFileName);
     strcat(sPath, "\\");
     //CharToOem(sPath,sPath);
     printf("\n==%s\n",sPath);
     sPath[strlen(sPath)- 1]= '\0'; 
     rez++;
     //OemToChar(sPath,sPath);
 
     GetFileList(sPath);
 
 
//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!оБЯЗАТЕЛЬН востанавливать дллину пути................................     
     sPath[strlen(sPath) - strlen(pFILEDATA.cFileName)- 1] = '\0';
 
   }
   else {
      //Если не будем использовать CharToOem() то на экране русский шрифт каракулями выйдет
      //CharToOem(sPath,sPath);
      printf("%s",sPath);
      //OemToChar(sPath,sPath);
      //CharToOem(pFILEDATA.cFileName,pFILEDATA.cFileName);
      printf("%s\n",pFILEDATA.cFileName);
      rez++;
   }
  }
  while (FindNextFile(hFile,&pFILEDATA));
  FindClose (hFile);
 }
}
Yandex
Объявления
11.01.2014, 22:40     Исправить ошибку в коде для сравнения строк
Ответ Создать тему
Опции темы

Текущее время: 01:51. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru