Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
807 / 534 / 158
Регистрация: 27.01.2015
Сообщений: 3,017
Записей в блоге: 1

Разогнать программу до сверхскорости

25.11.2016, 10:05. Показов 2821. Ответов 54
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте уважаемые форумчане!
Есть код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
#include <string>
using namespace std;
 
int main()
{
    //ios::sync_with_stdio(false);
    //cin.tie(nullptr);
 
    unsigned long num;
    cin >> num;
    cout << to_string(num).size();
 
    //system("pause");
}
Программа вычисляет кол-во цифр в числе (целое неотрицательное число n от 0 до 2 * (10 ^ 9) включительно), но делает она это за 2.50 ms.

Помогите пж ее ускорить (Рекорд стоит на отметке 1.29 ms).

Есть такой вариант, проанализировать буфер ввода(stdin или istreambuf(или что там на плюсах)) напрямую, но даже не знаю, как это сделать...

Добавлено через 9 минут
PS: асм вставки компиль не понимает
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.11.2016, 10:05
Ответы с готовыми решениями:

Можно ли разогнать i5?
Можно ли разогнать i5 4670 без пометки K? Может в интернете и есть, но я хочу узнать лично с моим случаем. Системные требования: ...

Как разогнать 2,66 D?
Можно как-нибудь это сделать?Матер.Gigabyte GA-8N 775:o .И что с кулерами делать?:)

не разогнать мать
материнская DZ87KLT-75K цп 4770к биос на английском я ничего не понимаю, пмогите. в интернете ничего нет толкового . по руководству...

54
807 / 534 / 158
Регистрация: 27.01.2015
Сообщений: 3,017
Записей в блоге: 1
25.11.2016, 13:58  [ТС]
Студворк — интернет-сервис помощи студентам
IGPIGP, conio.h у них не подключается (в с++ же нет такого?)
0
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9007 / 4708 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
25.11.2016, 13:59
Цитата Сообщение от Ferrari F1 Посмотреть сообщение
MrGluck, 00001 или 0000 что выведет? Должен вывести 1))
проверка и пропуск ведущего нуля много времени не займёт. Кроме того оно поглотится вводом и не войдёт во время исполнения.

Добавлено через 42 секунды
Цитата Сообщение от Ferrari F1 Посмотреть сообщение
в с++ же нет такого?)
С чего Вы взяли?
0
807 / 534 / 158
Регистрация: 27.01.2015
Сообщений: 3,017
Записей в блоге: 1
25.11.2016, 14:00  [ТС]
IGPIGP,
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
//#include <iostream>
#include <cstdio>
using namespace std;
 
int main()
{
    char arr[14], *beg(arr), *end;
    gets(arr);
    while (*beg++ == '0');
    end = --beg;
    while (*end++);
    printf("%d", (*arr = --end - beg) ? *arr : 1);
}
Цитата Сообщение от Ferrari F1 Посмотреть сообщение
Но он мало того, что проходит лишь 75%, так еще и медленный 2.43 ms
0
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
25.11.2016, 14:01
Цитата Сообщение от Ferrari F1 Посмотреть сообщение
DrOffset, очень жаль, но получилось хуже по времени
А ты позапускай несколько раз подряд одно и то же, и увидишь как время скачет И это при том, что код особо не менялся, наоборот, количество операций сократилось.

Так что тут я вынужден согласиться со stima, в общем случае эти цифры ничего не значат.
+0.30ms или -0.30ms ничего не дают, точная оценка невозможна вследствие того, что система не real-time. Даже в идеале имея, например, на руках программу, которая заняла там первое место (я не утверждаю, что она обязательно ничем не лучше предложенных), мы можем не получить такой же хороший результат при собственном запуске. Так что предлагаю прекратить мерить доли миллисекнд, это контрпродуктивно в данных условиях.
0
503 / 352 / 94
Регистрация: 22.03.2011
Сообщений: 1,112
25.11.2016, 14:05
Цитата Сообщение от IGPIGP Посмотреть сообщение
stdio.h
у них не подключается.
<cstdio>
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8217 / 5048 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
25.11.2016, 14:06
Цитата Сообщение от Ferrari F1 Посмотреть сообщение
00001 или 0000 что выведет?
Хз кто так числа записывает.
C
1
2
3
4
5
6
7
8
9
10
11
12
#include <stdio.h>
 
int main()
{
    char c;
    int x = 0;
    while (scanf("%c", &c) && c != '\n')
        if (x || c != '0')
            ++x;
    printf("%d", x ? x : 1);
    return 0;
}
0
807 / 534 / 158
Регистрация: 27.01.2015
Сообщений: 3,017
Записей в блоге: 1
25.11.2016, 14:06  [ТС]
DrOffset, можно перенести проверку на мой компьютер ради интереса?
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8217 / 5048 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
25.11.2016, 14:07
Цитата Сообщение от IGPIGP Посмотреть сообщение
С чего Вы взяли?
Ну хотя бы поэтому https://ru.wikipedia.org/wiki/Conio.h
Тем не менее, он не является частью языка программирования Си, стандартной библиотеки языка Си, ISO C или требуемой стандартом POSIX.
0
503 / 352 / 94
Регистрация: 22.03.2011
Сообщений: 1,112
25.11.2016, 14:09
нагуглил интересный варинат:
C++
1
2
3
4
5
6
7
8
9
10
#include <cstdio>
 
