问题 选择题
设函数y=f(x)在(-∞,+∞)内有定义.对于给定的正数K,定义函数 fk(x)=
f(x),f(x)≤K
K,f(x)>K
取函数f(x)=2-x-e-x.若对任意的x∈(+∞,-∞),恒有fk(x)=f(x),则(  )
A.K的最大值为2B.K的最小值为2
C.K的最大值为1D.K的最小值为1
答案

由题意可得出k≥f(x)最大值

由于f′(x)=-1+e-x,令f′(x)=0,e-x=1=e0解出-x=0,即x=0,

当x>0时,f′(x)<0,f(x)单调递减,

当x<0时,f′(x)>0,f(x)单调递增.

故当x=0时,f(x)取到最大值f(0)=2-1=1.

故当k≥1时,恒有fk(x)=f(x).

因此K的最小值是1.

故选D.

单项选择题
问答题

已知文件INl6.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位)、产品名称mc(字符型 10位)、单价dj(整型)、数量sl(整型)、金额je(长整型)几部分组成。其中:金额=单价×数量。函数ReadDat()的功能是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品名称从大到小进行排列,若产品名称相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件 OUT16.DAT中。
注意:部分源程序已给出。
请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
试题程序:
#include<stdio.h>
#include<mem.h>
#include<string.h>
#include<conio.h>
#include <stdlib.h>
#define MAX 100
typede f struct

char dm[5]; /*产品代码*/
char mc[11]; /* 产品代码 */
int dj; /* 单价 */
int sl;/* 数量 */
long je; /* 金额 */
PRO;
PRO sell [MAX];
void ReadDat();
void WriteDat();
void SortDat()


main ( )

memset(sell, 0, sizeof(sell));
ReadDat ( );
SortDat();
WriteDat ( );

void ReadDat ( )

FILE *fp;
char str[80] , ch[11];
int i;
fp = fopen("IN16.DAT", "r");
for(i=0; i<100; i++)

fgets(str, 80, fp);
memcpy(sell[i].dm, str, 4);
memcpy(sell[i].mc, str + 4, 10);
memcpy(ch, str + 14, 4);
ch[4] = 0;
sell[i] .dj = atoi(ch);
memcpy(ch, str +18, 5);
ch[5] = 0;
sell[i] .sl = atoi(ch);
sell[i] .je = (long)sell[i] .dj * sell[i] .sl;

fclose(fp);

void WriteDat()

FILE *fp;
int i;
fp = fopen("OUT16.DAT", "w");
for(i = 0; i < 100; i++)

fprintf(fp, "%s %s %4d %5d %101d\n", sell[i].dm, sell[i].mc, sell[i].dj,
sell[i] .sl, sell[i] .je);

fclose(fp);