青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

麒麟子

~~

導航

<2008年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

統計

常用鏈接

留言簿(12)

隨筆分類

隨筆檔案

Friends

WebSites

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

[導入]網易程序筆試題

題目如下:

21     22    23    24    25    26

20     7      8      9      10    27

19     6      1      2      11    28

18     5      4      3      12    29

17    16     15    14    13    30

    如圖:設“1”的坐標為(0,0) “7”的坐標為(-1,-1) 編寫一個小程序,使程序做到輸入坐標(X,Y)之后顯示出相應的數字。我的程序,沒有怎么調整,很粗糙,不過,實現就行了:#include <iostream>

using namespace std;

/* 

設“1”的坐標為(0,0) “7”的坐標為(-1,-1) 編寫一個小程序,

使程序做到輸入坐標(X,Y)之后顯示出相應的數字。

*/

/************************************************************************

**算法:數字是圍繞1“盤旋”, 移動的步進值是1,1,2,2,3,3,4,4,5,5,6,6……

**對于一個數,我們可以算出他移動的步數,然后和一個沒有走完的偏移,如果恰好走完就是

**偏移為0。

**然后我們對于輸入的值,我們模擬走過的路徑來求值,步數表示已經走過而偏移表示要繼續

**走偏移數目的步數

*************************************************************************/

enum X {RIGHT = 1, DOWM = 1,LEFT = -1, UP = -1};

/*

*get_attribution()函數取得輸入值移動過幾次用times表示,

*以及比每次移動的終點要多走的步數,用dif表示

*/

void get_attribution(int in_number, int &dif, int ×) {

    int i = 0;

     in_number--;

    while (in_number >= 0) {

         in_number = in_number - (i/2+1);

         times = i;

         i++;

        if (in_number >= 0) {

             dif = in_number;

         }

     }

}

int main()

{

    int a = 21; //輸入一個數值,這里就不人機交互輸入了

    int dif = 0, times = 0; // 起始偏移距離和次數

     get_attribution(a, dif, times);

     cout << "偏移" << dif << "中間走了" << times << "次" << endl;

    int x = 0, y = 0; //起始端點

    for (int i = 1; i <= times; i++) {

        switch (i%4) { //已經走過了一些步數

            case 0: //上移到下一個端點

                 y += UP *((i-1)/2+1);                   break;

            case 1: //右移到下一個端點

                 x += RIGHT * ((i-1)/2+1);               break;

            case 2: //下移到下一個端點

                 y += DOWM * ((i-1)/2+1);                break;

            case 3: //左移到下一個端點

                 x += LEFT * ((i-1)/2+1);                break;

         }

     }

    switch (times%4) { //繼續完成要偏移的值

        case 3: //接下來的操作是上移,x不變,y減小

             y += UP * dif;              break;

        case 0: //接下來的操作是右移

             x += RIGHT * dif;           break;

        case 1: //接下來的操作是下移

             y += DOWM * dif;            break;

        case 2: //接下來的操作是左移

             x += LEFT * dif;            break;

     }

     cout << "("   <<   x << ", " << y << ")" << endl;

    return 0;

}

作者給出了自己的程序,太長我就引用了,也給出了人家的程序 ,挺不錯,如下:#include <iostream>

#include <conio.h>

#include <math.h>

using namespace std;

int newVal(int x, int y)

{

    //以結點1為原點

    //以相鄰兩結點間的距離為單位(如結點2與結點3的之間線段)

    //結點7所在的正方形(由結點2、3、4、5、6、7、8、9構成)的邊長

    //的一半為1,即結點7到原點1的最大投影距離為1。

    //于是由結點坐標,可以求出此結點所在的正方形的投影距離:

    int r = max(abs(x),abs(y));    

    

    //進行坐標變換,即把坐標原點移動到正方形的一個角結點上,

    //使整個正方形落在第一象限,例如,當r=1時,將把坐標原點從結點1

    //移動到結點7。

     x += r;

     y += r;

    //正方形的邊長,等于投影距離的兩倍

    int d = 2*r;

    int s;    //s為結點在自己的正方形的偏移量

    if (y == 0)

         s = 3*d + x;

    else if (x == 0)

         s = 2*d + (d-y);

    else if (y == d)

         s = d + (d-x);

    else

         s = y;

    //pow((r+1),2)為內層的結點數。

    //例如,結點10的內層由結點1和正方形A(2、3、4、5、7、8、10)構成

    //這些內層的總結點數恰為:(正方形A的邊長+1)的平方,

    //因為:正方形A的邊長 =(結點10所在正方形的半徑-1)*2

    //故:內層結點數 = (結點10所在正方形的邊長-1)的平方

   //結點值 = 在當前正方形的偏移量 + 內層的結點數

     s += pow((d-1),2);

    return s;

}

