亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? chap25.lst

?? 《C語(yǔ)言大全(第四版)》
?? LST
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
listing 1
#define MAX 100

/* structure of the flight database */
struct FL {
  char from[20];
  char to[20];
  int distance;
  char skip;  /* used in backtracking */
};

struct FL flight[MAX];  /* array of db structures */

int f_pos = 0;    /* number of entries in flight db */
int find_pos = 0; /* index for searching flight db */

listing 2
void setup(void)
{
  assert_flight("New York", "Chicago", 1000);
  assert_flight("Chicago", "Denver", 1000);
  assert_flight("New York", "Toronto", 800);
  assert_flight("New York", "Denver", 1900);
  assert_flight("Toronto", "Calgary", 1500);
  assert_flight("Toronto", "Los Angeles", 1800);
  assert_flight("Toronto", "Chicago", 500);
  assert_flight("Denver", "Urbana", 1000);
  assert_flight("Denver", "Houston", 1500);
  assert_flight("Houston", "Los Angeles", 1500);
  assert_flight("Denver", "Los Angeles", 1000);
}

/* Put facts into the database. */
void assert_flight(char *from, char *to, int dist)
{
  if(f_pos < MAX) {
    strcpy(flight[f_pos].from, from);
    strcpy(flight[f_pos].to, to);
    flight[f_pos].distance = dist;
    flight[f_pos].skip = 0;
    f_pos++;
  }
  else printf("Flight database full.\n");
}

listing 3
/* If flight between from and to, then return
   the distance of flight; otherwise, return 0. */
int match(char *from, char *to)
{
  register int t;

  for(t=f_pos-1; t > -1; t--)
    if(!strcmp(flight[t].from, from) &&
      !strcmp(flight[t].to, to)) return flight[t].distance;

  return 0;  /* not found */
}

listing 4
/* Given from, find anywhere. */
int find(char *from, char *anywhere)
{
  find_pos = 0;
  while(find_pos < f_pos) {
    if(!strcmp(flight[find_pos].from, from) &&
      !flight[find_pos].skip) {
        strcpy(anywhere, flight[find_pos].to);
        flight[find_pos].skip = 1; /* make active */
        return flight[find_pos].distance;
    }
    find_pos++;
  }
  return 0;
}

listing 5
/* Stack Routines */
void push(char *from, char *to, int dist)
{
  if(tos < MAX) {
    strcpy(bt_stack[tos].from, from);
    strcpy(bt_stack[tos].to, to);
    bt_stack[tos].dist = dist;
    tos++;
  }
  else printf("Stack full.\n");
}

void pop(char *from, char *to, int *dist)
{
  if(tos > 0) {
    tos--;
    strcpy(from, bt_stack[tos].from);
    strcpy(to, bt_stack[tos].to);
    *dist = bt_stack[tos].dist;
  }
  else printf("Stack underflow.\n");
}

listing 6
/* Determine if there is a route between from and to. */
void isflight(char *from, char *to)
{
  int d, dist;
  char anywhere[20];

  /* see if at destination */
  if(d=match(from, to)) {
    push(from, to, d);
    return;
  }

  /* try another connection */
  if(dist=find(from, anywhere)) {
    push(from, to, dist);
    isflight(anywhere, to);
  }
  else if(tos > 0) {
    /* backtrack */
    pop(from, to, &dist);
    isflight(from, to);
  }
}

listing 7
/* Show the route and total distance. */
void route(char *to)
{
  int dist, t;

  dist = 0;
  t = 0;
  while(t < tos) {
    printf("%s to ", bt_stack[t].from);
    dist += bt_stack[t].dist;
    t++;
  }
  printf("%s\n", to);
  printf("Distance is %d.\n", dist);
}

listing 8
/* Depth-first search. */
#include <stdio.h>
#include <string.h>

 #define MAX 100

/* structure of the flight database */
struct FL {
  char from[20];
  char to[20];
  int distance;
  char skip; /* used in backtracking */
};

struct FL flight[MAX]; /* array of db structures */

int f_pos = 0;    /* number of entries in flight db */
int find_pos = 0; /* index for searching flight db */
int tos = 0;      /* top of stack */
struct stack {
  char from[20];
  char to[20];
  int dist;
} ;
struct stack bt_stack[MAX]; /* backtrack stack */

