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

Objective-C

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

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

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

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

Т,е например. есть число 2222 и число 2230 (правильные ответ здесь 1)
или 222 и 2230 (здесь уже правильный ответ 3)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
zulkis
681 / 608 / 38
Регистрация: 13.01.2011
Сообщений: 1,724
26.02.2013, 17:45     Разминка (логическая задачка) #2
А почему во 2м примере - ответ 3, а не 0?
Да и первый пример... почему ответ 1 а не 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.

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

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

<Расчеты>

0 и 2 -- неравно после 3го порядка.ответ 3.
Чего-то я в этой жизни не понимаю...
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)

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

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

порядок:3210
    
a1 =2222
b1 =2230
r1 =TTF 
    
a2 =0222
b2 =2230
r2 =F   
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)
sandye51
программист С++
677 / 579 / 39
Регистрация: 19.12.2010
Сообщений: 2,016
26.02.2013, 21:19     Разминка (логическая задачка) #10
mobidevelop, ну так все логично тут
mobidevelop
182 / 182 / 3
Регистрация: 10.01.2013
Сообщений: 596
26.02.2013, 21:46     Разминка (логическая задачка) #11
sandye51, да ладно? Да как так? Да как работает-то? Или мне таки выспаться надо?
sandye51
программист С++
677 / 579 / 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;
}
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 минут
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.02.2013, 11:50     Разминка (логическая задачка)
Еще ссылки по теме:

Prolog Логическая задачка Любимая еда и страхи
Маленькая разминка HTML, CSS
Разминка от Э. Таненбаума
Логическая задачка JavaScript

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

Или воспользуйтесь поиском по форуму:
korvin_
1660 / 1198 / 181
Регистрация: 28.04.2012
Сообщений: 4,347
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));
}
Yandex
Объявления
27.02.2013, 11:50     Разминка (логическая задачка)
Ответ Создать тему
Опции темы

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