Форум программистов, компьютерный форум CyberForum.ru

Решения на С с использованием указателей - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ срочно (Массивы) 4 вариант http://www.cyberforum.ru/cpp-beginners/thread222309.html
Задание 1 1. Описать двумерный массив целых чисел, число строк которого N. число столбцов М ввести с клавиатуры 2. Написать функцию для определения, числа строк имеющих минимальный элемент, являющийся простым числом. 3. Массив. С которым будут выполняться действия, следует передавать в функцию, как параметр, результат возвратить оператором return 4. Написать функцию main ( ) для ввода...
C++ строки символов Введите с клавиатуры строку символов. Замените первую букву в каждом слове на вопросительный знак и выведите результирующую строку на экран. http://www.cyberforum.ru/cpp-beginners/thread222296.html
Одномерный массив и его обработка C++
Помогите пожалуйста С++ знаю плохо... В одномерном массиве посчитать сумму элементов после максимального. Просьба сделать в С++ билдере и как-нибудь попроще
Стоимсть разговора C++
Написать программу вычисления стоимости разговора по телефону с учетом 20 % скидки, предоставляемой по субботам и воскресеньям. Ниже приведен рекомендуемый вид экрана программы во время ее работы(данные выделены полужирным шрифтом) Вычисление стоимости разговора по телефону. Введите исходные данные: Длительность разговора(целое кол-во минут) -> 3 День недели(1-понедельник, ...., 7 -...
C++ Указатели http://www.cyberforum.ru/cpp-beginners/thread222266.html
нашел у Страуструпа вот такую функцию: void swap(int *p, int *q) { int t = *p; *p = *q; *q = t; } зачем здесь указатели, почему нельзя просто использовать переменные?и вообще для чего используются указатели, в чем необходимость их использования?
C++ Упорядочить массив Всем здравствуйте. Мож кто сможет помочь с программкой? Очень надо, пожалуйста. Упорядочить массив натуральных чисел по неубыванию следующим способом: 1. сначала числа сортируются по последней цифре 2. затем числа сортируются по предпоследней цифре 3. т.д. Подсчитать количество умножений, делений, и перестановок элементов массива. подробнее

Показать сообщение отдельно
lemegeton
 Аватар для lemegeton
2910 / 1339 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
29.12.2010, 15:28     Решения на С с использованием указателей
Это на кого-ж ты учишься, что тебе объясняют указатели в С, а ты в С ни в зуб копытом?
Решение прямым пребором.
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
/*
 * Дан массив координат 30 точек на плоскасти.Найти максимальное и минимальное
 * расстояние между этими точками.Вывести координаты точек на экран.Реализовать,
 * используя указатели. 
 */
 
#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <ctime>
 
struct Point {
  int x;
  int y;
};
 
inline double calculate_distance(Point *a, Point *b) {
  return pow(pow(a->x - b->x, 2.) + pow(a->y - b->y, 2.), 0.5);
}
 
int main(int argc, char *argv[]) {
  srand(static_cast<unsigned int>(time(NULL)));
  int number_of_points = 30;
  Point point_set[number_of_points];
 
  printf("Points: ");
  for (int i = 0; i < number_of_points; ++i) {
    point_set[i].x = rand()%(number_of_points*10);
    point_set[i].y = rand()%(number_of_points*10);
    printf("(%d, %d) ", point_set[i].x, point_set[i].y);
  }
  printf("\n");
 
  Point *min_point_a, *max_point_a, *min_point_b, *max_point_b, *last_point;
  max_point_a = min_point_a = &point_set[0];
  max_point_b = min_point_b = &point_set[1];
  last_point = &point_set[number_of_points - 1];
  double max_distance, min_distance;
  max_distance = min_distance = calculate_distance(max_point_a, max_point_b);
 
  for (Point *a = &point_set[0]; a < last_point; ++a)
    for (Point *b = a+1; b <= last_point; ++b) {
      int distance_a_b = calculate_distance(a, b);
      if (max_distance < distance_a_b) {
        max_distance = distance_a_b;
        max_point_a = a;
        max_point_b = b;
      } else {
        if (min_distance > distance_a_b) {
          min_distance = distance_a_b;
          min_point_a = a;
          min_point_b = b;
        }
      }
    }
 
  printf("Min: (%d, %d) - (%d, %d), size: %f\n", 
        min_point_a->x, min_point_a->y,
        min_point_b->x, min_point_b->y,
        min_distance);
 
  printf("Max: (%d, %d) - (%d, %d), size: %f\n", 
        max_point_a->x, max_point_a->y,
        max_point_b->x, max_point_b->y,
        max_distance);
 
  int key;
  scanf("%d", &key);
  return 0;
}
 
Текущее время: 01:49. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru