dimrub: (Default)
[personal profile] dimrub
Вот задача про Юникс и Си, её придумал пользователь [livejournal.com profile] avysk, а я слегка модифицировал.

Написать на Си коротенькую программу, которая при вызове через конвейер выдаёт фразу "Hello, world!\n", а при вызове с командной строки выдаёт ту же строку, но не один, а два раза.
Короче, вот так:

$ my_prog
Hello, world!
Hello, world!
$ my_prog | cat -
Hello, world!
$

Конечно есть функция isatty, с помощью которой можно просто проверить, запущена ли программа с терминала, вот так:
if(isatty(1))...else...;
Поэтому дополнительное условие: этой функцией (или подобными ей) пользоваться нельзя.

И вот что интересно - пользователь [livejournal.com profile] ilya_dogolazky запостил очень похожую задачу.
Похожую, да решающуюся несколько иначе, хоть и непросто найти отличия в условии.




on 2008-03-09 12:12 am (UTC)
Posted by [identity profile] avva.livejournal.com
Ну например. По-моему, это не подходит под "подобными ей"?

on 2008-03-09 01:02 am (UTC)
Posted by [identity profile] ilya-dogolazky.livejournal.com
Ну это тоже прямой вопрос «не в конвейере ли мы сидим», так? Какой смысл был бы городить огород, если бы обе задачии решались бы абсолютно одинаково? :-)

on 2008-03-09 01:19 am (UTC)
Posted by [identity profile] avva.livejournal.com
Не знаю, по-моему это прямой вопрос "могу ли я читать оттуда, куда пишу"? Это совсем не то же самое, что "сижу ли я в конвейере", хоть в данном случае и совпадает.

on 2008-03-09 01:26 am (UTC)
Posted by [identity profile] ilya-dogolazky.livejournal.com
Да, разумеется. Эта задача (обе точнее) хороша тем, что имеет очень красивое (точнее два разных, но совпадающих на 50%) решение, но плоха тем, что формально отсечь другие решения нам не удалось. Считайте, что красота --- ещё одно дополнительное условие :-)

on 2008-03-09 01:32 am (UTC)
Posted by [identity profile] avva.livejournal.com
Хорошо, тогда давайте так в качестве одного из решений, хоть это и не очень-то гарантировано разнообразными стандартами.

on 2008-03-09 01:38 am (UTC)
Posted by [identity profile] ilya-dogolazky.livejournal.com
Ровно то, что надо! А что может обломиться? В случае с конвейером вроде ничего. А что говорят стандарты про случай интерактивного запуска?
(deleted comment)

on 2008-03-09 02:00 am (UTC)
Posted by [identity profile] ilya-dogolazky.livejournal.com
Пожалуйста!

А, здорово! Я вот немножко подсократил, так что получилось 4 «существенных» строчки - http://codepad.org/hh15AzmC
Если хотите можете подумать, как обойтись лишь двумя принтф"ами и ещё одним дополнительным вызовом некой функции (сразу скажу, что получится не слишком переносимо, но просто считайте, что запускаем под линуксом и всё тогда будет окей).

[если Вы ещё не спите и если не сложно, потрите пожалуйста коммент про волшебное слово на букву «с», а то с утра народ подтянется, его увидит и расстроится. А уж в ссылки с готовыми решениями никто случайно не ткнёт :-) ]

on 2008-03-09 02:02 am (UTC)
Posted by [identity profile] avva.livejournal.com
ага, стер.

on 2008-03-09 02:04 am (UTC)
Posted by [identity profile] ilya-dogolazky.livejournal.com
спасибо! [всё, я спать пойду, скоро уже Дима проснётся и продолжит :-) ]

on 2008-03-09 09:56 am (UTC)
Posted by [identity profile] ex-ex-zhuzh.livejournal.com
более надежно, например, так (http://codepad.org/hlJmdRw0).

on 2008-03-09 09:20 am (UTC)
avysk: (Default)
Posted by [personal profile] avysk
Можно запретить любые ветвления. То есть постулировать, что в обоих случаях исполняется один и тот же код.

on 2008-03-09 10:48 am (UTC)
Posted by [identity profile] ilya-dogolazky.livejournal.com
Это мысль! Хотя чревато массой дискуссий на тему того, является ли ветвлением ?:, && или даже == :-)

Profile

dimrub: (Default)
Adventures of a somewhat curious character

September 2013

S M T W T F S
12 345 67
891011121314
15161718192021
22232425262728
2930     

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Dec. 25th, 2025 03:34 am
Powered by Dreamwidth Studios