小编Luc*_*che的帖子

linux内核分叉子返回状态

所以这就是我的困境:为什么当我fork();是一个过程的孩子并且它结束时,&status孩子的回归向左移8位?

例如,假设我exit(4);在分叉子项的末尾,我在wait(&status); 父进程中的状态得到了我0x400.

所以这里有一些代码说明了我的意思

#include <stdio.h>

main() {
  int n, status, cpid;

  printf("Parent pid = %d\n",  getpid());

  n = fork();

  if (n != 0) {
     //  parent code
     printf ("I'm the parent with PID %d \t fork returned %d \t my parent is %d\n", getpid(), n, getppid()); 
     status = 0;
     sleep(5);      // verify status of child
     cpid = wait(&status);

     // so when i printf the hex value of status it gets …
Run Code Online (Sandbox Code Playgroud)

c unix linux shell kernel

2
推荐指数
1
解决办法
1232
查看次数

Futoshiki C递归求解器

所以我有这个程序应该从具有这种格式的文本文件中加载Cwich中的futoshiki拼图:

5
0 | 0 | 0 | 0 | 0
----v---- 
0> 0 | 0 | 0 | 3
--------- 
0 | 0 <2 | 0 | 0
----v---- 
0 | 0 | 0 | 0 | 4
^-v------ 
0 | 0 | 0 | 0 | 0

其中5是矩阵的大小和数量adjcent给运营商<>^v必须满足从文件由他们强加的条件下,所有的行的字符用空格分开例如0 |......所以,我已经成功地负载该文件,以检查它是否满足数学运算符的条件,但是我被困在递归函数上

我想知道的是:

我是否选择了正确的矩阵存储方式,还是应该将逻辑运算符中的数字相除?

如何在矩阵上执行递归扩展,如何在特定步骤中跟踪使用的数字(以防万一我必须回溯)?

例如。假设我到达的index[j][j]位置j<n(矩阵的大小),从那里开始,我只需要递减j(“触摸”)数字,然后检查子矩阵是否满足条件

到目前为止,这是我设法编写的代码。

在哪里:

char **readmat(int *n); //从文件中读取矩阵,消除字符之间的空格

void print(char **mat,int …

c algorithm backtracking

2
推荐指数
1
解决办法
3689
查看次数

对于循环[C/java之类的语法]

所以我在这里谈到这个简单的问题

考虑这两个周期,请向我解释两种写作方式之间是否存在差异

方法1:

  for(i=(max-1) ; i>=0 ; i--){ do-some-stuff }
Run Code Online (Sandbox Code Playgroud)

方法2:

  for(i=max ; i>0 ; i--)     { do-some-stuff }
Run Code Online (Sandbox Code Playgroud)

我问这个的原因是因为今天在学校我们看到了一些Java函数时,有一个这样的回文方法,它将用作传递给它的单词的最大长度,并且用于循环通过for的方法是第一个,任何人都可以澄清为什么那些编写该代码的人会使用该方法进行编程吗?

c c++ java algorithm

1
推荐指数
1
解决办法
929
查看次数

不可变的java对象

今天在我阅读有关BigDecimal类的一些文档时,我偶然发现了一个基本属性,BigDecimal类是不可变的.

我怎么能向祖母解释不变性概念?

班级不变性的利弊是什么?

扩展类可以变得可变吗?

考虑到我想用我的类扩展BigDecimal:

`MyBigDecimal extends BigDecimal` 
Run Code Online (Sandbox Code Playgroud)

扩展是否违反了面向对象的基本设计原则?

java design-patterns bigdecimal

1
推荐指数
1
解决办法
2656
查看次数

Java:在clone()方法中进行转换

上周在我们的java课程中,我们介绍了Object类及其一些方法,其中一个方法是clone(),当我们的老师向我们解释这个方法时,我们被告知每次我们克隆一个对象时,我们都必须向下-通过clone()转换返回的对象,因为clone()返回一个Object类型的对象。

因此,我找不到为什么此方法更愿意返回通用对象,因为它可以使用 getClass() 等其他方法轻松获取克隆对象的类型并自动处理向下转换。

哦,顺便说一句,这不是作业,只是我个人的好奇心促使我问这个问题(我的老师可以给我一个准确的答案,所以我决定暂时让他这样做:D)

java

0
推荐指数
1
解决办法
1962
查看次数

Java双增量

我有一个双变量

public double votes(){
    double votexp = 0;

      for(Elettore e:docenti.values()){
        if(e.getVoto()==true)          //everytime this is true increment by 1
        {
            votexp+=1.0;
        }   
    }
    for(Elettore e:studenti.values()){
        if(e.getVoto()==true)         //everytime this is true increment by 0.2
        {
            votexp+=0.2;
        }
    }
    for(Elettore e:pta.values()){
        if(e.getVoto()==true)        //everytime this is true increment by 0.2
        {
            votexp+=0.2;
        }
    }
    return votexp;
}
Run Code Online (Sandbox Code Playgroud)

在我的情况下,变量应该增加到2.6但是votexp返回2.6000000000000005我如何通过使用相同的双变量并返回双精度数来解决这个问题?

java ieee-754

0
推荐指数
1
解决办法
2121
查看次数

标签 统计

java ×4

c ×3

algorithm ×2

backtracking ×1

bigdecimal ×1

c++ ×1

design-patterns ×1

ieee-754 ×1

kernel ×1

linux ×1

shell ×1

unix ×1