- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下程序,它首先存储一些城市之间的直飞航类,然后使用DFS查询两个城市是否有间接航类连接。
程序在查询步骤中不断崩溃,因此我尝试使用 print 语句来查找问题,奇怪的是,当执行搜索的函数中有 print 语句时,程序不会崩溃。代码有什么问题?
(我正在使用代码:Blocks 13.12)
#include <stdio.h>
#include <stdlib.h>
#define MIN_SIZE 2
#define MAX_SIZE 10000
#define MIN_CON 1
#define FALSE 0
#define TRUE 1
//global variables
struct city** checked;
int* num_connect;
int n, found=0;
//Define a struct
struct city
{
//Declaration of struct members
int name;
struct city **connected; //array of all cities with direct flights to
};
int readCity(int n)
{
//Declaration of a variable
int city;
do
{
scanf("%d", &city);
}while(city<MIN_CON && city>n);
return city;
}
void addFlight(struct city *list, int orig, int dest)
{
//decl
int i=0;
int j=0;
//check if orig is in list
while(num_connect[i]!=0 && list[i].name!=orig)
{
i++;
}
//if it isnt add it
if (num_connect[i]==0)
{
list[i].name =orig;
list[i].connected = malloc((num_connect[i]+1)*sizeof(struct city*));
}
else
{
//reallocate memory to store additional flight connection
list[i].connected = realloc(list[i].connected, (num_connect[i]+1)*sizeof(struct city*));
}
num_connect[i]++;
//check if dest is in list
while(num_connect[j]!=0 && list[j].name!=dest)
{
j++;
}
//if it isnt add it
if (num_connect[j]==0)
{
list[j].name =dest;
list[j].connected = malloc((num_connect[j]+1)*sizeof(struct city*));
}
else
{
//reallocate memory to store additional flight connection
list[j].connected = realloc(list[j].connected, (num_connect[j]+1)*sizeof(struct city*));
}
num_connect[j]++;
//add b to a's connected and add b to a's connected
list[j].connected[num_connect[j]-1]=&list[i];
list[i].connected[num_connect[i]-1]=&list[j];
printf("JUST CONNECTED %d WITH %d\n", list[i].name, list[j].name);
}
int inChecked(struct city* c)
{
int i;
while(checked[i]!=c && i<n)
{
i++;
}
if (i==n)
{
return FALSE;
}
else
{
return TRUE;
}
}
void search_connection(struct city *list, int orig, int dest)
{
//decl
int i=0, k=0, j=0, p=0;
printf(" "); // <------------------------------------------------------------
//Find origin city in list
while(i<n && list[i].name!=orig)
{
i++;
}
//add to checked
while(checked[k]!=NULL)
{
k++;
}
checked[k]=&list[i];
//Check for 'dest' city in connected of origin
while(j<num_connect[i] && list[i].connected[j]->name!=dest)
{
j++;
}
//If-statement to determine if dest was found
if (j!=num_connect[i])
{
//Set 'found' to 1
found=1;
return;
}
else
{
//While not all connected have been checked and not found
while(p<num_connect[i] && found==0)
{
if (!inChecked(list[i].connected[p]))
{
//call method on it
search_connection(list, list[i].connected[p]->name, dest);
}
p++;
}
}
}
int main()
{
//Declaration of variables
int i, m;
int city_a, city_b, q_result;
//Read input
do
{
//printf("Enter number of cities:\n");
scanf("%d", &n);
}while(n<MIN_SIZE || n>MAX_SIZE);
//Declare an array of cities
struct city* cities;
//Allocate memory for array of 'n' cities
cities = malloc(n*sizeof(struct city)); // <---------------- FREE later!!!
//Allocate memory for array of 'n' pointers to cities
checked = calloc(n,sizeof(struct city*)); // <---------- FREE later!!!
//Allocate memory for array of 'n' integers
num_connect = calloc(n,sizeof(int)); // <------------ FREE later!!!
//Read input
do
{
//printf("Enter number of connections:\n");
scanf("%d", &m);
}while(n<MIN_SIZE || n>MAX_SIZE);
//For-loop to read connected cities
for (i=0; i<m; i++)
{
//Read two cities
city_a = readCity(n);
city_b = readCity(n);
//add flight connecting the two cities
addFlight(cities, city_a, city_b);
}
//Read connection to query
city_a = readCity(n);
city_b = readCity(n);
//Search for connection between the two cities by in-direct flight
search_connection(cities, city_a, city_b);
//Print results
if (found==1)
{
printf("Yes");
}
else
{
printf("No");
}
//Free up memory
// TO DO. . .
return 0;
}
最佳答案
在inChecked()
中,您永远不会初始化i
,因此您的函数将随机运行。如果该函数返回 false 的次数过多,稍后您的 checked
数组可能会溢出。
关于c - 为什么这个 print 语句可以阻止 C 程序崩溃?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29067941/
我已经和 Lua 搞了几天,我想出了一些让我三思而后行的事情。 Lua 5.3 的引用手册我还没有看,因为它似乎很复杂,我会尽快查看。 好的,在 lua 5.3 中,我们知道 print() 返回 n
计算时IO (IO ()) , 两个 (IO ())和 ()是计算出来的,所以为什么 main :: IO (IO ()) main = print (print "Hello, World!")
我不太理解从以下位置收到的输出: print(print(print('aaa'))) aaa None None 先aaa清楚了。但我认为第二个 print(aaa) 会抛出一个错误,因为变量 aa
当我运行下面的 Perl one-liner 时,它会打印 1在每一行的前面,我不想要它。它应该做的只是注释匹配 root 的行. $ cat /etc/passwd | perl -ne 'prin
我发现由于 Xcode 将不再消化 println() 我是 留下 Swift.print() 或 print() 。我的问题是, 两者有什么区别?我没能 在网上或在 swift 前卫郎。 (Swif
我正在开发一个内部 Google Chrome 扩展,它需要一种方法来启动将当前页面打印到打印机。我不希望出现默认的打印对话框(因此,javascript:window.print() 是不可能的)。
我正在将 Perl6 Terminal::Print 模块用于基于控制台的应用程序。 它运行良好 - 但是,现在我需要提示用户输入一串文本。 有什么好的方法可以做到这一点? 最佳答案 这是使用 Ter
在学习第三方的Lua代码时,我发现在主脚本文件的顶部 local insert = table.insert local match = string.match local gsub = strin
在学习第三方的Lua代码时,我发现在主脚本文件的顶部 local insert = table.insert local match = string.match local gsub = strin
我目前正在学习 Python,并开始了一个项目,为 2000-2005 年 MLB 摊牌纸牌游戏创建棒球模拟游戏。这些程序包含棒球比赛的事件,作为单独代码段中间的打印语句(“Jeff 击中单打”,“B
我的问题:在没有多余括号的情况下漂亮地打印表达式的最干净的方法是什么? 我有以下 lambda 表达式的表示: Term ::= Fun(String x, Term t) | App(
为了在 Julia 中创建可打印的新类型,应该定义哪些方法?我认为应该只定义 show,然后它将引发其他函数的行为,例如: 打印 字符串 repl_show 显示紧凑 展示 需要为新类型定义以下哪些方
我有一个页面,用户可以在其中打印一些带有图像和数据的 pdf。我希望他们能够打印他们想要的文件数量,并且能够暂停它们——这意味着他们可以停止打印并防止打印尚未发送到打印机的文件;当然,已经发送到打印机
CLHS 说 An attempt to print a circular structure with *print-circle* set to nil may lead to looping
正如标题所示,在 Pycharm 中使用自动完成功能时,显示的唯一自动完成选项是:print(args,kwargs) 内置 我希望自动完成功能以“print”完成,因为这是我通常使用的。我正在使用
是否有可能使用 fmt.Println("...") 打印一个 shell 居中对齐的字符串? 最佳答案 作为对这个长期回答问题的更新,可以通过使用 fmt 包中的 * 符号来改进@miltonb 发
我想在控制台屏幕上显示使用 DO 循环完成的计算进度。我可以像这样将进度变量打印到终端: PROGRAM TextOverWrite_WithLoop IMPLICIT NONE INTEGER ::
我正在尝试为我的新对象定义打印方法,并使用传递给 print 的对象名称。使用 deparse(substitute(y)) .这可以完美地使用 print功能明确: obj function (x
我需要安装 dompdf 方面的帮助。我应该将解压的 zip 文件放在目录中的哪个位置?我按照 INSTALL.txt 进行操作,它显示“将下载的包的内容提取到支持的路径之一”。这是否意味着放入“Mo
我的应用程序中有一个 webkit 小部件,您可以打印它。打印效果很好,除了打印时没有图像,即使屏幕上有图像。 打印代码如下: void MainWindow::printPage() { Q
我是一名优秀的程序员,十分优秀!