void setup(void), route(char *to);
void assert_flight(char *from, char *to, int dist);
void push(char *from, char *to, int dist);
void pop(char *from, char *to, int *dist);
void isflight(char *from, char *to);
int find(char *from, char *anywhere);
int match(char *from, char *to);

int main(void)
{
  char from[20], to[20];

  setup();

  printf("From? ");
  gets(from);
  printf("To? ");
  gets(to);

  isflight(from,to);
  route(to);

  return 0;
}

/* Initialize the flight database. */
void setup(void)
{
  assert_flight("New York", "Chicago", 1000);
  assert_flight("Chicago", "Denver", 1000);
  assert_flight("New York", "Toronto", 800);
  assert_flight("New York", "Denver", 1900);
  assert_flight("Toronto", "Calgary", 1500);
  assert_flight("Toronto", "Los Angeles", 1800);
  assert_flight("Toronto", "Chicago", 500);
  assert_flight("Denver", "Urbana", 1000);
  assert_flight("Denver", "Houston", 1500);
  assert_flight("Houston", "Los Angeles", 1500);
  assert_flight("Denver", "Los Angeles", 1000);
}

/* Put facts into the database. */
void assert_flight(char *from, char *to, int dist)
{

  if(f_pos < MAX) {
    strcpy(flight[f_pos].from, from);
    strcpy(flight[f_pos].to, to);
    flight[f_pos].distance = dist;
    flight[f_pos].skip = 0;
    f_pos++;
  }
  else printf("Flight database full.\n");
}

/* Show the route and total distance. */
void route(char *to)

{
  int dist, t;

  dist = 0;
  t = 0;
  while(t < tos) {
    printf("%s to ", bt_stack[t].from);
    dist += bt_stack[t].dist;
    t++;
  }
  printf("%s\n", to);
  printf("Distance is %d.\n", dist);
}

/* If flight between from and to, then return
   the distance of flight; otherwise, return 0. */
int match(char *from, char *to)
{
  register int t;

  for(t=f_pos-1; t > -1; t--)
    if(!strcmp(flight[t].from, from) &&
      !strcmp(flight[t].to, to)) return flight[t].distance;

  return 0; /* not found */
}

/* Given from, find anywhere. */
int find(char *from, char *anywhere)
{
  find_pos = 0;
  while(find_pos < f_pos) {
    if(!strcmp(flight[find_pos].from,from) &&
      !flight[find_pos].skip) {
        strcpy(anywhere,flight[find_pos].to);
        flight[find_pos].skip = 1; /* make active */
        return flight[find_pos].distance;
      }
    find_pos++;
  }
  return 0;
}

/* Determine if there is a route between from and to. */
void isflight(char *from, char *to)
{
  int d, dist;
  char anywhere[20];

  /* see if at destination */
  if(d=match(from, to)) {
    push(from, to, d);
    return;
  }
  /* try another connection */
  if(dist=find(from, anywhere)) {
    push(from, to, dist);
    isflight(anywhere, to);
  }
  else if(tos > 0) {
    /* backtrack */
    pop(from, to, &dist);
    isflight(from, to);
  }
}

/* Stack Routines */
void push(char *from, char *to, int dist)
{
  if(tos < MAX) {
    strcpy(bt_stack[tos].from,from);
    strcpy(bt_stack[tos].to,to);
    bt_stack[tos].dist = dist;
    tos++;
  }
  else printf("Stack full.\n");
}

void pop(char *from, char *to, int *dist)
{
  if(tos > 0) {
    tos--;
    strcpy(from,bt_stack[tos].from);
    strcpy(to,bt_stack[tos].to);
    *dist = bt_stack[tos].dist;
  }
  else printf("Stack underflow.\n");
}

listing 9
void isflight(char *from, char *to)
{
  int d, dist;
  char anywhere[20];

  while(dist=find(from, anywhere)) {
    /* breadth-first modification */
    if(d=match(anywhere, to)) {
      push(from, to, dist);
      push(anywhere, to, d);
      return;
    }
  }
  /* try any connection */
  if(dist=find(from, anywhere)) {
    push(from, to, dist);
    isflight(anywhere, to);
  }
  else if(tos>0) {
    pop(from, to, &dist);
    isflight(from, to);
  }
}