int main(int argc,char * argv[])

{

    int x, y;

     cout <<"請輸入坐標(x y):";

    while (cin>>x>>y)

     {

     cout <<"坐標所在的結點值為:"<<f(x, y)<<endl;

     cout <<"請輸入坐標(x y):";

     }

    return 0;

}

 

----------------------------------------------------------------------------------------------------------------------------------

這是我寫的,算法請看二樓

#include<stdio.h>

int GetX(int x)//求(X,0)
   {
    int result=1,i=0;
    if (x==0) return result;
    else if (x>0)
    {
        for(i=0;i<x;i++)
        {
            result = result + 1+8*i;//通項公試. a(n) = a(n-1) + a(0) + d*(n-1)
        }
        return result;
     }
     else if(x<0)
     {
        for(i=0;i<-x;i++)
        {
            result = result + 5+8*i;
        }
        return result;
     }
}
int GetY(int y)//求(0,Y)
{
    int result=1,i=0;
    if (y==0) return result;
    else if (y>0)
    {
        for(i=0;i<y;i++)
        {
            result = result + 7+8*i;
        }
        return result;
     }
     else if(y<0)
     {
        for(i=0;i<-y;i++)
        {
            result = result + 3+8*i;
        }
        return result;
     }
}
int GetNum(int x,int y)//求(X,Y)對應的值
{
    if(abs(x)<=abs(y))
    {
        if(y<=0)
        return GetY(y)+x;
        else return GetY(y)-x;
     }
    else
    {
        if(x<=0)
        return GetX(x)-y;
        else return GetX(x)+y;
    }

}
       
void main()
{
    int x,y;
    while(1)
    {
    printf("please input (X,Y)\n");
    scanf("%d,%d",&x,&y);
    printf("The result is:%d\n",GetNum(x,y));
    }
    getch();

}


文章來源:http://ly-weiwei.blog.163.com/blog/static/72975283200811281154738

posted on 2008-12-28 01:15 麒麟子 閱讀(150) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美jizz19性欧美| 久久欧美中文字幕| 亚洲黄网站在线观看| 久久久久久有精品国产| 精品动漫3d一区二区三区免费版| 免费不卡在线观看av| 久久久久久久成人| 亚洲区免费影片| 亚洲精品久久在线| 国产精品午夜春色av| 欧美自拍偷拍午夜视频| 久久久亚洲国产美女国产盗摄| 亚洲国产精品一区二区三区| 亚洲欧洲另类国产综合| 国产精品户外野外| 麻豆国产精品一区二区三区| 欧美高清视频一区二区三区在线观看 | 亚洲在线播放电影| 午夜国产精品视频免费体验区| 伊甸园精品99久久久久久| 亚洲国产日韩精品| 国产农村妇女精品一二区| 欧美黄色一区二区| 国产精品久久久久久久久久三级| 久久久亚洲人| 欧美视频在线一区二区三区| 老司机久久99久久精品播放免费 | 国产婷婷色一区二区三区在线| 老司机免费视频一区二区三区| 欧美日韩国产小视频| 欧美在线首页| 欧美日韩国产成人精品| 久久综合九色综合欧美就去吻| 欧美理论电影在线播放| 久久综合狠狠综合久久综合88| 国产精品videosex极品| 欧美sm重口味系列视频在线观看| 国产精品久久久久999| 欧美风情在线观看| 国产一区二区三区直播精品电影 | 久久精品123| 欧美日韩成人网| 麻豆国产精品va在线观看不卡 | 久久久久欧美精品| 亚洲欧美中文日韩v在线观看| 欧美freesex交免费视频| 久久国产精品亚洲77777| 欧美午夜片在线免费观看| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲国产乱码最新视频| 激情久久综艺| 欧美一级视频| 香蕉成人伊视频在线观看| 欧美日韩一区在线| 亚洲精品欧美激情| 亚洲欧美日韩成人高清在线一区| 99精品欧美一区二区蜜桃免费| 欧美日韩国产高清视频| 久久午夜国产精品| 国产欧美综合一区二区三区| 亚洲综合视频一区| 国产午夜精品视频| 一区二区三区毛片| 一区二区三区欧美在线观看| 欧美成人综合一区| 欧美激情一区二区三区在线视频| 在线观看日韩一区| 久久亚洲精选| 亚洲高清一二三区| 亚洲激情在线播放| 欧美精品亚洲二区| 99国产精品久久| 亚洲欧美日韩在线一区| 国产精一区二区三区| 香港成人在线视频| 久久一区二区三区超碰国产精品| 黄色工厂这里只有精品| 久久男人资源视频| 亚洲国产成人精品女人久久久| 日韩视频在线免费观看| 欧美日韩精品一区二区在线播放| 日韩视频中文| 正在播放日韩| 久久在线精品| 欧美国产精品久久| 在线视频观看日韩| 欧美精品在线免费观看| 亚洲精品乱码久久久久久黑人| 亚洲精品国偷自产在线99热| 欧美精品一区二区三区蜜桃| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲网站在线看| 国产精品一区二区欧美| 久久婷婷国产综合尤物精品| 亚洲国产日韩欧美一区二区三区| 亚洲视频免费在线| 国产一区二区视频在线观看 | 欧美一区二区三区在线观看| 国内精品视频在线播放| 欧美精品1区2区| 国产在线高清精品| 欧美电影免费观看大全| 一本久道综合久久精品| 久久久视频精品| 一区二区欧美在线观看| 国产综合久久久久影院| 欧美久久99| 久久成年人视频| 日韩亚洲综合在线| 久久免费高清视频| 亚洲女人天堂成人av在线| 亚洲成在人线av| 国产精品私拍pans大尺度在线| 久久亚洲国产精品一区二区 | 欧美成人免费va影院高清| 亚洲欧美日韩区| 亚洲精品欧美在线| 国产一区免费视频| 国产精品高潮粉嫩av| 欧美freesex8一10精品| 久久精品夜色噜噜亚洲a∨| 99v久久综合狠狠综合久久| 欧美成在线视频| 久久久99爱| 性色av一区二区三区| 一区二区三区高清在线观看| 在线观看成人小视频| 国产视频丨精品|在线观看| 国产精品福利片| 欧美私人网站| 欧美理论大片| 欧美精品在线观看播放| 欧美成人网在线| 米奇777在线欧美播放| 久久国产99| 中文日韩电影网站| 日韩午夜av| 日韩视频永久免费观看| 亚洲激情视频在线观看| 亚洲国产精品va| 亚洲国产专区校园欧美| 在线播放国产一区中文字幕剧情欧美 | 久久久视频精品| 久久久99精品免费观看不卡| 久久精品一区二区三区中文字幕| 欧美一区二区私人影院日本| 性色一区二区| 久久人人爽爽爽人久久久| 久久亚洲私人国产精品va| 久久综合色婷婷| 欧美激情视频网站| 欧美美女bbbb| 欧美色大人视频| 国产精品一区二区三区久久| 国产精品一区二区在线观看网站 | 国产一区二区精品久久99| 国产亚洲福利一区| 极品少妇一区二区三区精品视频| 激情小说另类小说亚洲欧美| 亚洲第一二三四五区| 亚洲国产欧美在线人成| 99综合在线| 欧美一区二区三区在线观看| 卡通动漫国产精品| 亚洲国产精品毛片| 一区二区三区国产精华| 香蕉尹人综合在线观看| 老司机成人网| 欧美日韩亚洲国产一区| 国产人成精品一区二区三| 在线国产精品播放| 一二美女精品欧洲| 久久精品国产亚洲a| 亚洲承认在线| 亚洲一区二区三区免费视频| 久久久精品一品道一区| 欧美极品aⅴ影院| 国产欧美日韩免费| 亚洲欧洲一区二区三区久久| 亚洲男女自偷自拍图片另类| 免费日韩视频| 亚洲网站啪啪| 蜜桃av一区二区| 国产精品日韩专区| 亚洲精品欧美日韩专区| 欧美一二三视频| 亚洲日本中文字幕区| 久久成人免费电影| 欧美日韩美女在线| 亚洲午夜激情| 蘑菇福利视频一区播放| 国产区精品视频| 一区二区av| 欧美大片一区| 欧美亚洲视频一区二区| 欧美午夜理伦三级在线观看| 亚洲欧洲一区| 卡一卡二国产精品| 亚洲欧美一区二区三区在线| 欧美日韩专区在线|