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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? chap25.lst

?? These files contain all of the code listings in C: The Complete Reference, 4th Edition The so
?? LST
?? 第 1 頁 / 共 2 頁
字號:
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;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲污的网站| 国产精品毛片久久久久久久| 精品久久久影院| 国产精品亲子乱子伦xxxx裸| 天天爽夜夜爽夜夜爽精品视频| 懂色av一区二区三区蜜臀| 欧美日韩不卡一区二区| 中文字幕一区二区三区av| 免费成人在线影院| 日韩毛片高清在线播放| 99精品视频一区| 久久精品一区四区| 亚洲欧美福利一区二区| 国精产品一区一区三区mba视频| 色婷婷综合久久久久中文一区二区 | 婷婷中文字幕一区三区| 成人黄动漫网站免费app| 精品久久久久久久久久久久包黑料| 亚洲人成影院在线观看| 国产欧美日韩激情| 亚洲一区二区欧美日韩| 国产精品 欧美精品| 8v天堂国产在线一区二区| 国产精品久久久久三级| 东方欧美亚洲色图在线| 久久这里只有精品首页| 麻豆成人久久精品二区三区小说| 欧美系列日韩一区| 亚洲免费观看视频| 91啪亚洲精品| 国产精品国产成人国产三级| 成人午夜在线免费| 国产偷国产偷亚洲高清人白洁| 久久99国产精品麻豆| 日韩一区二区三区观看| 日韩高清在线不卡| 日韩激情在线观看| thepron国产精品| 日本一区二区久久| www.亚洲在线| 中文字幕一区二区三区精华液 | 91久久人澡人人添人人爽欧美| 国产精品麻豆欧美日韩ww| 成人一区二区视频| 国产精品色噜噜| 99视频精品在线| 亚洲免费观看高清完整版在线 | 91丨九色丨蝌蚪富婆spa| 国产精品久久久久影院亚瑟 | 99精品久久久久久| 亚洲精品国产精品乱码不99| 91九色02白丝porn| 亚洲电影一区二区三区| 欧美一级国产精品| 国产精品自产自拍| ...av二区三区久久精品| 色悠悠亚洲一区二区| 午夜伦理一区二区| www国产精品av| 93久久精品日日躁夜夜躁欧美| 亚瑟在线精品视频| 欧美精品一区二区在线播放| 成人av网站在线| 亚洲国产欧美在线人成| 2024国产精品| 色婷婷综合激情| 蜜臀久久99精品久久久画质超高清 | 91精品国产黑色紧身裤美女| 国产呦萝稀缺另类资源| 中文字幕日韩一区二区| 5月丁香婷婷综合| 成人短视频下载| 亚洲mv在线观看| 久久久精品欧美丰满| 91成人在线观看喷潮| 韩国女主播一区二区三区| 亚洲三级电影网站| 精品国产乱码久久久久久图片| av在线不卡观看免费观看| 天天综合网 天天综合色| 国产精品久久久久久妇女6080 | 精品一二三四区| 日韩理论电影院| 精品免费一区二区三区| 色偷偷成人一区二区三区91 | 日韩一区二区电影网| www.久久久久久久久| 久久99精品久久只有精品| 亚洲综合另类小说| 国产精品视频免费看| 日韩免费高清av| 欧美性受极品xxxx喷水| 成人深夜在线观看| 日本成人中文字幕在线视频| 亚洲精品中文在线| 欧美激情中文字幕| 久久色.com| 日韩精品一区二区三区swag | 国产成人精品网址| 男人的天堂久久精品| 夜夜嗨av一区二区三区中文字幕| 亚洲国产成人在线| 国产欧美日韩另类一区| 欧美一区二区三区视频在线观看| 欧美亚洲动漫精品| 91视频在线观看| 99re热这里只有精品免费视频| 风间由美一区二区三区在线观看| 久久精品国内一区二区三区| 午夜成人在线视频| 亚洲国产日韩a在线播放性色| 一区二区在线观看免费| 亚洲免费观看高清| 亚洲激情自拍视频| 亚洲男人的天堂一区二区| 婷婷久久综合九色综合绿巨人| 国产最新精品免费| 免费观看在线综合| 日韩在线一区二区三区| 亚洲第一电影网| 亚洲a一区二区| 午夜视频一区二区| 天堂va蜜桃一区二区三区漫画版| 亚洲国产成人av| 午夜视频一区二区| 青草av.久久免费一区| 美女看a上一区| 国产一区二区主播在线| 成人影视亚洲图片在线| 99精品久久99久久久久| 色av一区二区| 欧美老肥妇做.爰bbww视频| 4438x成人网最大色成网站| 欧美一区二区三区免费大片| 精品久久一区二区三区| 欧美激情一区二区三区不卡| 国产精品免费看片| 亚洲午夜电影在线| 日本不卡在线视频| 国产九色精品成人porny| bt7086福利一区国产| 91精品国产综合久久福利| 欧美日韩亚洲综合一区| 欧美人伦禁忌dvd放荡欲情| 欧美一级欧美三级| 国产日产欧产精品推荐色| 亚洲男人的天堂网| 日韩国产在线观看一区| 国产一区二区调教| 91九色02白丝porn| 日韩一卡二卡三卡四卡| 国产精品视频你懂的| 偷偷要91色婷婷| 成人性生交大片免费看中文 | 久久久久久免费网| 亚洲素人一区二区| 免费欧美在线视频| 99精品视频中文字幕| 日韩小视频在线观看专区| 国产精品美女一区二区三区 | 久久国产麻豆精品| 波多野结衣中文字幕一区| 777午夜精品免费视频| 国产日韩av一区| 欧美日本免费一区二区三区| 国产精品天美传媒| 亚洲午夜私人影院| 韩国欧美国产一区| 欧美亚洲日本一区| 国产欧美日韩在线| 日本欧美在线看| 91丝袜美女网| 久久久久久影视| 日本亚洲免费观看| 91成人在线免费观看| 日本一区二区电影| 美腿丝袜亚洲三区| 欧美日韩成人综合在线一区二区| 欧美国产日韩a欧美在线观看| 日韩电影网1区2区| 欧美天堂一区二区三区| 国产精品麻豆网站| 国产精品一线二线三线精华| 欧美一区二区三区在线看| 亚洲一级在线观看| 92精品国产成人观看免费 | 一区二区在线看| 国产精品影音先锋| 日韩欧美一级二级三级| 亚洲人午夜精品天堂一二香蕉| 国产福利一区二区| 精品成人佐山爱一区二区| 日本成人超碰在线观看| 欧美日韩不卡一区二区| 亚洲一区二区黄色| 在线观看网站黄不卡| 亚洲日本在线观看| 99久久99久久久精品齐齐| 亚洲国产精品99久久久久久久久| 国产在线一区观看|