对不起,如果这是一个愚蠢的问题,我是新来的C++。为什么它没有正确地将所有输入复制到输出?Printf打印错误的字符和0
#include <iostream>
#include <iomanip>
#include <limits>
#include <string>
using namespace std;
int main() {
int num1;
long num2;
long long num3;
char char1;
float num4;
double num5;
scanf("%d %ld %lld %c %f %lf", &num1, &num2, &num3, &char1, &num4, &num5);
//input: 211916801 452082285 97592151379235457 p 19856.992 -5279235.721231465
printf("%d %ld %lld %c %f %lf", num1, num2, &num3, &char1, &num4, &num5);
//expected output: 211916801 452082285 97592151379235457 p 19856.992 -5279235.721231465
//actual output: 211916801 452082285 68674564278975280 c 0.000000 0.000000
system("pause");
return 0;
}
为什么在第一个地方在C++代码中使用'scanf()'和'printf()'? –
,因为如果我使用cout它不会打印所有小数的double,但是使用printf它也可以,这就是HackerRank要我做的事情(https://www.hackerrank.com/challenges/c-tutorial-基本数据类型?h_r = next-challenge&h_v = zen) – kirill2485
检查'std :: fixed'和'std :: setprecision()'[manipulators](http://en.cppreference.com/w/cpp/ IO/MANIP)。 –