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

Ровно вывести надписи - C++

Восстановить пароль Регистрация
 
Dragoon
1 / 1 / 0
Регистрация: 26.11.2012
Сообщений: 26
26.05.2013, 15:25     Ровно вывести надписи #1
Не подскажите, как можно выровнять все надписи типа "R=оо", приведенных на скриншоте. Текущий вывод выглядит вот так:
C++
1
cout<<setw(20)<<" R="<<"oo"<<endl;
и все это проделывается в цикле
Миниатюры
Ровно вывести надписи  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.05.2013, 15:25     Ровно вывести надписи
Посмотрите здесь:

Стирание надписи с экрана C++
Некорректно отображаются русские надписи на кнопках C++
C++ Вложенные циклы(Вывести на экран все четырехзначные числа, в которых ровно три одинаковые цифры)
Написать программу, в которой по нажатию на кнопку (Button) будет изменяться цвет надписи (Label) C++
Задача со строками (вывести слово, которое содержит ровно три буквы "и") C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Нету имени
177 / 22 / 2
Регистрация: 16.05.2013
Сообщений: 181
26.05.2013, 16:12     Ровно вывести надписи #2
Цитата Сообщение от Dragoon Посмотреть сообщение
Не подскажите, как можно выровнять все надписи типа "R=оо"
у меня такое предложение, определи общую линию от левого края до линии где будут надпись выстраиваться (допустим 40 пробелов), потом определи сколько знаков у тебя занимают твои расчеты (например у тебя на скриншоте '(1,2)' ) = 5 знаков, отними от 40 длину строки(5), и выведи на печать.
Olivеr
 Аватар для Olivеr
411 / 407 / 13
Регистрация: 06.10.2011
Сообщений: 830
26.05.2013, 16:22     Ровно вывести надписи #3
нужен код
Dragoon
1 / 1 / 0
Регистрация: 26.11.2012
Сообщений: 26
26.05.2013, 16:33  [ТС]     Ровно вывести надписи #4
Olivеr, привожу полный код функции:
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
void bruteforce(int x[n][n]) //вызов!!! Полный перебор
{
    int arc[2][1000],k=0,T=0,binary[100][100],tempmatr[n][n],max=0,jt=0,R=1000;
    int minmax[n][n]; //финальная минимаксная матрица
    bool flag=false;
 
    for(int i=0;i<n;i++)
        for(int j=0;j<n;j++)
            if (x[i][j]!=0)
            {
                T++;
                arc[0][k]=i;
                arc[1][k]=j;
                k++;
            }
 
    cout<<endl<<endl;
 
    for(int i=0;i<2;i++)      //выводим дуги
    {
        for(int j=0;j<k;j++)
            cout<<arc[i][j]+1<<" ";
        cout<<"\n";
    }
 
    cout<<endl;
 
    for(int i=0;i<n;i++)           //создали пустую матрицу
        for(int j=0;j<n;j++) tempmatr[i][j]=0;
 
    for(int i=0;i<pow((float)2,T);i++)   //заполняем бинарный счетчик
    {
        for(int j=0;j<T;j++)
            binary[i][j]=((i/(int)pow((float)2,T-1-j))%2?1:0)<< ' ';
    }
 
    for(int i=0;i<pow((float)2,T);i++)
    {
        for(int j=0;j<T;j++)
            if(binary[i][j]!=0)
            {
                tempmatr[arc[0][j]][arc[1][j]]=x[arc[0][j]][arc[1][j]];
                cout<<"("<<arc[0][j]+1<<","<<arc[1][j]+1<<")";
                //jt=j;
            }
            else tempmatr[arc[0][j]][arc[1][j]]=0;
 
            flag=chckrch(tempmatr,rchsrc);
            if (flag==true)   //Если матрица обладает исходной достижимостью,
            {           //то ищем ее максимальную дугу
                for(int i1=0;i1<n;i1++)
                    for(int j1=0;j1<n;j1++)
                        if(tempmatr[i1][j1]>max)
                        {
                            max=tempmatr[i1][j1];
                            flag=false;
                        }
 
                if(R>max) //минимальная дуга из максимальных
                {
                    R=max;
                    for(int i1=0;i1<n;i1++)
                        for(int j1=0;j1<n;j1++) minmax[i1][j1]=tempmatr[i1][j1];
                }
 
                cout<<" R="<<max<<endl;
                max=0;
            }
            else cout<<setw(20)<<" R="<<"oo"<<endl;
 
    }
 
    cout<<endl<<"Minmax arc weight: "<<R<<endl;
    cout<<"Minmax arc base: "<<endl;
    finalarcs(minmax);
}
Добавлено через 55 секунд
Нету имени, я думаю над твоим предложением...
Olivеr
 Аватар для Olivеr
