对于我的程序的一部分,我想在每个字符之间连接两个字符串和星号。例如,如果我有第一个"abcde"
字符串和第二个"1234567"
字符串,我希望得到"a*b*c*d*e*1*2*3*4*5*6*7*"
的结果。
对于这部分程序,我有:
char *widen_stars(char *one, char *two)
{
int length_one = strlength(one); // length of first parameter
int length_two = strlength(two); // Length of second parameter
char *p = malloc((sizeof(char) * (length_one + length_two) * 2)+ 1), *p_start; //Allocate enough memory for both strings concatenated together with a * between each letter
p_start = p;
while(*one != '0')
{
if( (p - p_start) % 2 == 0) // Keeps track of where we are in the p string
{
*p = *one;
p++;
one++;
}
else
{
*p = '*';
p++;
}
}
while(*two != '0')
{
if( (p - p_start) % 2 == 0)
{
*p = *two;
p++;
two++;
}
else
{
*p = '*';
p++;
}
}
return p_start;
}
int main(int argc, char *argv[])
{
char first[31]= {0};
char second[31]= {0};
char *f = first, *s = second;
printf("Please enter a string of maximum 30 characters: ");
scanf("%s", f);
printf("Please enter a string of maximum 30 characters: ");
scanf("%s", s);
printf("The combined string is: %s\n", widen_stars(f, s));
}
return 0;
}
然而,当我使用上面的输入运行程序时,我得到类似"a*b*c*d*e*"
的东西,没有任何第二个字符串。如果我阻止第一个while循环进入注释来测试第二个循环,我会得到像"1*2*3*4*5*5*7*"
这样的东西,让我摸不着头脑。
答案 0 :(得分:4)
你的问题在于:
{"$set":"foo"}
如果您正在寻找字符串的结尾,那么您应该寻找的是res.end(JSON.stringify({ $set: factura }));
,而不是while(*oneOrTwo != '0')
。前者是字符串结尾标记,后者只是字符 '\0'
。
而且,除此之外,还有更少......,错误,详细方法(假设它不是类工作 - 如果是,你应该使用当前的方法) 。例如:
'0'
这取决于您的实际预期结果,在每个字符后放置一个星号。但是,您的规范要求在每个字符之间使用星号 。如果您决定使用后者,那么在函数中取消注释倒数第二个语句就是一个简单的问题,基本上备份并用字符串结尾标记替换最后的星号。
答案 1 :(得分:3)
您的代码中的问题是id
条件,您应该增加指针,直到$waf1 = DB::table('pricings')->join('carts', 'carts.sp_id', '=', 'pricings.sp_id')
->select(DB::raw('sum(pricings.Regular_Laundry*carts.q_Regular_Laundry) AS waf1'))
->where('pricings.sp_id', '=', $sp_id)->where('carts.id', '=' , $cart_id)->first();
$waf2 = DB::table('pricings')->join('carts', 'carts.sp_id', '=', 'pricings.sp_id')
->select(DB::raw('sum(pricings.Bedding_Mattress_Duvet_Cover*carts.q_Bedding_Mattress_Duvet_Cover) AS waf2'))
->where('pricings.sp_id', '=', $sp_id)->where('carts.id', '=' , $cart_id)->first();
$waf3 = DB::table('pricings')->join('carts', 'carts.sp_id', '=', 'pricings.sp_id')
->select(DB::raw('sum(pricings.Bedding_Comforter_laundry*carts.q_Bedding_Comforter_laundry) AS waf3'))
->where('pricings.sp_id', '=', $sp_id)->where('carts.id', '=' , $cart_id)->first();
$waf4 = DB::table('pricings')->join('carts', 'carts.sp_id', '=', 'pricings.sp_id')
->select(DB::raw('sum(pricings.Bedding_Blanket_Throw*carts.q_Bedding_Blanket_Throw) AS waf4'))
->where('pricings.sp_id', '=', $sp_id)->where('carts.id', '=' , $cart_id)->first();
$waf5 = DB::table('pricings')->join('carts', 'carts.sp_id', '=', 'pricings.sp_id')
->select(DB::raw('sum(pricings.Bedding_Pillow_laundry*carts.q_Bedding_Pillow_laundry) AS waf5'))
->where('pricings.sp_id', '=', $sp_id)->where('carts.id', '=' , $cart_id)->first();
$waf6 = DB::table('pricings')->join('carts', 'carts.sp_id', '=', 'pricings.sp_id')
->select(DB::raw('sum(pricings.Bath_Mat_laundry*carts.q_Bath_Mat_laundry) AS waf6'))
->where('pricings.sp_id', '=', $sp_id)->where('carts.id', '=' , $cart_id)->first();
$waf7 = DB::table('pricings')->join('carts', 'carts.sp_id', '=', 'pricings.sp_id')
->select(DB::raw('sum(pricings.Every_Hang_Dry_Item*carts.q_Every_Hang_Dry_Item) AS waf7'))
->where('pricings.sp_id', '=', $sp_id)->where('carts.id', '=' , $cart_id)->first();
$waftotal = $waf1->waf1 + $waf2->waf2 + $waf3->waf3 + $waf4->waf4 + $waf5->waf5 + $waf6->waf6 + $waf7->waf7 ;
而不是while
。所以不要这样做:
'\0'
你这样做:
'0'
当您返回动态分配的内存时,请考虑使用指向此内存的指针,使用后while(*one != '0')
...
while(*two != '0')
:
while(*one != '\0')
...
while(*two != '\0')