listing 10
/* Given from, find the farthest away "anywhere". */
int find(char *from, char *anywhere)
{
  int pos, dist;

  pos=dist = 0;
  find_pos = 0;

  while(find_pos < f_pos) {
    if(!strcmp(flight[find_pos].from, from) &&
      !flight[find_pos].skip) {
        if(flight[find_pos].distance>dist) {
        pos = find_pos;
        dist = flight[find_pos].distance;
      }
    }
    find_pos++;
  }
  if(pos) {
    strcpy(anywhere, flight[pos].to);
    flight[pos].skip = 1;
    return flight[pos].distance;
  }
  return 0;
}

listing 11
/* Hill-climbing */
#include <stdio.h>
#include <string.h>

 #define MAX 100

/* structure of the flight database */
struct FL {
  char from[20];
  char to[20];
  int distance;
  char skip; /* used for backtracking */
};

struct FL flight[MAX];  /* array of db structures */

int f_pos = 0;    /* number of entries in flight db */
int find_pos = 0; /* index for searching flight db */

int tos = 0;      /* top of stack */
struct stack {
  char from[20];
  char to[20];
  int dist;
} ;

struct stack bt_stack[MAX]; /* backtrack stack */

void setup(void), route(char *to);
void assert_flight(char *from, char *to, int dist);
void push(char *from, char *to, int dist);
void pop(char *from, char *to, int *dist);
void isflight(char *from, char *to);
int find(char *from, char *anywhere);
int match(char *from, char *to);

int main(void)
{
  char from[20], to[20];

  setup();

  printf("From? ");
  gets(from);
  printf("To? ");
  gets(to);

  isflight(from,to);
  route(to);

  return 0;
}

/* Initialize the flight database. */
void setup(void)
{
  assert_flight("New York", "Chicago", 1000);
  assert_flight("Chicago", "Denver", 1000);
  assert_flight("New York", "Toronto", 800);
  assert_flight("New York", "Denver", 1900);
  assert_flight("Toronto", "Calgary", 1500);
  assert_flight("Toronto", "Los Angeles", 1800);
  assert_flight("Toronto", "Chicago", 500);
  assert_flight("Denver", "Urbana", 1000);
  assert_flight("Denver", "Houston", 1500);
  assert_flight("Houston", "Los Angeles", 1500);
  assert_flight("Denver", "Los Angeles", 1000);
}

/* Put facts into the database. */
void assert_flight(char *from, char *to, int dist)
{

  if(f_pos < MAX) {
    strcpy(flight[f_pos].from, from);
    strcpy(flight[f_pos].to, to);
    flight[f_pos].distance = dist;
    flight[f_pos].skip = 0;
    f_pos++;
  }
  else printf("Flight database full.\n");
}

/* Show the route and the total distance. */
void route(char *to)
{
  int dist, t;

  dist = 0;
  t = 0;
  while(t < tos) {
    printf("%s to ", bt_stack[t].from);
    dist += bt_stack[t].dist;
    t++;
  }
  printf("%s\n", to);
  printf("Distance is %d.\n", dist);
}

/* If flight between from and to, then return
   the distance of flight; otherwise, return 0. */
int match(char *from, char *to)
{
  register int t;

  for(t=f_pos-1; t > -1; t--)
    if(!strcmp(flight[t].from, from) &&
      !strcmp(flight[t].to, to)) return flight[t].distance;

  return 0;  /* not found */
}

/* Given from, find the farthest away "anywhere". */
int find(char *from, char *anywhere)
{
  int pos, dist;

  pos=dist = 0;
  find_pos = 0;

  while(find_pos < f_pos) {
    if(!strcmp(flight[find_pos].from, from) &&
      !flight[find_pos].skip) {
        if(flight[find_pos].distance>dist) {
          pos = find_pos;
          dist = flight[find_pos].distance;
        }
    }
    find_pos++;
  }
  if(pos) {
    strcpy(anywhere, flight[pos].to);
    flight[pos].skip = 1;
    return flight[pos].distance;
  }
  return 0;
}

/* Determine if there is a route between from and to. */
void isflight(char *from, char *to)
{
  int d, dist;
  char anywhere[20];

  if(d=match(from, to)) {
    /* is goal */
    push(from, to, d);
    return;
  }

  /* find any connection */
  if(dist=find(from, anywhere)) {
    push(from, to, dist);
    isflight(anywhere, to);
  }
  else if(tos > 0) {
    pop(from, to, &dist);
    isflight(from, to);
  }
}

/* Stack Routines */
void push(char *from, char *to, int dist)
{
  if(tos < MAX) {
    strcpy(bt_stack[tos].from, from);
    strcpy(bt_stack[tos].to, to);
    bt_stack[tos].dist = dist;
    tos++;
  }
  else printf("Stack full.\n");
}

void pop(char *from, char *to, int *dist)
{
  if(tos > 0) {
    tos--;
    strcpy(from, bt_stack[tos].from);
    strcpy(to, bt_stack[tos].to);
    *dist = bt_stack[tos].dist;
  }
  else printf("Stack underflow.\n");
}

listing 12
/* Find closest "anywhere". */
int find(char *from, char *anywhere)
{
  int pos, dist;

  pos = 0;
  dist = 32000;  /* larger than the longest route */
  find_pos = 0;

  while(find_pos < f_pos) {
    if(!strcmp(flight[find_pos].from, from) &&
      !flight[find_pos].skip) {
        if(flight[find_pos].distance<dist) {
        pos = find_pos;
        dist = flight[find_pos].distance;
      }
    }
    find_pos++;
  }
  if(pos) {
    strcpy(anywhere, flight[pos].to);
    flight[pos].skip = 1;
    return flight[pos].distance;
  }
  return 0;
}

listing 13
int main(void)
{
  char from[20], to[20];

  setup();

  printf("From? ");
  gets(from);
  printf("To? ");
  gets(to);
  do {
    isflight(from, to);
    route(to);
    tos = 0;  /* reset the backtrack stack */
  } while(getchar() != 'q');

  return 0;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久激情五月婷婷| 欧美精品一区二区高清在线观看| 欧美日韩在线观看一区二区| 337p亚洲精品色噜噜噜| 久久久久一区二区三区四区| 亚洲啪啪综合av一区二区三区| 亚洲电影一级黄| 精品亚洲成a人| 亚洲欧美视频一区| 欧美日韩激情一区二区| 欧美成人aa大片| 国产精品素人视频| 亚洲第一福利视频在线| 国产一区二区视频在线播放| 欧美自拍偷拍午夜视频| 欧美videos大乳护士334| 国产精品久久二区二区| 日韩电影在线一区二区| 成人精品gif动图一区| 在线综合视频播放| 国产精品伦一区二区三级视频| 天天亚洲美女在线视频| 成人av在线影院| 日韩欧美高清dvd碟片| 免费久久精品视频| 99国产精品国产精品毛片| 日韩精品中午字幕| 亚洲尤物视频在线| 国产成人aaa| 日韩亚洲欧美成人一区| 亚洲色图制服丝袜| 国产精品资源在线看| 7777精品伊人久久久大香线蕉超级流畅| 国产精品乱人伦中文| 久久国产人妖系列| 欧美日韩亚州综合| 国产精品久久久久久久久免费丝袜 | 欧美色成人综合| 久久蜜臀精品av| 日本中文字幕一区二区有限公司| 99在线视频精品| 精品国产乱码久久久久久牛牛| 亚洲一级二级三级| aaa国产一区| 亚洲国产精品黑人久久久| 秋霞午夜鲁丝一区二区老狼| 在线免费观看日本一区| 国产精品久久午夜| 国产成人在线观看| 精品国产乱码久久久久久浪潮| 日韩电影在线一区| 欧美在线短视频| 亚洲欧美一区二区三区久本道91| 国产激情一区二区三区桃花岛亚洲| 日韩视频一区二区三区在线播放| 亚洲国产精品久久人人爱| 色婷婷国产精品久久包臀| 日韩美女视频19| 91污在线观看| 亚洲欧美另类小说视频| 国产精品无遮挡| 国产99精品国产| 中文字幕欧美三区| 国产美女久久久久| 久久久午夜精品| 国产激情一区二区三区桃花岛亚洲| 久久综合中文字幕| 久草这里只有精品视频| 精品噜噜噜噜久久久久久久久试看 | 欧美日韩一区二区三区在线看 | 国产成人午夜精品5599 | 国产一区二区三区在线观看精品| 欧美一二三在线| 肉色丝袜一区二区| 欧美日韩第一区日日骚| 婷婷丁香久久五月婷婷| 欧美日韩mp4| 男人的天堂久久精品| 欧美一区二视频| 九九在线精品视频| 久久亚洲一区二区三区四区| 国产真实精品久久二三区| 国产日韩欧美精品综合| 国产精品亚洲一区二区三区妖精 | 一本久道久久综合中文字幕| 亚洲视频一区二区在线| 91久久精品一区二区二区| 亚洲永久免费视频| 欧美精品黑人性xxxx| 免费欧美日韩国产三级电影| 26uuu精品一区二区三区四区在线| 国产一区二区按摩在线观看| 中文字幕成人av| 日本精品一区二区三区四区的功能| 亚洲成人一二三| 欧美v亚洲v综合ⅴ国产v| 国产成a人无v码亚洲福利| 综合久久国产九一剧情麻豆| 欧美日韩国产精品自在自线| 久久99精品久久久久| 国产精品久久久久久久久免费樱桃 | 国产精品欧美经典| 91浏览器打开| 三级久久三级久久| 久久久蜜臀国产一区二区| 91美女在线观看| 日韩精品欧美成人高清一区二区| 精品久久久久久久久久久久久久久久久 | 亚洲精品在线电影| 国产河南妇女毛片精品久久久| 国产精品日产欧美久久久久| 欧美色图激情小说| 精品伊人久久久久7777人| 国产精品乱码久久久久久| 欧美午夜精品久久久久久超碰| 男人的j进女人的j一区| 国产免费成人在线视频| 精品视频在线看| 国产乱码精品一区二区三区忘忧草 | 国产美女视频一区| 亚洲裸体xxx| 日韩视频一区二区三区在线播放 | 亚洲天堂av一区| 日韩一区和二区| av资源网一区| 久久精品国产99国产| 亚洲欧美国产毛片在线| 欧美成人激情免费网| 色综合久久久网| 国产精品一区二区男女羞羞无遮挡 | 丁香婷婷综合色啪| 丝袜亚洲另类欧美| 国产欧美一区二区精品忘忧草 | 在线播放视频一区| 成人午夜碰碰视频| 日本不卡高清视频| 一区二区三区在线播| 久久老女人爱爱| 欧美精品乱码久久久久久按摩| av色综合久久天堂av综合| 加勒比av一区二区| 亚洲一区二区在线观看视频| 国产精品久久久爽爽爽麻豆色哟哟| 日韩视频在线一区二区| 在线亚洲高清视频| 成人听书哪个软件好| 久久国产精品99久久久久久老狼| 亚洲精品福利视频网站| 国产精品久久久久久久久久免费看 | 亚洲国产成人porn| 中文字幕在线观看不卡| 精品国产99国产精品| 欧美日韩精品一区视频| 色综合色综合色综合色综合色综合 | 欧美一级搡bbbb搡bbbb| 色激情天天射综合网| 99视频一区二区三区| 国产精品伊人色| 久久机这里只有精品| 欧美a级一区二区| 亚洲国产精品久久人人爱| 亚洲男人天堂av网| 日本一二三不卡| 国产欧美一区二区在线| 精品久久久久久久久久久久久久久| 在线不卡免费欧美| 欧美探花视频资源| 一本大道久久a久久精品综合| av男人天堂一区| 97久久精品人人做人人爽50路| 国产91精品入口| 国产成人高清视频| 国产麻豆成人精品| 国产一区亚洲一区| 精品午夜久久福利影院| 国产综合久久久久影院| 国产综合色产在线精品| 国产专区欧美精品| 国产精品综合一区二区| 国产一区二区三区在线看麻豆| 九色综合国产一区二区三区| 激情欧美一区二区三区在线观看| 久久er99精品| 极品尤物av久久免费看| 国产一区二区0| 国产成人高清在线| 99久久精品国产精品久久| 91在线视频在线| 在线免费观看成人短视频| 在线观看视频一区| 欧美日韩日日骚| 日韩一卡二卡三卡四卡| 精品国产自在久精品国产| 久久久久久久久伊人| 国产精品免费人成网站| 中文字幕亚洲在| 亚洲国产wwwccc36天堂| 奇米四色…亚洲| 国产一区欧美一区| 成人深夜福利app|