Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/25: Рейтинг темы: голосов - 25, средняя оценка - 4.76
0 / 0 / 0
Регистрация: 23.04.2018
Сообщений: 24

Дано вещественное число а. Напечатать все значения n, при которых 1 + 1/2 + 1/3 +.+ 1+n > a

04.05.2018, 17:23. Показов 5038. Ответов 8
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Дано вещественное число а. Напечатать все значения n, при которых 1 + 1/2 + 1/3 +...+ 1+n > a.

Вот код, который получился при переписывании с паскаля, но не могу понять, где ошибки. Помогите, пожалуйста.
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
#include <stdio.h>
#include <stdlib.h>
#include<locale.h>
 
int main()
{   setlocale(LC_ALL, "Rus");
 
    int n;
    double a, s;
 
    do{
        printf("Введите вещественное число <1 a= ");
        scanf("%lf", &a);
      }
    while( a < 1 );
    s = 0;
    n = 1;
    while (s > a - 1/n)
    {
        s += 1/n;
        printf("%d%4", n);
        n += 1;
    }
 
    printf("s = %lf", s);
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.05.2018, 17:23
Ответы с готовыми решениями:

Дано натуральное число n. Напечатать все цифры, которых нет в записи данного числа
Дано натуральное число n. Напечатать в возрастающем порядке все цифры, которых нет в записи данного числа

Дано вещественное число a, из чисел последовательности напечатать те, которые меньше a.
Помогите пожалуйста решить задачи Дано вещественное число a, из чисел 1; 1+;1+;..., напечатать те, которые меньше a. Заранее...

Дано вещественное число a. Из чисел 1+½, 1+⅓, 1+1/n напечатать те, которые меньше a
Дано вещественное число a. Из чисел 1+½, 1+⅓, 1+1/n напечатать те, которые меньше a.

8
Диссидент
Эксперт C
 Аватар для Байт
27710 / 17328 / 3810
Регистрация: 24.12.2010
Сообщений: 38,979
04.05.2018, 23:10
Цитата Сообщение от wakizashiii Посмотреть сообщение
s += 1/n;
В Си есть такой секретик. 1/2 = 0

Добавлено через 1 минуту
Но вот стало интересно. Разве в Паскале это не так?
0
 Аватар для palva
4256 / 2952 / 688
Регистрация: 08.06.2007
Сообщений: 9,862
Записей в блоге: 4
04.05.2018, 23:22
Байт, Не так. В паскале есть операция div для целого деления с отбрасыванием остатка.
1
Диссидент
Эксперт C
 Аватар для Байт
27710 / 17328 / 3810
Регистрация: 24.12.2010
Сообщений: 38,979
05.05.2018, 10:38
palva, а константы типа 1, 2 ... интерпретируются как real? Да?

Добавлено через 1 минуту
Тогда ругать новичков, приходящих в Си из Паскаля особенно не за что...
0
 Аватар для palva
4256 / 2952 / 688
Регистрация: 08.06.2007
Сообщений: 9,862
Записей в блоге: 4
05.05.2018, 10:55
Байт, нет, целые. Но результат деления '/' будет плавающим даже если разделилось нацело. В реальности это, наверно, так: целые числа загружаются в сопроцессор, там они автоматически запоминаются как 10 байтовые плавающие, а потом сопроцессор их делит. Операции 'div' и 'mod' реализуются обычным процессором.
1
0 / 0 / 0
Регистрация: 23.04.2018
Сообщений: 24
14.05.2018, 16:58  [ТС]
Вот готовая программа, но не знаю, как доработать, чтоб выводились ВСЕ значения n (выводится наименьшее n)
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
#include <stdio.h>
#include <stdlib.h>
#include<locale.h>
 
int main()
{   setlocale(LC_ALL, "Rus");
 
    int j;
    double a;
    printf("Введите вещественное число (a > 1) a = ");
    scanf("%lf", &a);
    if( a < 1)
    {
        printf("a < 1 !!!");
    }
    else
    {
        double sum = 0;
        for(j = 1; sum < a; j++)
            {
                sum += 1.0/j;
            }
        printf("%d : %lf", j, sum);
    }
   return 0;
}
0
 Аватар для palva
4256 / 2952 / 688
Регистрация: 08.06.2007
Сообщений: 9,862
Записей в блоге: 4
14.05.2018, 20:57
Цитата Сообщение от wakizashiii Посмотреть сообщение
1 + 1/2 + 1/3 +...+ 1+n > a.
Вот это вы написали в условии задания. Последними слагаемыми у вас должны быть числа 1 и n.
Ничего подобного ваша программа не делает.
Каким должно быть предпоследнее слагаемое, это я своим слабым умом понять не могу, поэтому предпочитаю молчать. Но эту вашу ошибку вижу.
Как вывести все? Это проще простого. Если число n удовлетворяет условию задачи, то ему удовлетворяет и любое число большее n. Так что, найдя n, напишите бесконечный цикл печати чисел n, n+1, n+2 и т. д. Всех чисел компьютер, естественно, не сможет напечатать, но вашему преподавателю, который дает вам такие странные и непонятные задачи, должно понравиться.
C Скопировано
1
for(;;j++) printf("%d\n", j);
1
0 / 0 / 0
Регистрация: 23.04.2018
Сообщений: 24
15.05.2018, 17:04  [ТС]
Только сейчас увидела ошибку в условии: последнее слагаемое ...+1/n > a. Дело в том, что таких значений n бесконечно много, т.к. это гармонический ряд. Вопрос в том, каким образом вывести эти значения? Не знаю, куда и какую строчку с кодом нужно вставить. Да, это глупо выводить бесконечность значений, но задание есть задание.
0
 Аватар для palva
4256 / 2952 / 688
Регистрация: 08.06.2007
Сообщений: 9,862
Записей в блоге: 4
15.05.2018, 19:17
Цитата Сообщение от wakizashiii Посмотреть сообщение
Не знаю, куда и какую строчку с кодом нужно вставить.
Вы вообще читаете, что вам пишут? Я написал вам что делать и написал эту строчку.

Добавлено через 26 минут
Вот так даже правильнее, чтоб два раза не печатать то значение j, которое вы уже нашли и напечатали.
C Скопировано
1
for(j++;;j++) printf("%d\n", j);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.05.2018, 19:17
Помогаю со студенческими работами здесь

Дано вещественное число X целое число N (>0).Найти значения выражения
Дано вещественное число X целое число N (&gt;0).Найти значения выражения 1+X+X^2+X^3+...+X^n помогите пожалуйста написать программу

Напечатать все значения n, при которых 1+1/2+1/3...+1/n>a
Дано вещественное число а. Напечатать все значения n, при которых 1+1/2+1/3...+1/n&gt;a

Напечатать все значения n, при которых 1+(1/2)+(1/3)+..+(1/n)<a
Дано вещественное число а. Напечатать все значения n,при которых 1+(1/2)+(1/3)+..+(1/n)&lt;a

Напечатать все значения n, при которых все числа последовательности будут не меньше а
Рассмотрим последовательность чисел: 1, 1+1/2, 1+1/3 . . . . . 1+1/n Напечатать все значения n, при которых все числа последовательности...

Напечатать все значения n, при которых все числа последовательности будут не меньше а
Рассмотрим последовательность чисел 1+ 1+ , … , 1+ . Напечатать все значения n, при которых все числа последовательности будут не меньше...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Создаем Telegram бот на TypeScript с grammY
run.dev 05.04.2025
Одна из его самых сильных сторон Telegram — это интеграция ботов прямо в экосистему приложения. В отличие от многих других платформ, он предоставляет разработчикам мощный API, позволяющий создавать. . .
Паттерны распределённых транзакций в Event-Driven микросервисах
ArchitectMsa 05.04.2025
Современные программные системы всё чаще проектируются как совокупность взаимодействующих микросервисов. И хотя такой подход даёт множество преимуществ — масштабируемость, гибкость, устойчивость к. . .
Работа с объемным DOM в javascript
Htext 04.04.2025
Сегодня прочитал статью тут о расходах памяти в JS, ее утечках и т. п. И вот что вспомнил из своей недавней практики. Может, кому пригодится. Хотя, в той статье об этом тоже есть. Дело в том, что я. . .
Оптимизация производительности Node.js с помощью кластеризации
run.dev 04.04.2025
Масштабирование приложений для обработки тысяч и миллионов запросов — обыденная задача для многих команд. Node. js, благодаря своей асинхронной событийно-ориентированной архитектуре, стал популярной. . .
Управление зависимостями в Python с Poetry
py-thonny 04.04.2025
Стандартный инструмент для установки пакетов в Python - pip - прекрасно справляется с базовыми сценариями: установил пакет командой pip install и используешь его. Но что произойдёт, когда разные. . .
Мониторинг с Prometheus в PHP
Jason-Webb 04.04.2025
Prometheus выделяется среди других систем мониторинга своим подходом к сбору и хранению метрик. В отличие от New Relic, который использует агентный подход и отправляет данные во внешнее хранилище,. . .
Пакет Context в Golang: Управление потоками и ресурсами
golander 04.04.2025
Работа с горутинами в Go часто напоминает управление непослушными детьми - они разбегаются кто куда, делают что хотят и не всегда завершаются вовремя. К счастью, в Go 1. 7 появился пакет context,. . .
Контейнеризация React приложений с Docker
Reangularity 03.04.2025
Контейнеризация позволяет упаковать приложение со всеми его зависимостями в автономный контейнер, который можно запустить на любой платформе с установленным Docker. Это существенно упрощает процессы. . .
Свой попап в SwiftUI
mobDevWorks 03.04.2025
SwiftUI, как декларативный фреймворк от Apple, предоставляет множество инструментов для создания пользовательских интерфейсов. В нашем распоряжении есть такие API как alerts, popovers, action sheets. . .
Антипаттерны микросервисной архитектуры
ArchitectMsa 03.04.2025
Хорошо спроектированная микросервисная система может выдержать испытание временем, оставаясь гибкой, масштабируемой и устойчивой к большинству проблем. Такая архитектура обладает высоким уровнем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер