Форум программистов, компьютерный форум, киберфорум
Наши страницы

Objective-C

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.82
dollar8
13 / 13 / 3
Регистрация: 25.09.2011
Сообщений: 84
#1

Разминка (логическая задачка) - Objective-C

26.02.2013, 17:30. Просмотров 1395. Ответов 13
Метки нет (Все метки)

как узнать наименьшими усилиями после какого порядкя отличаются два числа.

Т,е например. есть число 2222 и число 2230 (правильные ответ здесь 1)
или 222 и 2230 (здесь уже правильный ответ 3)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.02.2013, 17:30
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Разминка (логическая задачка) (Objective-C):

Логическая задачка - JavaScript
Всем привет. Решил ради интереса написать пасьянс, да вот заглох, не успев начать:) Вот код: <!DOCTYPE HTML PUBLIC "-//W3C//DTD...

Логическая задачка - C++
Здравствуйте. Помогите решить задачку. Имеется 100 рублей. Стоимость курицы 1,5 рубля, овечки 2 руб. , бычка 5 руб. Вопрос: сколько...

Логическая задачка с объектами - JavaScript
Всем привет. Сразу к делу.. Пытаюсь написать что-то типа поиск по объектам с параметрами. Дано: var obj = Хочу в этом...

логическая задачка на пролог-д - Prolog
Задачка: Пришла весна. Четверо друзей – Костя, Вадим, Слава и Марат – влюбились в девушек (в различных!) и решили, что каждый подарит...

Логическая задачка про гирьки! - Lisp
Алеша, Витя и Игорь после уроков нашли на полу в кабинете физики маленькую гирьку. Каждый из них, рассматривая находку, высказал два...

Логическая задачка из ЕГЭ по информатике - Информатика
Приветствую всех! Сдавал я как то ЕГЭ по информатике и в целом ничего так, но вот логическая задачка меня вогнала в ступор. Точное ее...

13
zulkis
683 / 610 / 38
Регистрация: 13.01.2011
Сообщений: 1,724
26.02.2013, 17:45 #2
А почему во 2м примере - ответ 3, а не 0?
Да и первый пример... почему ответ 1 а не 0 опять же?
0
dollar8
13 / 13 / 3
Регистрация: 25.09.2011
Сообщений: 84
26.02.2013, 18:39  [ТС] #3
Цитата Сообщение от zulkis Посмотреть сообщение
А почему во 2м примере - ответ 3, а не 0?
Да и первый пример... почему ответ 1 а не 0 опять же?
есть число 2222 и число 2230 (правильные ответ здесь 1)

--т.е. берем старшие порядки и сравниваем.
2 и 2 --равно (они после 3го порядка)
2 и 2 -- равно (они после 2го порядка)
2 и 3 -- неравно после первого порядка (1), т.е идут числа 2 и 3, а они разные.

или 222 и 2230 (здесь уже правильный ответ 3)
сравниваем со старших порядков:
0 и 2 -- неравно после 3го порядка.ответ 3.

как то наверное сложно сформулировал задачу. ))

(т.е. мне надо знать когда начинает меняться цифра при сравнении двух чисел, если так грубо говорить)
0
mobidevelop
182 / 182 / 3
Регистрация: 10.01.2013
Сообщений: 596
26.02.2013, 19:07 #4
Цитата Сообщение от dollar8 Посмотреть сообщение
есть число 2222 и число 2230 (правильные ответ здесь 1)

<Расчеты>

0 и 2 -- неравно после 3го порядка.ответ 3.
Чего-то я в этой жизни не понимаю...
0
dollar8
13 / 13 / 3
Регистрация: 25.09.2011
Сообщений: 84
26.02.2013, 19:18  [ТС] #5
Цитата Сообщение от mobidevelop Посмотреть сообщение
Чего-то я в этой жизни не понимаю...
ТАК это два разный частных случая, которые я привел в виде пример.

вот еще.
22 и 32 (ответ 1)
222 и 232(ответ 1)
2222 и 2232 (ответ 1)

2222 и 2322 (ответ 2)
2222 и 3222 (ответ 3)
2222 и 222 (ответ 3)

вроде на примерах более понятно.
0
zulkis
683 / 610 / 38
Регистрация: 13.01.2011
Сообщений: 1,724
26.02.2013, 20:17 #6
mobidevelop, полностью разделяю точку зрения.
Это кошмар товарищи xD
0
mobidevelop
182 / 182 / 3
Регистрация: 10.01.2013
Сообщений: 596
26.02.2013, 20:34 #7
То ли леший нынче рьян,
То ли воздух нынче пьян,
То ли в ухе приключился
У меня какой изъян.
То ли логика своеобразная какая-то...
Одно ясно. НАСТОЛЬКО логические задачки мне не под силу

dollar8, перечитайте собственные посты.
0
korvin_
1912 / 1396 / 219
Регистрация: 28.04.2012
Сообщений: 5,007
26.02.2013, 21:03 #8
А я все понял (хотя и не с первого раза) =) Достаточно поставить чила друг под другом и пронумеровать порядки (а сравнивать нужно от большего порядка к меньшему — этого нет в условии):

порядок:3210
    
a1 =2222
b1 =2230
r1 =TTF 
    
a2 =0222
b2 =2230
r2 =F   
1
mobidevelop
182 / 182 / 3
Регистрация: 10.01.2013
Сообщений: 596
26.02.2013, 21:09 #9
korvin_, я сначала тоже так понял. Но ТС разрушил мои догадки. Да и мозг заодно.
Цитата Сообщение от dollar8 Посмотреть сообщение
222 и 232(ответ 1)
2222 и 2232 (ответ 1)
Цитата Сообщение от dollar8 Посмотреть сообщение
2222 и 3222 (ответ 3)
2222 и 222 (ответ 3)
0
sandye51
программист С++
685 / 587 / 39
Регистрация: 19.12.2010
Сообщений: 2,016
26.02.2013, 21:19 #10
mobidevelop, ну так все логично тут
0
mobidevelop
182 / 182 / 3
Регистрация: 10.01.2013
Сообщений: 596
26.02.2013, 21:46 #11
sandye51, да ладно? Да как так? Да как работает-то? Или мне таки выспаться надо?
0
sandye51
программист С++
685 / 587 / 39
Регистрация: 19.12.2010
Сообщений: 2,016
26.02.2013, 21:46 #12
-1 если числа равны
Objective-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
74
75
76
//
//  main.m
//  TestObj-C
//
//  Created by Ilya Lavrenov on 2/25/13.
//  Copyright (c) 2013 Ilya Lavrenov. All rights reserved.
//
 
#import <Foundation/Foundation.h>
 
@interface NumberComparator : NSObject
 
@property (assign, nonatomic, readwrite) NSUInteger firstValue;
@property (assign, nonatomic, readwrite) NSUInteger secondValue;
 
- (id)initWithFirstValue:(NSUInteger)firstArg andSecond:(NSUInteger)secondArg;
+ (id)comparatorWithFirstValue:(NSUInteger)firstArg andSecond:(NSUInteger)secondArg;
 
- (NSInteger)returnPosition;
 
@end
 
@implementation NumberComparator
 
@synthesize firstValue = _firstValue;
@synthesize secondValue = _secondValue;
 
- (id)initWithFirstValue:(NSUInteger)firstArg andSecond:(NSUInteger)secondArg
{
    self = [super init];
    if (self != nil)
    {
        [self setFirstValue:firstArg];
        [self setSecondValue:secondArg];
    }
    return self;
}
 
+ (id)comparatorWithFirstValue:(NSUInteger)firstArg andSecond:(NSUInteger)secondArg
{
    return [[[NumberComparator alloc] initWithFirstValue:firstArg andSecond:secondArg] autorelease];
}
 
- (NSInteger)returnPosition
{
    NSString *firstStringRepr = [NSString stringWithFormat:@"%li", [self firstValue]];
    NSString *secondStringRepr = [NSString stringWithFormat:@"%li", [self secondValue]];
    NSUInteger firstDigits = [firstStringRepr length], secondDigits = [secondStringRepr length];
    NSInteger maxDigits = (firstDigits > secondDigits ? firstDigits : secondDigits) - 1;
    
    if (firstDigits != secondDigits)
        return maxDigits;
    
    NSInteger i = 0;
    BOOL lastComp = [firstStringRepr characterAtIndex:i] == [secondStringRepr characterAtIndex:i];
    while (lastComp && i < maxDigits)
    {
        ++i;
        lastComp = [firstStringRepr characterAtIndex:i] == [secondStringRepr characterAtIndex:i];
    }
    
    return maxDigits - i - (lastComp ? 1 : 0);
}
 
@end
 
int main(int argc, const char * argv[])
{
    @autoreleasepool
    {
        NumberComparator *comparator = [NumberComparator comparatorWithFirstValue:1135 andSecond:2135];
        NSLog(@"%li", [comparator returnPosition]);
    }
    
    return 0;
}
1
dollar8
13 / 13 / 3
Регистрация: 25.09.2011
Сообщений: 84
27.02.2013, 09:27  [ТС] #13
Цитата Сообщение от sandye51 Посмотреть сообщение
-1 если числа равны
Objective-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
74
75
76
//
//  main.m
//  TestObj-C
//
//  Created by Ilya Lavrenov on 2/25/13.
//  Copyright (c) 2013 Ilya Lavrenov. All rights reserved.
//
 
#import <Foundation/Foundation.h>
 
@interface NumberComparator : NSObject
 
@property (assign, nonatomic, readwrite) NSUInteger firstValue;
@property (assign, nonatomic, readwrite) NSUInteger secondValue;
 
- (id)initWithFirstValue:(NSUInteger)firstArg andSecond:(NSUInteger)secondArg;
+ (id)comparatorWithFirstValue:(NSUInteger)firstArg andSecond:(NSUInteger)secondArg;
 
- (NSInteger)returnPosition;
 
@end
 
@implementation NumberComparator
 
@synthesize firstValue = _firstValue;
@synthesize secondValue = _secondValue;
 
- (id)initWithFirstValue:(NSUInteger)firstArg andSecond:(NSUInteger)secondArg
{
    self = [super init];
    if (self != nil)
    {
        [self setFirstValue:firstArg];
        [self setSecondValue:secondArg];
    }
    return self;
}
 
+ (id)comparatorWithFirstValue:(NSUInteger)firstArg andSecond:(NSUInteger)secondArg
{
    return [[[NumberComparator alloc] initWithFirstValue:firstArg andSecond:secondArg] autorelease];
}
 
- (NSInteger)returnPosition
{
    NSString *firstStringRepr = [NSString stringWithFormat:@"%li", [self firstValue]];
    NSString *secondStringRepr = [NSString stringWithFormat:@"%li", [self secondValue]];
    NSUInteger firstDigits = [firstStringRepr length], secondDigits = [secondStringRepr length];
    NSInteger maxDigits = (firstDigits > secondDigits ? firstDigits : secondDigits) - 1;
    
    if (firstDigits != secondDigits)
        return maxDigits;
    
    NSInteger i = 0;
    BOOL lastComp = [firstStringRepr characterAtIndex:i] == [secondStringRepr characterAtIndex:i];
    while (lastComp && i < maxDigits)
    {
        ++i;
        lastComp = [firstStringRepr characterAtIndex:i] == [secondStringRepr characterAtIndex:i];
    }
    
    return maxDigits - i - (lastComp ? 1 : 0);
}
 
@end
 
int main(int argc, const char * argv[])
{
    @autoreleasepool
    {
        NumberComparator *comparator = [NumberComparator comparatorWithFirstValue:1135 andSecond:2135];
        NSLog(@"%li", [comparator returnPosition]);
    }
    
    return 0;
}
Cупер!!! завтра запущу в проекте, но по коду--супер.
Просто я не очень хотел влазить в стринги да и вообще в объекты.
Плюс теперь надо чтобы эта задачка и для дабл чисел работала. т.е. порядок может уходить в минус, если расхождение будет после запятой.
sandye51, спасибо еще раз. с даблами я уже сам доделаю.

Добавлено через 3 минуты
Цитата Сообщение от korvin_ Посмотреть сообщение
А я все понял (хотя и не с первого раза) =) Достаточно поставить чила друг под другом и пронумеровать порядки (а сравнивать нужно от большего порядка к меньшему — этого нет в условии):

порядок:3210
    
a1 =2222
b1 =2230
r1 =TTF 
    
a2 =0222
b2 =2230
r2 =F   
да не сказал, что от большего порядка к меньшему (но это вполне логично из задачки).

Так вот как поставить числа друг под другом -- в этом и проблемка то. (Т.е можноооо как-то через стринги, но хочется это сделать просто и изящно).

Добавлено через 3 минуты
mobidevelop,
zulkis, Завтра изложу вообще цель данной задачки. просто я ее упростил до данного частного случая. Строю оси графика и на нем градацию. нарисую картинку завтра.

Добавлено через 8 часов 5 минут
0
korvin_
1912 / 1396 / 219
Регистрация: 28.04.2012
Сообщений: 5,007
27.02.2013, 11:50 #14
Чисто C без строк и объектов:

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
#include <stdio.h>
 
int pow(int base, int power)
{
   int result = 1;
   while (power > 0) {
      result *= base;
      --power;
   }
   return result;
}
 
int len(int num)
{
   int result = 0;
   while (num) {
      num /= 10;
      ++result;
   }
   return result;
}
 
int compare(int x, int y)
{
   int lx = len(x);
   int ly = len(y);
   
   if (lx > ly) return lx - 1;
   if (lx < ly) return ly - 1;
   
   int r = lx - 1;
   int q = pow(10, r);
   int dx, dy;
   while (r) {
      dx = x / q;
      dy = y / q;
      if (dx != dy) break;
      
      x %= q;
      y %= q;
      q /= 10;
      --r;
   }
   return r;
}
 
int main()
{
   printf("%d\n", compare(2222, 2230));
   printf("%d\n", compare( 222, 2230));
   printf("%d\n", compare(2222, 3222));
   printf("%d\n", compare(2222,  222));
}
1
27.02.2013, 11:50
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.02.2013, 11:50
Привет! Вот еще темы с ответами:

Логическая задачка в SWI Prolog - Prolog
На заводе работали три друга: слесарь, токарь и сварщик. Их фамилии Борисов, Иванов и Семенов. У слесаря нет ни братьев, ни сестер. Он...

Логическая задачка Любимая еда и страхи - Prolog
Здравствуйте, коллеги! Подскажите пожалуйста по синтаксису пролога. Задача: Решить задачу методом &quot;образовать и проверить&quot;. ...

Разминка от Э. Таненбаума - Сети
Мы постоянно решаем практические и сложные задачи. Как на счет простой разминки? Система обладает n-уровневой иерархией протоколов....

Маленькая разминка - HTML, CSS
Здравствуйте , для кого то это обычная разминка на 15 минут , а для кого то , то бишь меня , это путевка в армию , суть темы раскрывать не...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru