1.已知在文件in.dat中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)四部分组成。其中:金额=单价*数量计算得出。函数readdat()是读取这100个销售记录并存入结构数组sell中。请编制函数sortdat(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数writedat()把结果输出到文件out10.dat中。 部分源程序已给出。 请勿改动主函数main()、读数据函数readdat()和输出数据函数writedat()的内容。 #include #include #include #include #include #define max 100
typedef struct{ char dm[5]; /*产品代码*/ char mc[11]; /*产品名称*/ int dj; /*单价*/ int sl; /*数量*/ long je; /*金额*/ }pro; pro sell[max]; void readdat(); void writedat(); void sortdat()
{ }
void main()
{ memset(sell,0,sizeof(sell)); readdat(); sortdat(); writedat(); } void readdat()
{ file *fp; char str[80],ch[11]; int i; fp=fopen('in.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(void)
{ file *fp; int i; fp=fopen('out10.dat','w');
for(i=0;i<100;i++){ fprintf(fp,'%s %s m ] ld/n', sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je); } fclose(fp); }' -------------------------------------------------------------------------------- 注:这时也是采用冒泡法进行排序。与前面的冒泡法在写法上有所不同请注意区分。 void sortdat() { int i,j; pro swap; for(i=0;i for(j=0;j { if(strcmp(sell[j].dm,sell[j+1].dm)<0) /*用函数strcmp判断两个字符串的大小*/ { swap=sell[j]; s ell[j]=sell[j+1]; sell[j+1]=swap; } if(strcmp(sell[j].dm,sell[j+1].dm)==0&&sell[j].je { swap=sell[j]; sell[j]=sell[j+1]; sell[j+1]=swap; } } } 若产品代码相同,则按金额从大到小进行排列没有体现! 2.six+six+six=nine+nine的个数cnt及它们的和sum,s,i,n,e是0-9自然数,但s,n不能为0.
如84+984+984=1476+1476, 我临时编的(可能算法不太好) main()
{ int i,j,cnt=0; float sum=0; for(i=100;i<1000;i++) for(j=1000;j<10000;j++) { if(i+i+i==j+j) { cnt++; sum=sum+i+j; printf('%d+%d+%d=%d+%d/n',i,i,i,j,j); } } printf('%d,%f',cnt,sum); } 参考这个:for(i=666;i<1000;i++)
if((i/10=(3*i/2)/100)&&((i*3/2)/1000=(i*3/2)/10) {cnt++; sum+=(5/2)*i; } 3.函数readdat()实现从文件eng.in中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptchar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数writedat()把结果xx输出到文件ps4.dat中。 替代关系:f(p)=p*11 mod56 (p是数组中某一个字符的ascii值,f(p)是计算后新字符的ascii值),如果计算后f(p)值小于等于32或f(p)对应的字符是大写字母,则该字符不变,否则将f(p)所对应的字符进行替代。
部分源程序已给出。原始数据文件存放的格式是:每行的宽度均小于80个字符。
请勿改动主函数main()、读数据函数readdat()和输出数据函数writedat()的内容。
#include
#include
#include
#include
unsigned char xx[50][80]; int maxline=0;/*文章的总行数*/
int readdat(void) void writedat(void)
void encryptchar() {
} void main() {
clrscr();
if(readdat()){
printf(/'数据文件eng.in不能打开!//n//007/');
return;
}
encryptchar();
writedat();
}
int readdat(void) {
file *fp;
int i=0; >
unsigned char *p;
if((fp=fopen(/'eng.in/',/'r/'))==null) return 1; while(fgets(xx[i],80,fp)!=null){
p=strchr(xx[i],'//n');
if(p)*p=0;
i++;
}
maxline=i;
fclose(fp);
return 0;
}
void writedat(void) {
file *fp;
int i;
fp=fopen(/'ps4.dat/',/'w/'); for(i=0;i printf(/'%s//n/',xx[i]);
fprintf(fp,/'%s//n/',xx[i]);
}
fclose(fp);
}
-------------------------------------------------------------------------------- 注:下题1相似,只是它要求对f(p)进行判断。 void encryptchar()
{
int i;
char *pf;
for(i=0;i {pf=xx[i];
while(*pf!=0)
{if(*pf*11%6>='a'&&*pf*11%6<='z'||*pf*11%6<32)
{pf++;continue;}
*pf=*pf*11%6;
pf++;
}
}
}
void encryptchar()
{
int i,j,t;
for(i=0;i {
for(j=0;j {
t=xx[i][j]*11%6;
if(t<=32 || t>='a' && t<='z') continue;
xx[i][j]=t;
}
}
}
4.南开第一题
函数readdat()实现从文件eng.in中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptchar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数writedat()把结果xx输出到文件ps10.dat中。 替代关系:f(p)=p*11 mod56 (p是数组中某一个字符的ascii值,f(p)是计算后新字符的ascii值),如果原字符的ascii值是偶数或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。 部分源程序已给出,原始数据文件存放的格式是:每行的宽度均小于80个字符。 请勿改动主函数main()、读数据函数readdat()和输出数据函数writedat()的内容。 #include #include #include #include unsigned char xx[50][80];
< p>int maxline=0;/*文章的总行数*/ int readdat(void)
void writedat(void) void encryptchar()
{ }
void main()
{ clrscr(); if(readdat()){ printf('数据文件eng.in不能打开!/n/007'); return; } encryptchar(); writedat(); } int readdat(void)
{ file *fp; int i=0; unsigned char *p; if((fp=fopen('eng.in','r'))==null) return 1;
while(fgets(xx[i],80,fp)!=null){ p=strchr(xx[i],'/n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return 0; } void writedat(void)
{ file *fp; int i; fp=fopen('ps10.dat','w'); for(i=0;i printf('%s/n',xx[i]); fprintf(fp,'%s/n',xx[i]); } fclose(fp); } --------------------------------------------------------------------------------
注:在readdat()函数中由于fgets()函数读入数据时没有读入字符串结束符'/0',因
而用while()循环在xx数组每一行未尾将换行符'/n'替换成结束符'/0'。 编写的函数如下:该函数的基本算法是——让字符指针pf指向每一行的开头然后逐一往 后移动,在移动过程中按要求进行转换。*pf%2==0用于判断是否为偶数。if()条件语 句用于控制不替代字符。 的 解法1:
void encryptchar()
{ int i; char *pf; for(i=0;i {pf=xx[i]; /*每行字符个数*/ while(*pf!=0) {if(*pf%2==0||*pf*11%6<32) {pf++;continue;} *pf=*pf*11%6; pf++; } } }
|