Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Java [игнор отключен] [закрыт для гостей] / задача / 9 сообщений из 9, страница 1 из 1
14.04.2005, 11:10
    #33015227
stydent
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
Помогите решить задачу:
Надо написать алгоритм,с помощью которого можно определить по номеру элемента в какой строке от находится(пирамида бесконечная):
0 -1 строка
1 2 -2 строка
3 4 5 -3 строка
6 7 8 9 -4 строка
10 11 12 13 14 -5 строка
15 16 17 18 19 20 -6 строка
и т.д.....

Пишем :4: -3 строка,:10-5строка:....
...
Рейтинг: 0 / 0
14.04.2005, 11:20
    #33015258
NotGonnaGetUs
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
первый элемент в строке n(n-1)/2, где n её номер.
ищи такое n, что бы твоё число было >= n(n-1)/2 и меньше чем n(n+1)/2 и будет тебе счастье.
...
Рейтинг: 0 / 0
14.04.2005, 12:24
    #33015515
wessen
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
Совсем было скучно и нечего делать
Код: plaintext
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.
 package  fromsqlru;

 import  java.io.BufferedReader;
 import  java.io.InputStreamReader;

 public   class  Main {
    
     private   int  number;
     private   int  row= 0 ;
     private   int  diag= 0 ;
     private   int  incRow= 1 ;
     private   int  incDiag= 2 ;
 
    /** Creates a new instance of Main */
     public  Main() {
        calc();
    }
    
    /**
     * @param args the command line arguments
     */
     public   static   void  main(String[] args) {
         new  Main();
    }
    
     private   void  calc(){
         while (true){
            System.out.println("Inter the number: ");
            BufferedReader buff= new  BufferedReader( new  InputStreamReader(System.in));
            
             boolean  isError=false;
             try {
                String line=buff.readLine();
                number=Integer.parseInt(line);
            } catch (Exception e){
                e.printStackTrace();
                isError=true;
            }
            
             if (!isError){
                 for ( int  i= 2 ;i< 1000000 ;i++){
                    row+=incRow;
                    diag+=incDiag;
                     if (number>=row && number<=diag){
                        System.out.println("Number is "+number+" Line is "+i);
                        row= 0 ;diag= 0 ;incRow= 1 ;incDiag= 2 ;
                         break ;
                    }
                    incRow++;
                    incDiag++;
                }
            }
            
        }
    }
    
}
...
Рейтинг: 0 / 0
14.04.2005, 12:30
    #33015531
javaScript != java
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
i ограничено бесконечностью :)
...
Рейтинг: 0 / 0
14.04.2005, 12:41
    #33015572
wessen
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
javaScript != javai ограничено бесконечностью :)
а это пускай сам делает, что б жизнь медем не казалась :)
там еще когда ноль введешь, веселый ответ получается.
...
Рейтинг: 0 / 0
14.04.2005, 13:20
    #33015726
NotGonnaGetUs
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
лучше так:
Код: plaintext
1.
 int  row =  ( int ) Math.round(Math.sqrt( 2  * number +  1 ));

Если нужны реальные "бесконечности" придётся int заменить на BigDecimal %)
...
Рейтинг: 0 / 0
14.04.2005, 15:05
    #33016158
Pitbull terrier
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
 public   class  CalcRow {
     public   static   void  main(String[] args) {
         if  (args.length ==  0 )
             return ;
         int  symbNum = Integer.parseInt(args[ 0 ]);
         int  rowNum =  1 ;
         int  symbsCount =  0 ;
         while  (true) {
            symbsCount += rowNum;
             if  (symbsCount > symbNum) {
                System.out.println("Row is: " + rowNum);
                 return ;
            }
            rowNum++;
        }
    }
}

так проще
...
Рейтинг: 0 / 0
14.04.2005, 15:16
    #33016198
Pitbull terrier
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
торможу
NotGonnaGetUs жжот
...
Рейтинг: 0 / 0
14.04.2005, 15:22
    #33016212
wessen
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
задача
Pitbull terrierторможу
NotGonnaGetUs жжот
это точно
...
Рейтинг: 0 / 0
Форумы / Java [игнор отключен] [закрыт для гостей] / задача / 9 сообщений из 9, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]