Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C] На интервале (1000, 9999) найти все простые числа, обладающие заданным свойством 
V
    Опции темы
anad
Дата 27.9.2006, 19:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 62
Регистрация: 30.3.2006

Репутация: нет
Всего: нет



Помогите решить задачу на си!
На интервале (1000, 9999) найти все простые числа, каждое из которых обладает тем свойством, что сумма первой и второй цифр в записи этого числа равна сумме третьей и четвертой цифр.

Это сообщение отредактировал(а) Cr@$h - 4.10.2006, 05:26
PM MAIL   Вверх
darkart
Дата 27.9.2006, 21:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 379
Регистрация: 9.11.2005

Репутация: 26
Всего: 31



Код

#include<stdio.h>
#include<conio.h>
int IsSymple(int num)
//функция проверки на простоту
{
    if(num<2||num%2==0)//если число четное
    {
        return 0;
    }
    else
    {
        for(int i=3;i<num/2;i=i+2)
            if(num%i==0)//если нашли делитель
                return 0;
        return 1;//число num-простое
    }
}
int CheckSum(int num)
//функция проверки суммы
{
    if(num%10+(num%100)/10==(num/100)%10+num/1000)
    {
        return 1;
    }
    else
    {
        return 0;
    }
}
int main()
{
    printf("Result:\n");
    for(int i=1000;i<10000;i++)
        if(CheckSum(i)&&IsSymple(i))
            printf("%d, ",i);

    getch();
    return 0;
}


Это сообщение отредактировал(а) Cr@$h - 4.10.2006, 05:29
PM MAIL WWW ICQ Skype GTalk   Вверх
Oleg_Ci
Дата 1.10.2006, 08:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Friend
**


Профиль
Группа: Участник
Сообщений: 485
Регистрация: 28.5.2006
Где: Новосиб.обл.

Репутация: 25
Всего: 30



Код

#include <stdio.h>

void main()
{
    int kol = 0, begin_j, begin_x, end, name, j, x, i, flag;
    for ( name=0; name<=18; name++  )
    {
        if ( name<10 )
            { begin_j = 1; begin_x = 0; end = name; }
        else { begin_j = begin_x = name-9; end = 9; }

        for ( j = begin_j; j <= end; j++ )
            for ( x = begin_x; x <= end; x++, kol++ )
            {
                int n = j*1000 + (name-j)*100 + x*10 + name-x;
                flag = 1;
                for ( i=2; i<n-1; i++ )
                {
                  if ( n%i == 0 )
                  {
                    kol--;
                    flag = 0;
                    break;
                  }
                }
                if ( flag ) printf("%d\n", n );
            }
    }
    printf("\n\n\nKol-vo number :  %d\n\n\n", kol );
    getchar();
}



Это сообщение отредактировал(а) Cr@$h - 4.10.2006, 05:32
PM MAIL   Вверх
Cr@$h
Дата 4.10.2006, 05:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Исследователь
***


Профиль
Группа: Участник Клуба
Сообщений: 1693
Регистрация: 3.4.2005
Где: Санкт-Петербург, Россия

Репутация: 3
Всего: 41




 ! 
Cr@$h
На будущее, прошу обратить внимания на мои замачания:

Модератор: Пожалуйста, один топик - один вопрос.
Модератор: Название темы должно отражать ее суть!

M
Cr@$h
Выделено из темы "[Turbo C] Вычисление косинуса угла треугольника, используя TPoint, TTriangle и функ. Leng".


Это сообщение отредактировал(а) Cr@$h - 4.10.2006, 05:53
PM MAIL ICQ   Вверх
anad
Дата 11.10.2006, 18:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 62
Регистрация: 30.3.2006

Репутация: нет
Всего: нет



Мне надо без функций и процедур!

Добавлено @ 18:43 
Олег4, количество чисел в конце пишет:56. А самих чисел выдает меньше. Что-то не правильно...
PM MAIL   Вверх
Dov
Дата 11.10.2006, 21:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

Репутация: 50
Всего: 88



Код
#include <stdio.h>

int main()
{
    int q = 0;
    int i, j;

    printf("Result:\n");

    for(i = 1000; i < 10000; i++)
    {
        for(j = 2; j * 2 < i; j++)
            if(i % j == 0)
                break;

        if(j * 2 >= i && (i % 10 + i / 10 % 10 == i / 100 % 10 + i / 1000))
            printf("\n%d. %d ", ++q, i);
    }
        
    return 0;
}



--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
maxim1000
Дата 11.10.2006, 22:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник
Сообщений: 3334
Регистрация: 11.1.2003
Где: Киев

Репутация: 24
Всего: 110



Цитата(Dov @  11.10.2006,  20:59 Найти цитируемый пост)
        for(j = 2; j * 2 < i; j++)
            if(i % j == 0)
                break;

если это проверка на простоту, то не совсем удачная, т.к. она нигде не сохраняет результат своей работы
желательно бы ещё флажок сделать какой-нибудь...
P.S.
условие окончания достаточно j*j<i - итераций будет меньше...


--------------------
qqq
PM WWW   Вверх
Dov
Дата 11.10.2006, 23:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

Репутация: 50
Всего: 88



maxim1000, человек попроще просит, попроще и получает.
А с этим j*j<i  согласен, хотя в данном случае это не принципиально.


--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
anad
Дата 12.10.2006, 00:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 62
Регистрация: 30.3.2006

Репутация: нет
Всего: нет



 мне только непонятно что такое break?

PM MAIL   Вверх
Cr@$h
Дата 12.10.2006, 00:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Исследователь
***


Профиль
Группа: Участник Клуба
Сообщений: 1693
Регистрация: 3.4.2005
Где: Санкт-Петербург, Россия

Репутация: 3
Всего: 41



Выход из текущего цикла.
PM MAIL ICQ   Вверх
Oleg_Ci
Дата 12.10.2006, 15:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Friend
**


Профиль
Группа: Участник
Сообщений: 485
Регистрация: 28.5.2006
Где: Новосиб.обл.

Репутация: 25
Всего: 30



 smile 
Код

#include <stdio.h>

int main(int argc, char *argv[] )
{
    int count = 1, i, j;

    for ( i = 1000; i<10000; i++ )
        if( i % 10 + i / 10 % 10 == i / 100 % 10 + i / 1000 )    
            for ( j=2; i%j; j++ )
                    if ( j == i-1 )    printf("%2d%6d\n",count++, i );

    getchar();
    return 0;
}


Это сообщение отредактировал(а) Олег4 - 12.10.2006, 15:49
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0888 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.