int main()
{
    int pos;
    char buff[10];
    scanf("%10s%n", buff, &pos);
    printf("%d\n", pos);
    return 0;
}
1
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
25.11.2016, 14:12
Цитата Сообщение от Ferrari F1 Посмотреть сообщение
DrOffset, можно перенести условия проверки на мой компьютер ради интереса?
На твоем компьютере будет примерно тоже самое. Не говоря о том, что условия проверки сайт не раскрывает, насколько я понял.
Например, когда я делал свой вариант, то на моей машине время скакало от 0.8ms до 1.6ms для одинаковых кода и вводимых данных.
Относительная точность возможна только в системах со строгим real-time, ни windows, ни linux, ни тем более, веб-сервис проверки этих примеров такой системой не является, поэтому замеры на них могут давать лишь приближенную оценку в пределах погрешности.
0
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9007 / 4708 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
25.11.2016, 14:57
Цитата Сообщение от stima Посмотреть сообщение
<cstdio>
угу. Вы еще <cconio> напишите для комплекта. Хотя может быть и <cstdio> но не обязательно.
вот развернуто половинное деление:
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
#include <iostream>
using namespace std;
 
int main(int argc, char* argv[])
{
 int a;
 cin>>a;
if(a>=10000)
{
if(a<100000)
{
cout<<5;
goto fin;
}//>=100000
 
if(a>=10000000)
{
if(a<100000000)
{
cout<<8;
goto fin;
}
if(a==1000000000)
{
    cout<<10;
    goto fin;
}
else 
{
    cout<<9;
    goto fin;
}
}
else//>=100000 <10000000
{
if(a>=1000000)
{
    cout<<7;
    goto fin;
}
else 
{
    cout<<6;
    goto fin;
}
}
}
else//<10000
{
if(a>=10)
{
    if(a<100)
    {
        cout<<2;
        goto fin;
    }
//>=100
if(a<1000)
{
    cout<<3;
    goto fin;
}
//>=1000
cout<<4;
}
else//<10
cout<<1;
goto fin;
}
 
fin:
      cout<<endl;
            
                system("pause");
return 0;
}
это где-то около того что Вы показали, Ferrari F1?
0
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
25.11.2016, 15:48
IGPIGP, в 3 тесте выдаёт ошибку.
0
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9007 / 4708 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
25.11.2016, 16:21
Цитата Сообщение от mat_for_c Посмотреть сообщение
IGPIGP, в 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
67
68
69
70
71
72
73
74
75
76
77
#include <iostream>
using namespace std;
 
int main(int argc, char* argv[])
{
 int a;
 cin>>a;
if(a>=10000)
{
if(a<100000)
{
cout<<5;
goto fin;
}//>=100000
 
if(a>=10000000)
{
if(a<100000000)
{
cout<<8;
goto fin;
}
if(a==1000000000)
{
    cout<<10;
    goto fin;
}
else 
{
    cout<<9;
    goto fin;
}
}
else//>=100000 <10000000
{
if(a>=1000000)
{
    cout<<7;
    goto fin;
}
else 
{
    cout<<6;
    goto fin;
}
}
}
else//<10000
{
if(a>=10)
{
    if(a<100)
    {
        cout<<2;
        goto fin;
    }
//>=100
if(a<1000)
{
    cout<<3;
    goto fin;
}
//>=1000
cout<<4;
goto fin;
}
else//<10
cout<<1;
goto fin;
}
 
fin:
      cout<<endl;
            
                system("pause");
return 0;
}

после cout<<4;
позабытый переход добавил
0
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
25.11.2016, 17:06
Цитата Сообщение от IGPIGP Посмотреть сообщение
Скажите при каком входе не работает
если бы я сам знал
1
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9007 / 4708 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
25.11.2016, 17:47
Цитата Сообщение от mat_for_c Посмотреть сообщение
если бы я сам знал
Вспомнилось:
Цитата Сообщение от Петька и Чапаев
Первый пилот: - Петруха! Приборы!!!
Второй пилот: - 120 Василий Иванович!
Первый пилот: - Что 120??
Второй пилот: - А что приборы?!
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.11.2016, 17:47

как разогнать
как на biostar a870 разогнать проц ? ( а то не понимаю до этого были асроки всё понятно было , а в этой ни как разобраться не могу )

Разогнать amd
Привет помогите?!Не пойму почему по 5 v просадка?(проц немного по множителю разогнал(

Возможно ли разогнать процессор
Здравствуйте все. Имею компьютер с начинкой: Процессор : Intel Core 2 Duo E4700 2.6 GHz Материнка : Asus P5K-SE Оперативная память...

Хочу разогнать видеокарту
Хочу разогнать видеокарту Palit GeForce 7300 GT, помогите как это сделать, и вообще может не стоит ее разгонять?

Не могу разогнать память
HELP !!! Ребят помогите, проблема с ОЗУ !!! = Мать Z77 P8Z77-V LX + Xeon E3 1240, разогнал BCLK 105 и память 2200 CL 12 - 1.6V, вроде...


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

Или воспользуйтесь поиском по форуму:
55
Ответ Создать тему
Новые блоги и статьи
Сезонность и суточность закисления почв
anaschu 04.07.2026
200 часов это все равно моловато. Есть ситуации, но нестандартные, когда смена происходит за 5 лет. Но обычно это 50 лет и более. Наверное, закисление почвы происходит сезонно в средней. . .
В чем ценность человеческого опыта в глобальном смысле?
kumehtar 03.07.2026
Возможно, ценность человека не в том, что он однажды достигает мудрости, а в том, что он становится носителем карты пути. Он знает не только истину, но и последовательность внутренних изменений,. . .
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи. Через несколько переработок от PHP кода к C89 (надеюсь, 89). Но довольно запутанно получилось. Код для Linux. Но если убрать time и то, что с ним. . .
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения: - добавлена многоязычность - добавлено снятие скриншотов - добавлено поддержание бафов хождения по воде (для жреца, дк и шамана) - и так, по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru