- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
这段代码是大型源代码的一部分,但错误就在这里。
int solve(int* unsolved_var)
{
int i;
for (i = 0; unsolved_var[i] != 0; i++)
{
int n;
for (n = 1; n <= 9; n++)
{
//if (!numInBox(unsolved_var[i], n)==1 || !numInLine()==1)
printf("%d %d\n", n, unsolved_var[i]);
numInBox(unsolved_var[i], n);//ERROR OCCURS HERE
}
}
}
int numInBox(int space, int n)//space is always three digits long
{
printf("this should print but doesnt(segmentation fault)");
char unsolved_str[3];
sprintf(unsolved_str, "%d", space);//converts int into char[]
printf("%s",unsolved_str);//confirms
int check[3] = {atoi(unsolved_str[0]), 0, atoi(unsolved_str[2])};//converts char[] to int[]
完整代码...它运行良好。如果你输入 solve 那么我会抛出那个错误。
`#include <stdio.h>
#include <string.h>
char grid[20][42];
void display()
{
int j;
int u;
for (j = 0; j <= 19; j++)
{
for (u = 0; u <= 39; u++)
{
printf("%c",grid[j][u]);
}
printf("\n");
}
printf("\n");
}
int* unsolved()
{//2-18 4,8-36
int r;
int c;
int size = 0;
static int unsolved_var[81];
unsolved_var[0] = 0;
for (r = 2; r <= 18; r+=2)
{
for (c = 4; c <=36; c+=4)
{
if (grid[r][c] == ' ')
{
if (c <= 9)
{
unsolved_var[size] = r/2*100 + c/4;
size++;
unsolved_var[size] = 0;//sets end of array
}
else
{
unsolved_var[size] = r/2*100 + c/4;
size++;
unsolved_var[size] = 0;
}
// 100 1000 100 1000
//2-0-4 2-0-10 10-0-4 10-0-10
}
}
}
int p;
//for (p = 0; p <= size; p++){printf("%d", unsolved_var[p]);}
return unsolved_var;
}
int numInBox(int space, int n)
{
char unsolved_str[3];
sprintf(unsolved_str, "%d", space);
printf("%s",unsolved_str);
int check[3] = {atoi(unsolved_str[0]), 0, atoi(unsolved_str[2])};
}//***********************************************************************
static int x = 0;
int solve(int* unsolved_var)
{
if (unsolved_var[0] == 0 || x == 10){return 0;}
else
{
int i;
for (i = 0; unsolved_var[i] != 0; i++)
{
int n;
for (n = 1; n <= 9; n++)
{
//if (!numInBox(unsolved_var[i], n)==1 || !numInLine()==1)
printf("%d %d\n", n, unsolved_var[i]);//
numInBox(unsolved_var[i], n);
}
}
x++;
}
}
main()
{
//*****************************GRID******************************
//2 4 6 8 10 12 14 16 18
//3-5 7-9 11-13 15-17 19-21 23-25 27-29 31-33 35-37
char top[] = "\t 1 2 3 4 5 6 7 8 9 ";
char line0[] = "\t+---+---+---+---+---+---+---+---+---+";
char field1[]="1\t| | | | | | | | | |";
char line1[] = "\t+---+---+---+---+---+---+---+---+---+";
char field2[]="2\t| | | | | | | | | |";
char line2[] = "\t+---+---+---+---+---+---+---+---+---+";
char field3[]="3\t| | | | | | | | | |";
char line3[] = "\t+---+---+---+---+---+---+---+---+---+";
char field4[]="4\t| | | | | | | | | |";
char line4[] = "\t+---+---+---+---+---+---+---+---+---+";
char field5[]="5\t| | | | | | | | | |";
char line5[] = "\t+---+---+---+---+---+---+---+---+---+";
char field6[]="6\t| | | | | | | | | |";
char line6[] = "\t+---+---+---+---+---+---+---+---+---+";
char field7[]="7\t| | | | | | | | | |";
char line7[] = "\t+---+---+---+---+---+---+---+---+---+";
char field8[]="8\t| | | | | | | | | |";
char line8[] = "\t+---+---+---+---+---+---+---+---+---+";
char field9[]="9\t| | | | | | | | | |";
char line9[] = "\t+---+---+---+---+---+---+---+---+---+";
int o;
for (o = 0; o <= 39; o++)
{
grid[0][o] = top[o];
grid[1][o] = line0[o];
grid[2][o] = field1[o];
grid[3][o] = line1[o];
grid[4][o] = field2[o];
grid[5][o] = line2[o];
grid[6][o] = field3[o];
grid[7][o] = line3[o];
grid[8][o] = field4[o];
grid[9][o] = line4[o];
grid[10][o] = field5[o];
grid[11][o] = line5[o];
grid[12][o] = field6[o];
grid[13][o] = line6[o];
grid[14][o] = field7[o];
grid[15][o] = line7[o];
grid[16][o] = field8[o];
grid[17][o] = line8[o];
grid[18][o] = field9[o];
grid[19][o] = line9[o];
}
display();
//****************************INPUT******************************
while(1)
{
char input_raw[7];
printf("Enter a Command\n");
fgets(input_raw, 256, stdin);
input_raw[strlen(input_raw)-1] = '\0';
if (strcmp(input_raw, "solve") == 0){solve(unsolved());}
else
{
char *first = input_raw;
char *second = input_raw;
char *third = input_raw;
char *copy = input_raw;
int flag = 1;
while (*copy)
{
if (*copy == ',')
{
*copy = '\0';
if (flag==0) {third = ++copy;}
if (flag==1) {second = ++copy; flag = 0;}
}
else copy++;
}
switch (first[0])
{
case '1':
{
switch (second[0])
{
case '1':{grid[2][3] = '*'; grid[2][4]=third[0]; grid[2][5] = '*'; break;}
case '2':{grid[2][7] = '*'; grid[2][8]=third[0]; grid[2][9] = '*'; break;}
case '3':{grid[2][11] = '*';grid[2][12]=third[0];grid[2][13] = '*';break;}
case '4':{grid[2][15] = '*';grid[2][16]=third[0];grid[2][17] = '*';break;}
case '5':{grid[2][19] = '*';grid[2][20]=third[0];grid[2][21] = '*';break;}
case '6':{grid[2][23] = '*';grid[2][24]=third[0];grid[2][25] = '*';break;}
case '7':{grid[2][27] = '*';grid[2][28]=third[0];grid[2][29] = '*';break;}
case '8':{grid[2][31] = '*';grid[2][32]=third[0];grid[2][33] = '*';break;}
case '9':{grid[2][35] = '*';grid[2][36]=third[0];grid[2][37] = '*';break;}
}
break;
}
case '2':
{
switch (second[0])
{
case '1':{grid[4][3] = '*'; grid[4][4]=third[0]; grid[4][5] = '*'; break;}
case '2':{grid[4][7] = '*'; grid[4][8]=third[0]; grid[4][9] = '*'; break;}
case '3':{grid[4][11] = '*';grid[4][12]=third[0];grid[4][13] = '*';break;}
case '4':{grid[4][15] = '*';grid[4][16]=third[0];grid[4][17] = '*';break;}
case '5':{grid[4][19] = '*';grid[4][20]=third[0];grid[4][21] = '*';break;}
case '6':{grid[4][23] = '*';grid[4][24]=third[0];grid[4][25] = '*';break;}
case '7':{grid[4][27] = '*';grid[4][28]=third[0];grid[4][29] = '*';break;}
case '8':{grid[4][31] = '*';grid[4][32]=third[0];grid[4][33] = '*';break;}
case '9':{grid[4][35] = '*';grid[4][36]=third[0];grid[4][37] = '*';break;}
}
break;
}
case '3':
{
switch (second[0])
{
case '1':{grid[6][3] = '*'; grid[6][4]=third[0]; grid[6][5] = '*'; break;}
case '2':{grid[6][7] = '*'; grid[6][8]=third[0]; grid[6][9] = '*'; break;}
case '3':{grid[6][11] = '*';grid[6][12]=third[0];grid[6][13] = '*';break;}
case '4':{grid[6][15] = '*';grid[6][16]=third[0];grid[6][17] = '*';break;}
case '5':{grid[6][19] = '*';grid[6][20]=third[0];grid[6][21] = '*';break;}
case '6':{grid[6][23] = '*';grid[6][24]=third[0];grid[6][25] = '*';break;}
case '7':{grid[6][27] = '*';grid[6][28]=third[0];grid[6][29] = '*';break;}
case '8':{grid[6][31] = '*';grid[6][32]=third[0];grid[6][33] = '*';break;}
case '9':{grid[6][35] = '*';grid[6][36]=third[0];grid[6][37] = '*';break;}
}
break;
}
case '4':
{
switch (second[0])
{
case '1':{grid[8][3] = '*'; grid[8][4]=third[0]; grid[8][5] = '*'; break;}
case '2':{grid[8][7] = '*'; grid[8][8]=third[0]; grid[8][9] = '*'; break;}
case '3':{grid[8][11] = '*';grid[8][12]=third[0];grid[8][13] = '*';break;}
case '4':{grid[8][15] = '*';grid[8][16]=third[0];grid[8][17] = '*';break;}
case '5':{grid[8][19] = '*';grid[8][20]=third[0];grid[8][21] = '*';break;}
case '6':{grid[8][23] = '*';grid[8][24]=third[0];grid[8][25] = '*';break;}
case '7':{grid[8][27] = '*';grid[8][28]=third[0];grid[8][29] = '*';break;}
case '8':{grid[8][31] = '*';grid[8][32]=third[0];grid[8][33] = '*';break;}
case '9':{grid[8][35] = '*';grid[8][36]=third[0];grid[8][37] = '*';break;}
}
break;
}
case '5':
{
switch (second[0])
{
case '1':{grid[10][3] = '*'; grid[10][4]=third[0]; grid[10][5] = '*'; break;}
case '2':{grid[10][7] = '*'; grid[10][8]=third[0]; grid[10][9] = '*'; break;}
case '3':{grid[10][11] = '*';grid[10][12]=third[0];grid[10][13] = '*';break;}
case '4':{grid[10][15] = '*';grid[10][16]=third[0];grid[10][17] = '*';break;}
case '5':{grid[10][19] = '*';grid[10][20]=third[0];grid[10][21] = '*';break;}
case '6':{grid[10][23] = '*';grid[10][24]=third[0];grid[10][25] = '*';break;}
case '7':{grid[10][27] = '*';grid[10][28]=third[0];grid[10][29] = '*';break;}
case '8':{grid[10][31] = '*';grid[10][32]=third[0];grid[10][33] = '*';break;}
case '9':{grid[10][35] = '*';grid[10][36]=third[0];grid[10][37] = '*';break;}
}
break;
}
case '6':
{
switch (second[0])
{
case '1':{grid[12][3] = '*'; grid[12][4]=third[0]; grid[12][5] = '*'; break;}
case '2':{grid[12][7] = '*'; grid[12][8]=third[0]; grid[12][9] = '*'; break;}
case '3':{grid[12][11] = '*';grid[12][12]=third[0];grid[12][13] = '*';break;}
case '4':{grid[12][15] = '*';grid[12][16]=third[0];grid[12][17] = '*';break;}
case '5':{grid[12][19] = '*';grid[12][20]=third[0];grid[12][21] = '*';break;}
case '6':{grid[12][23] = '*';grid[12][24]=third[0];grid[12][25] = '*';break;}
case '7':{grid[12][27] = '*';grid[12][28]=third[0];grid[12][29] = '*';break;}
case '8':{grid[12][31] = '*';grid[12][32]=third[0];grid[12][33] = '*';break;}
case '9':{grid[12][35] = '*';grid[12][36]=third[0];grid[12][37] = '*';break;}
}
break;
}
case '7':
{
switch (second[0])
{
case '1':{grid[14][3] = '*'; grid[14][4]=third[0]; grid[14][5] = '*'; break;}
case '2':{grid[14][7] = '*'; grid[14][8]=third[0]; grid[14][9] = '*'; break;}
case '3':{grid[14][11] = '*';grid[14][12]=third[0];grid[14][13] = '*';break;}
case '4':{grid[14][15] = '*';grid[14][16]=third[0];grid[14][17] = '*';break;}
case '5':{grid[14][19] = '*';grid[14][20]=third[0];grid[14][21] = '*';break;}
case '6':{grid[14][23] = '*';grid[14][24]=third[0];grid[14][25] = '*';break;}
case '7':{grid[14][27] = '*';grid[14][28]=third[0];grid[14][29] = '*';break;}
case '8':{grid[14][31] = '*';grid[14][32]=third[0];grid[14][33] = '*';break;}
case '9':{grid[14][35] = '*';grid[14][36]=third[0];grid[14][37] = '*';break;}
}
break;
}
case '8':
{
switch (second[0])
{
case '1':{grid[16][3] = '*'; grid[16][4]=third[0]; grid[16][5] = '*'; break;}
case '2':{grid[16][7] = '*'; grid[16][8]=third[0]; grid[16][9] = '*'; break;}
case '3':{grid[16][11] = '*';grid[16][12]=third[0];grid[16][13] = '*';break;}
case '4':{grid[16][15] = '*';grid[16][16]=third[0];grid[16][17] = '*';break;}
case '5':{grid[16][19] = '*';grid[16][20]=third[0];grid[16][21] = '*';break;}
case '6':{grid[16][23] = '*';grid[16][24]=third[0];grid[16][25] = '*';break;}
case '7':{grid[16][27] = '*';grid[16][28]=third[0];grid[16][29] = '*';break;}
case '8':{grid[16][31] = '*';grid[16][32]=third[0];grid[16][33] = '*';break;}
case '9':{grid[16][35] = '*';grid[16][36]=third[0];grid[16][37] = '*';break;}
}
break;
}
case '9':
{
switch (second[0])
{
case '1':{grid[18][3] = '*'; grid[18][4]=third[0]; grid[18][5] = '*'; break;}
case '2':{grid[18][7] = '*'; grid[18][8]=third[0]; grid[18][9] = '*'; break;}
case '3':{grid[18][11] = '*';grid[18][12]=third[0];grid[18][13] = '*';break;}
case '4':{grid[18][15] = '*';grid[18][16]=third[0];grid[18][17] = '*';break;}
case '5':{grid[18][19] = '*';grid[18][20]=third[0];grid[18][21] = '*';break;}
case '6':{grid[18][23] = '*';grid[18][24]=third[0];grid[18][25] = '*';break;}
case '7':{grid[18][27] = '*';grid[18][28]=third[0];grid[18][29] = '*';break;}
case '8':{grid[18][31] = '*';grid[18][32]=third[0];grid[18][33] = '*';break;}
case '9':{grid[18][35] = '*';grid[18][36]=third[0];grid[18][37] = '*';break;}
}
break;
}
}
}
display();
}
}
最佳答案
numInBox
中(至少)有两个问题,首先,unsolved_str
没有空间容纳 nul 终止符,因此您在堆栈上乱涂乱画。第二个 atoi
接受一个 char*
,但你给它一个 char
参数。 (至少应该得到一个警告。)这几乎肯定会在 atoi
中产生段错误。
关于调用方法失败 : segmentation fault in c,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6053708/
这是一个类作业,用于将有序插入到已排序的链表中。我已经避免访问空指针,并且添加了一些调试输出行以将段错误缩小到 while 循环本身的条件语句。 我可以将一个节点添加到空列表并将具有较小键的节点添加到
一个小型测试程序在 64 位 Linux 上使用 gfortran (4.4.5) 返回段错误。 n=2_8**22_8 时不存在故障。 gdb 指示在循环的第一次迭代期间函数 mylen 中发生段错
我正在使用 Spring-WS,当我通过 webServiceTemplate 中的 marshalSendAndReceive 调用 Web 服务时,我收到错误代码为 500 的 SOAP 错误。不
我有一个具有此方法的单例数据管理器: -(NSArray*)fetchItems { NSEntityDescription *entity = [NSEntityDescription
我有一个调用 Web 服务的 Java 应用程序 (A)。 1)然后我有另一个使用 A jar 的应用程序 (B)。调用成功,返回需要的数据。 2)然后我有一个也使用A jar 的网络应用程序。在这种
我正在 Java 应用程序中对第三方网络服务进行 SOAP 网络服务调用。用于查找 Web 服务、传输数据和发出 SOAP 请求的 Java 类是使用来自 WSDL 的 Apache CXF 库生成的
我正在尝试学习 SOAP 协议(protocol)。因此,在使用以下命令借助 wsimport 生成 net.webservicex 代码后 C:\Program Files\Java\jdk1.8.
我正在构建一个基于配备 arm64 CPU 的 UltraScale+ FPGA 的数据采集系统。数据通过 DMA 传输到 RAM。驱动程序中的 DMA 缓冲区保留如下: virt_buf[i] =
我使用 QtDesigner 创建了两个对话框“listdialog.ui”和“editdialog.ui”,已发布使用Qt5.3.1,然后添加到项目“phone book.pro”“带有源代码”使用
有谁知道空中交通管制系统是如何实现软件容错的? 一些 URL 会很有帮助。 最佳答案 Lockheed 不久前发表了一些关于此的文章。看看here . 许多系统都使用 Ada,它明确支持验证命题和其他
我认为阅读内存应该不会引起任何问题,例如 char *d=""; char *d2="test"; memcmp(d,d2,10); memcmp() 永远 会失败吗? 最佳答案 您的假设是不正确的,
这个程序在我的 UNIX 机器上导致了段错误。我将原因缩小到 memset() 的第二次调用。 为什么会出现这种行为?第一个“ block ”代码与第二个几乎相同,不是吗?为什么 第一次 调用 mem
我很困惑进程在使用虚拟内存时如何可能出现段错误。据我了解,“虚拟”内存允许进程访问所有可用内存,然后将其映射到“实际”硬件内存。通过这种转换,进程怎么可能尝试访问不允许访问的内存部分? 最佳答案 听起
Tritwise操作(向右旋转和疯狂操作)无法正确运行,并在Malbolge编译器/解释器中引发分段错误。 在看到有关Coding Challenges和Code Golf的惊人答案之后,我决定开始在
这是我的代码 #include #include #include /************************************************** a is a poin
我有下面的代码。当我取消注释 temperature(i,j) = anode_temperature 时,我会出现 SegFault。 forall(i=0:Cells(1), j=0:Cells(
我是 C 编程新手,我的代码中出现了段错误。该程序使用返回函数来询问用户他们的银行帐户中有多少钱。稍后我将添加代码来计算利息。感谢您为我查看此内容,因为我很难找出为什么会出现此错误。 #include
为了测试,我编写了一个代码来计算 #include int main(void) { int p, i, primes[50], index; boo
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
考虑 const a = [1,2,3] console.log(a[5]) // returns undefined 我是一名 C 和 Fortran 程序员,我预计会发生段错误。这里的内存是如何管
我是一名优秀的程序员,十分优秀!