09.04.2012, 00:59 | #1 (permalink) |
Новичок
Регистрация: 09.04.2012
Сообщений: 4
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
|
Программа на Си
Я думаю вам они будут несложны и даже интересны: Задача 1 Написать программу имитирующую работу высотомера бомбы. Бамба падает с высоты Н, которая которая задается пользователем. В любой момент времени можно узнать пройденное расстояние по формуле L = g(t*t)/2, где g = 9.81 m/(c*c) Высотомер бомбы срабатывает раз в секунду и выводит на терминал текущее значение высоты над поверхностью земли h. Задача 2 Написать программу представляющую символы в массиве согласно правилу: сначала идут латинские буквы, потом цифры. Строка задается в коде программы в виде случайной последовательности букв и цифр. Пользоваться дополнительными массивами нельзя. Замечание: сортировка в данной программе не применима в виду ее трудоемкости. Нужно использовать группировку элементов массива. Задача 3 Программа очищающая строку от лишних пробелов. Лишними считаются пробелы в начале строки. и в конце строки и пробелы между словами, если их количество больше 1. Замечание: Сдесь запрещено создавать дополнительные массивы, т.е. неоходимо стремится к экономии памяти. Если поможете хотя бы с одной из них буду очень признателен, буду зазбираться в коде |
09.04.2012, 00:59 | |
Helpmaster
Member
Регистрация: 08.03.2016
Сообщений: 0
|
Темы которые подобны вашей уже были на нашем форуме Программа на С Программа на C++ |
09.04.2012, 10:32 | #2 (permalink) | |
Специалист
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
|
Цитата:
|
|
09.04.2012, 16:00 | #4 (permalink) |
Специалист
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
|
Я тоже не в курсе, но альтернативный пузырьку метод придумал - может быть, это оно? Суть: шлёпаем по массиву слева направо до первой цифры. Фиксируем ее номер (I). Дальше, стартуя от I, двигаемся вправо до первой буквы, пусть ее позиция (J). Меняем местами элементы I и J. Возвращаемся на позицию I и шлепаем дальше, и так продолжаем до тех пор, пока правее очередной цифры не обнаружится ни одной буквы.
Можно и так. Надо будет попробовать. |
09.04.2012, 16:30 | #5 (permalink) |
Member
Регистрация: 27.02.2010
Сообщений: 659
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 1312
|
Эмм если я правильно понял, то стартовать от I+1
Ну и вроде от того же метода пузырька не сильно отличается)) Хотя чем метод пузырька сложен и правда не понятно |
Ads | |
Member
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
|
09.04.2012, 23:25 | #6 (permalink) |
Новичок
Регистрация: 09.04.2012
Сообщений: 4
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
|
интересно конечно читать как вы эту задачку обсуждаете, но скиньте пожалуйста код чтобы я хоть посмотрел как это вообще получается
а на паскале я не понимаю я только вот Си начал изучать |
10.04.2012, 08:23 | #7 (permalink) |
Novel user
Регистрация: 16.04.2010
Сообщений: 568
Записей в дневнике: 3
Сказал(а) спасибо: 1
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 1149
|
Для первой задачи надо провести табулирование функции с шагом 1 и интервалом от Н до нуля. Если время будет вечером код напишу .
|
17.04.2012, 19:06 | #10 (permalink) |
Novel user
Регистрация: 16.04.2010
Сообщений: 568
Записей в дневнике: 3
Сказал(а) спасибо: 1
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 1149
|
Вот код на прошлой неделе не было времени:
Код:
#include "stdafx.h" //подключаем стандартные библиотеки #include "math.h" //подключаем стандартные библиотеки void main() { float t,b,h,x,y; //вводим переменные printf("Введите a,b,h -->"); //Спрашиваем у пользователя ввести необходимые переменные scanf("%f %f",&b,&h); //Считываем значения двух переменных t=sqert((2*b)/9.81); //Рассчитываем общее время падения for(x=t;x>=0;t-=h) //Запускаем массив, где время больше нуля с шагом 1 сек. { y=9.81*((x*x)/2); //Вводим нашу формулу printf("x=%f --> y=%f \n",x,y); //Выводим на экран значения высоты и времени } clrscr() //Очищаем экран и ждём нажатия кнопкипользователем getch() } возможно с ошибками Последний раз редактировалось Chervones; 17.04.2012 в 19:16 |
Ads | |
Member
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
|
Опции темы | |
Опции просмотра | |
|
|