清华大学2001年复试上机题 第一套 解题报告

九度OJ 题目1062:分段函数
时间限制:1 秒  内存限制:32 兆  特殊判题:否  提交:397  解决:223
题目描述:
    编写程序,计算下列分段函数y=f(x)的值。
    y=-x+2.5; 0<=x<2
    y=2-1.5(x-3)(x-3); 2<=x<4
    y=x/2-1.5; 4<=x<6
输入:
    一个浮点数N
输出:
    测试数据可能有多组,对于每一组数据,
    输出N对应的分段函数值:f(N)。结果保留三维小数
样例输入:
    1
样例输出:
    1.500
//清华2001:题目1062:分段函数
//编写程序,计算下列分段函数y=f(x)的值。
//y=-x+2.5; 0<=x<2
//y=2-1.5(x-3)(x-3); 2<=x<4
//y=x/2-1.5; 4<=x<6
#include <iostream>
using namespace std;

int main()
{
	int i, j, t;
	float n;
	while( cin >> n ){
		cout.setf(ios::fixed);
		cout.precision(3);
		if( n<2 )
			cout << 2.5-n << endl;
		else if( n<4 )
			cout << 2-1.5*(n-3)*(n-3) << endl;
		else
			cout << n/2-1.5 << endl;
	}
	//system("pause");
	return 0;
}


九度OJ 题目1063:整数和
时间限制:1 秒  内存限制:32 兆  特殊判题:否  提交:349  解决:244
题目描述:
    编写程序,读入一个整数N。
    若N为非负数,则计算N到2N之间的整数和;
    若N为一个负数,则求2N到N之间的整数和
输入:
    一个整数N,N的绝对值小于等于1000
输出:
    测试数据可能有多组,对于每一组数据,
    输出题目要求的值
样例输入:
    1
    -1
样例输出:
    3
    -3
//清华2001:题目1063:整数和
//编写程序,读入一个整数N (N<=1000)
//若N为非负数,则计算N到2N之间的整数和
//若N为一个负数,则求2N到N之间的整数和
#include <iostream>
using namespace std;

int main()
{
	int i, j, t, n;
	while( cin >> n ){
		t = 0;
		if( n<0 )
			cout << 3*n*(-n+1)/2 << endl;
		else
			cout << 3*n*(n+1)/2 << endl;
	}
	//system("pause");
	return 0;
}


九度OJ 题目1064:反序数
时间限制:1 秒  内存限制:32 兆  特殊判题:否   提交:275   解决:219
题目描述:
    设N是一个四位数,它的9倍恰好是其反序数(例如:1234的反序数是4321)
    求N的值
输入:
    程序无任何输入数据
输出:
    输出题目要求的四位数,如果结果有多组,则每组结果之间以回车隔开
//清华2001:题目1064:反序数
//设N是一个四位数,它的9倍恰好是其反序数(例如:1234的反序数是4321)
//求N的值
#include <iostream>
using namespace std;

int reverse( int x ){	//求反序数 输入为4位数
	int i, j, a[4], y=0;
	for( i=0; i<4; i++ ){
		a[i] = x % 10;
		x /= 10;
	}
	for( i=0; i<4; i++ )
		for( j=0; j<3-i; j++ )
			a[i] *= 10;
	for( i=0; i<4; i++ )
		y += a[i];
	return y;
};

int main()
{
	int i, j, n, t;
	//while( cin >> n )
	//	cout << reverse(n);

	for( i=1000; i<=1111; i++ )	//9*1112>1w 是5位数了
		if( 9*i == reverse(i) )
			cout << i;

	system("pause");
	return 0;
}

你可能感兴趣的:(ios,测试,n2)