411 / 407 / 13
Регистрация: 06.10.2011
Сообщений: 830
26.05.2013, 16:36     Ровно вывести надписи #5
Предлагаю попробовать так...
Заменить
C++
1
                cout<<"("<<arc[0][j]+1<<","<<arc[1][j]+1<<")";
на
C++
1
                cout<<setw(40)<<left<<"("<<arc[0][j]+1<<","<<arc[1][j]+1<<")";
Заменить
C++
1
2
3
            cout<<" R="<<max<<endl;
            max=0;
        } else cout<<setw(20)<<" R="<<"oo"<<endl;
на
C++
1
2
3
            cout<<" R="<<max<<endl;
            max=0;
        } else cout<<" R="<<"oo"<<endl;
Dragoon
1 / 1 / 0
Регистрация: 26.11.2012
Сообщений: 26
26.05.2013, 17:08  [ТС]     Ровно вывести надписи #6
Olivеr, Сделал. Вот результат:
Миниатюры
Ровно вывести надписи  
Olivеr
 Аватар для Olivеr
411 / 407 / 13
Регистрация: 06.10.2011
Сообщений: 830
26.05.2013, 17:27     Ровно вывести надписи #7
а если так?
Заменить
C++
1
                cout<<"("<<arc[0][j]+1<<","<<arc[1][j]+1<<")";
на
C++
1
                cout<<"("<<arc[0][j]+1<<","<<arc[1][j]+1<<setw(30)<<left<<")";
Заменить
C++
1
2
3
            cout<<" R="<<max<<endl;
            max=0;
        } else cout<<setw(20)<<" R="<<"oo"<<endl;
на
C++
1
2
3
            cout<<" R="<<max<<endl;
            max=0;
        } else cout<<" R="<<"oo"<<endl;
Добавлено через 2 минуты
хотя не, так тоже не будет работать

Добавлено через 5 минут
подключите #include <sstream> и замените цикл, в котором идет вывод на этот
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
    for(int i=0; i<pow((float)2,T); i++) {
        stringstream ss;
        for(int j=0; j<T; j++)
            if(binary[i][j]!=0) {
                tempmatr[arc[0][j]][arc[1][j]]=x[arc[0][j]][arc[1][j]];
                ss<<"("<<arc[0][j]+1<<","<<arc[1][j]+1<<")";
            } else tempmatr[arc[0][j]][arc[1][j]]=0;
 
        flag=chckrch(tempmatr,rchsrc);
        if (flag==true) { //Если матрица обладает исходной достижимостью,
            //то ищем ее максимальную дугу
            for(int i1=0; i1<n; i1++)
                for(int j1=0; j1<n; j1++)
                    if(tempmatr[i1][j1]>max) {
                        max=tempmatr[i1][j1];
                        flag=false;
                    }
 
            if(R>max) { //минимальная дуга из максимальных
                R=max;
                for(int i1=0; i1<n; i1++)
                    for(int j1=0; j1<n; j1++) minmax[i1][j1]=tempmatr[i1][j1];
            }
 
            cout<<ss.str()<<setw(40 - ss.str().size())<<" R="<<max<<endl;
            max=0;
        } else cout<<ss.str()<<setw(40 - ss.str().size())<<" R="<<"oo"<<endl;
 
    }
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.05.2013, 17:59     Ровно вывести надписи
Еще ссылки по теме:

C++ В предложении найти и вывести на экран все слова, содержащие ровно две буквы “d”
Вывести элементы массива, которые повторяются ровно два раза C++
Вывести только те слова сообщения, которые встречаются в нем ровно один раз C++

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

Или воспользуйтесь поиском по форуму:
Dragoon
1 / 1 / 0
Регистрация: 26.11.2012
Сообщений: 26
26.05.2013, 17:59  [ТС]     Ровно вывести надписи #8
Olivеr, Вот результат.
Спасибо Вам, спасибо огромное!!! Очень помогли. Еще раз спасибо. Пойду почитаю про эту библиотеку...
Миниатюры
Ровно вывести надписи  
Yandex
Объявления
26.05.2013, 17:59     Ровно вывести надписи
Ответ Создать тему
Опции темы

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