Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.66/29: Рейтинг темы: голосов - 29, средняя оценка - 4.66
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 44

Дано натуральное число. Получить строковое представление этого числа

13.02.2012, 23:12. Показов 6085. Ответов 22
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано натуральное число. Получить строковое представление этого числа в виде последовательности цифр и пробелов, разделяющих группы по три цифры, начиная справа. Например, если исходное число равно 1753967, то результирующей должна быть строка 1 753 967.

PS: Вопорос в том что если делать строку нужно двигать элементы, а как это сделать не имею понятия
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.02.2012, 23:12
Ответы с готовыми решениями:

Дано натуральное число N получить все делители этого числа.
Дано натуральное число N получить все делители этого числа. C++ в QT. Можно и в MVS. Почищу код если в MVS.

Дано натуральное число. Определить минимальную цифру этого числа
Given a positive integer N.Write a program that determines the smallest digit which can be found in number

Дано натуральное число n. Переставить местами первую и последнюю цифры этого числа
Дано натуральное число n. Переставить местами первую и последнюю цифры этого числа.

22
08.03.2012, 20:53
Студворк — интернет-сервис помощи студентам

Не по теме:

Цитата Сообщение от easybudda Посмотреть сообщение
-=ЮрА=-, отрицательные числа забавно выводятся...
А если вбить просто минус, то вообще магия начинается =)
По крайней мере под линухом можно просто нажимать рандомно кнопки и текст будет стираться справа налево... Впечатлило.

0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
08.03.2012, 21:21
Цитата Сообщение от Vadikk Посмотреть сообщение
почему то тут выдает 2 лишних символа, можете объяснить в чем дело?
потому что в функции int ss (char ss1[80], char ss2[80]) нужно было написать не:
Цитата Сообщение от Vadikk Посмотреть сообщение
C++
1
for (sj=0; sj<=si; sj++)
, а:
C++
1
for (sj=0; sj<si; sj++)
Весь код:
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
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <iostream>
 
using namespace std;
 
int ss (char ss1[80], char ss2[80])
{
    int si=0;
    int sj;
    int sk;
    int sm=0;  
    
    while (ss1[si])    // Проходим все символы 
    {
    // printf("%c", ss1[si]);
        si++;
    }
    printf("\n\n Количество  = %d\n",si);
    //printf("razbivaem\n"); 
    
    for (sj=0; sj<si; sj++) 
    {
      sk=(si-sj)%3;
      if (sk==0 && sj!=0) 
      {
         printf(" ");  
         ss2[sm]=' ';
         sm++;
      }
      //printf("%c", ss1[sj]);
      ss2[sm]=ss1[sj];   
      sm++;
    };
    printf("\n");
    //printf("sm = %d\n",sm); 
    printf("\n");  
    return sm;
}
 
 
 
int main()
{
 
    char str1[80];  //входная строка
    char str2[80];  //строка-результат
    int i=0;
    int j;
    int k;
 
    printf(" Vvedite 4islo: \n\n");
    scanf("%s",&str1);
     
 
 
    k=ss(str1,str2);
    //printf("Polu4eno k = %d\n",k);
    printf(" Polu4ena stroka: \n\n");  
 
    
    for (i=0; i<k; i++) 
    {
        printf("%c", str2[i]);   
    };
    
    printf("\n"); 
    printf("\n\n");   
  
    system("PAUSE");
    return EXIT_SUCCESS;
}
1
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
09.03.2012, 14:33
Vadikk, я понял в каком направлении ты пошёл, вот твой код откуда я попытался выкинуть на мой взгляд лишнее. Алгоритм работает без сторонних хедеров, только лишь stdio.h и всё
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
#include <stdio.h>
 
int ss(char *str1, char *str2)
{
    int i,j;
    int sLen1 = 0;
    //Определяем длинну строки
    while(str1[sLen1])
        sLen1 = sLen1 + 1;
    for(i = (j = 0); i < sLen1; i++, j++)
    {
        if((i - sLen1 % 3) % 3 == 0 && 0 < i)
        {
            str2[j] = ' ';
            j = j + 1;
        }
        str2[j] = str1[i];
    }
    return j;
}
 
int main()
{
    char str1[256] = {0};  //входная строка
    char str2[256] = {0};  //строка-результат
    printf("Vvedite 4islo: ");scanf("%s",str1);
    int sLen2 = ss(str1,str2);
    printf("Dlina novoi stroki = %d\n",sLen2);
    printf("Polu4ena stroka: %s\n",str2);
    getchar();
    getchar();
    return 0;
}
Миниатюры
Дано натуральное число. Получить строковое представление этого числа  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.03.2012, 14:33

Дано натуральное число n. Найти сумму первой и последней цифры этого числа
Дано натуральное число n. Найти сумму первой и последней цифры этого числа.

Дано натуральное число л. Найти сумму первой и последней цифры этого числа
Дано натуральное число л. Найти сумму первой и последней цифры этого числа.

Дано натуральное число л. Переставить местами первую и последнюю цифры этого числа
Дано натуральное число л. Переставить местами первую и последнюю цифры этого числа.

Дано натуральное число n. Верно ли, что сумма цифр этого числа является чётной
У меня никак не получается сделать эту лабу. Очень прошу.срочно 1. Дано натуральное число n. Верно ли, что сумма цифр этого числа...

Получить двоичное строковое представление целого неотрицательного числа
Помогите пожалуйста с программой, очень надо. Описать функцию DecToBin(N) строкового типа, возвращающую строковое представление...


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

Или воспользуйтесь поиском по форуму:
23
Ответ Создать тему
Новые блоги и статьи
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np class PlantAgent: def __init__(self, name, strategy, initial_biomass): self. name = name self. strategy = strategy # "greedy" (широколиственные) или. . .
сукцессия 9. Математика подлости: как растения предали грибных друзей
anaschu 27.06.2026
Статья 2. Глобальная фосфорная война: эволюционно-экономические механизмы распределения биомов Земли Введение: Экологический рынок как игра с нулевой суммой Традиционная экология долгое время. . .
сукцессия 8. Как я спорил с ИИ, которые - агенты растений и ненавистники грибов!
anaschu 27.06.2026
Статья 1. Хроники грибного восстания: как Сократов диалог разрушил академические догмы ИИ Введение: Синдром «цифрового учебника» Современные большие языковые модели (LLM) обладают колоссальным. . .
Главный вопрос моделирования сукцессии
anaschu 27.06.2026
главный вопрос. Если эктомикориза лучше добывает недоступный фосфор. И ее масса максимальна из всех. А широколиственный лес тоже имеет самую крутую биомассу. То почему не возникло их симбиоза? Это. . .
сукцессия 6. Питон реализация энилоджиковской модели, картинка про Центральную часть будущей модели
anaschu 26.06.2026
Етить. ИИ мне на основе моего старого файла R создал вот эту вот хмерь на пайтоне. Это уже новая модель, модель сукцессии грибной. потоки фосфора, азота. Углерода. 5 видов организмов. Я даже. . .
Как замкнутый ядерный цикл решит проблему недостатки фосфора? Био миграция фосфора со дна океана
anaschu 26.06.2026
Биологический лифт: Концепция подъема фосфора со дна океана с помощью ЗЯТЦ Предлагаю на обсуждение альтернативу тяжелому промышленному бурению океанического дна. Вместо сложной инженерии мы можем. . .
сукцессия 5
anaschu 26.06.2026
ПЛАН РАЗРАБОТКИ математической модели сукцессии микоризных систем Переход AM → EcM (Endo + ErM) · Шумилов А. С. · ИФХиБПП РАН · Пущино · 2026 . . .
сукцессия 4
anaschu 25.06.2026
Более детализированный план разработки План доработки модели динамики микоризных симбиозов (EcM с гистерезисом) Цель: Реализовать логику переключения между эрикоидным (ErM) и эктомикоризным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru