Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
0 / 0 / 1
Регистрация: 01.03.2010
Сообщений: 21

Файлы. Переместить отрицательные числа в начало, положительные в конец

29.09.2010, 16:38. Показов 1871. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Решить задачу через "Файлы". Переместить отрицательные числа в начало, положительные в конец, не применяя сотировк, затем обнулить 2 граничащих (отрицат. и положит. числа).
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.09.2010, 16:38
Ответы с готовыми решениями:

Задана последовательность чисел, нужно отрицательные числа переписать в начало, а положительные в конец, 0 - в середине
помогите пжл. завтра экзамен, не успеваю 1. Задана последовательность чисел, нужно отрицательные числа переписать в начало, а...

Последовательно переместить все отрицательные элементы списка в его начало, а положительные - в конец
1314 Дан список из n целых чисел a1, a2,..., an. Последовательно переместить все отрицательные элементы списка в его начало, а все...

Положительные элементы массива переместить в начало, а отрицательные — в конец
Дана последовательность чисел неизвестной длинны. Нужно заполнить массив этими числами, а потом в отдельной функции положительные элементы...

2
 Аватар для Dexter
291 / 151 / 34
Регистрация: 13.10.2009
Сообщений: 164
29.09.2010, 17:38
Ну можно сделать используя список, например, так:

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
struct Node
{ int nom;
Node *next;
};
typedef Node *PNode;
 
 
void AddFirst(PNode & Head,PNode NewNode)
{
NewNode->next=Head;
Head=NewNode;
}
 
void AddLast(PNode&Head, PNode NewNode)
{
PNode g=Head;
if (Head==NULL)
{
    AddFirst(Head,NewNode);
    return;
}
while(g->next)
    g=g->next;
g->next=NewNode;
}
 
PNode CreateNode(int nom)
{ PNode NewNode= new Node;
  NewNode->nom=nom;
  NewNode->next=NULL;
  return NewNode; }
 
 
void main()
{
    PNode Head=NULL, p;
    FILE *in, *out;
    int word;
    int n;
    in=fopen("input.txt","rt");
    while(1)
    {
        n=fscanf(in,"%i",&word);
        if(n<=0)
        break;
        p=CreateNode(word);
        if (word>0)
        AddLast(Head,p);
        else
        AddFirst(Head,p);
    }
    fclose(in);
    out=fopen("output.txt","wt");
    p=Head;     
    while(p)
    {
      fprintf(out,"%i ",p->nom);
      p=p->next;
    }
    fclose(out);
}
Оно ничего не сортирует, просто отрицательные переносит в начало, а положительные в конец файла.
Вход - файл input.txt с числами, выход - файл output.txt

затем обнулить 2 граничащих (отрицат. и положит. числа).
Эту фразу я не понял
1
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
29.09.2010, 18:30
Лучший ответ Сообщение было отмечено donvvv как решение

Решение

Эту фразу я не понял
Если бы писал сам и на Паскале(см. название раздела) , может и понял бы.
Это значит что там где кончаются отрицательные и начинаются положительные, есть граница и 2 элемента на границе нужно заменить нолем.

Добавлено через 13 минут
Pascal
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
78
79
80
81
82
83
84
85
86
87
88
uses crt;
var f:file of integer;
    n,i,j,p:integer;
    a,c,d,x:integer;
    k:byte;
begin
clrscr;
assign(f,'file1');
rewrite(f);
writeln('Введите в файл целые положительные и отрицательные чичла, окончание ввода 0');
repeat
readln(c);
if c<>0 then write(f,c);
until c=0;
reset(f);
writeln('Содержание исходного файла:');
while not eof(f) do
 begin
  read(f,c);
  write(c,' ');
 end;
writeln;
close(f);
{перестановка отрицательных вперед}
reset(f);
p:=0;
for i:=0 to filesize(f)-1 do
 begin
  seek(f,i);
  read(f,c);
  if c<0 then{если отрицательное}
   begin
    p:=p+1;{считаем}
    x:=c;{запоминаем}
    for j:=i downto p do{идем назад}
     begin
      seek(f,j-1);{читаем предыдущее число }
      read(f,d);
      seek(f,j);{вставляем вперед}
      write(f,d);
     end;
    seek(f,p-1);{вставляем на место которое нашли}
    write(f,x);
   end
 end;
if (p=0)or(p=filesize(f)) then
  begin
   write('Перестановок не было!');
   close(f);
  end
else
 begin
  writeln('Содержание нового файла:');
  reset(f);
  while not eof(f) do
   begin
    read(f,c);
    write(c,' ');
   end;
  close(f);
{замена граничных нолями}
  reset(f);
  for i:=0 to filesize(f)-1 do
   begin
    read(f,c);
    if c>0 then
     begin
      p:=i;
      break;
     end;
    a:=0;
    seek(f,p);
    write(f,a);
    seek(f,p-1);
    write(f,a);
   end;
  close(f);
  writeln('Замена граничных элементов на 0:');
  reset(f);
  while not eof(f) do
   begin
    read(f,c);
    write(c,' ');
   end;
  close(f);
 end;
readln
end.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.09.2010, 18:30
Помогаю со студенческими работами здесь

Переместить положительные элементы в начало массива, отрицательные в конец
1 Одномерный целочисленный массив. Превратить данный массив таким образом, чтобы сначала шли все положительные элементы, а затем...

Переместить положительные числа в начало списка, расположив их по возрастанию. Остальные - в конец
4. Преобразовать список по следующему правилу: Элементы списка, являющиеся положительными числами перенести в его начало, расположив их...

Для каждого из массивов все отрицательные элементы переместить в начало массива, а все положительные — в конец
Составить программу, которая превращает массивы А и В следующим образом: для каждого из них все отрицательные элементы одномерного...

Сортировка массива: перенести положительные числа в начало, а отрицательные - в конец массива
Дан вещественный массив A(N). Отсортировать его таким образом, чтобы все положительные числа находились в начале, а отрицательные - в конце...

Все отрицательные элементы переместить в начало массива, а остальные — в конец
Здравствуйте, помогите пожалуйста решить задачу на языке VBA, на делфи частично могу сделать, но в VBA совершенно не понимаю. Заранее...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Киев стоит - украинская песня
zorxor 28.01.2026
wfWdiRqdTxc О Господи, Вечный, Ты . . . Я помоги, Бесконечный. . . Я прошу Ты. . . Я погибаю, спаси. . . Я прошу Тебя Вечный. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru