c语言100题(c语言100道题)

hacker2年前黑客资讯139

本文目录一览:

C语言题目,100分悬赏

/*

之一题:已知某班N(〈=50)名学生进行了高数、英语和C语言等3门课考试,将3门课

的成绩以及计算3门课的总分存放于一个二维数组中,将学生姓名存放在另一个二维字

符数组中,按总分(由高到低)将学生姓名排序并输出排序结果(序号和姓名)。

*/

#include "stdafx.h"

#include "stdio.h"

struct scoreInfo{

int scoreMath;

int scoreProC;

int scoreEng;

int scorSum;

};

struct studentInfo{

char name[20];

struct scoreInfo _scoreInfo;

};

void inputInfo(struct studentInfo *stu,int n)

{

int i = 0;

for(i = 0; i  n; i++)

{

printf("第%d个学生的姓名:",i+1);

gets(stu[i].name);

printf("第%d个学生的数学成绩:",i+1);

scanf("%d",stu[i]._scoreInfo.scoreMath);

getchar();

printf("第%d学生的C语言成绩:",i+1);

scanf("%d",stu[i]._scoreInfo.scoreProC);

getchar();

printf("第%d个学生的英语成绩:",i+1);

scanf("%d",stu[i]._scoreInfo.scoreEng);

getchar();

}

printf("\n");

}

void outputInfo(struct studentInfo *stu,int n)

{

int i = 0;

for (i = 0; i  n; i++)

{

stu[i]._scoreInfo.scorSum = stu[i]._scoreInfo.scoreEng + stu[i]._scoreInfo.scoreMath

+ stu[i]._scoreInfo.scoreProC;

}

printf("姓名\t数学成绩\tC语言成绩\t英语成绩\t总分\n");

for (i = 0; i  n; i++)

{

printf("%s\t%d\t\t%d\t\t%d\t\t%d\n",stu[i].name,stu[i]._scoreInfo.scoreMath, stu

[i]._scoreInfo.scoreProC

,stu[i]._scoreInfo.scoreEng,stu[i]._scoreInfo.scorSum);

}

}

void arry_max_to_min(struct studentInfo *stu,int n)

{

int indexi;

int indexj;

struct studentInfo _temp;

// struct stdentInfo *ptemp;

// ptemp = stu;

for (indexi = 0; indexi  n;indexi++)

{

for (indexj = indexi+1; indexj  n; indexj++)

{

if (stu[indexi]._scoreInfo.scorSum  stu[indexj]._scoreInfo.scorSum)

{

_temp = stu[indexj];

stu[indexj] = stu[indexi];

stu[indexi] = _temp;

}

}

}

printf("总分从高到低排列:\n");

for (indexi = 0 ; indexi  n; indexi++)

{

printf("%s\t%d\t\t%d\t\t%d\t\t%d\n",stu[indexi].name,stu[indexi]._scoreInfo.scoreMath, stu

[indexi]._scoreInfo.scoreProC

,stu[indexi]._scoreInfo.scoreEng,stu[indexi]._scoreInfo.scorSum);

}

}

int main()

{

int studentNum;

struct studentInfo stu[50];

printf("输入学生数:");

scanf("%d",studentNum);

getchar();

inputInfo(stu,studentNum);

outputInfo(stu,studentNum);

arry_max_to_min(stu,studentNum);

return 0;

}

运行结果:

输入学生数:3

第1个学生的姓名:Jack

第1个学生的数学成绩:89

第1学生的C语言成绩:86

第1个学生的英语成绩:96

第2个学生的姓名:Tom

第2个学生的数学成绩:95

第2学生的C语言成绩:94

第2个学生的英语成绩:92

第3个学生的姓名:Star

第3个学生的数学成绩:98

第3学生的C语言成绩:78

第3个学生的英语成绩:89

姓名 数学成绩 C语言成绩 英语成绩 总分

Jack 89 86 96 271

Tom 95 94 92 281

Star 98 78 89 265

总分从高到低排列:

Tom 95 94 92 281

Jack 89 86 96 271

Star 98 78 89 265

Press any key to continue

/*

第二题:编写函数fun(char s[ ], int num[ ]),其功能是统计字符串 s 中数字字符、大写字母、

小写字母和空格字符的出现次数,统计结果存于num数组中。再设计main函数,调用fun函数,

实现预期功能。

*/

#include "stdafx.h"

#include "stdio.h"

#include "string.h"

void fun(char *s, int *num)

{

int length;

int index;

int sum_number = 0;

int sum_char = 0;

int sum_spac = 0;

int sum_CHAR = 0;

length = strlen(s);

for (index = 0; index  length; index++)

{

if ((*s = '0')  (*s = '9') )

{

sum_number++;

}

if ((*s = 'a')  (*s  'z') )

{

sum_char++;

}

if ((*s = 'A')  (*s = 'Z') )

{

sum_CHAR++;

}

if (*s == 0x20 )

{

sum_spac++;

}

s++;

}

num[0] = sum_number;

num[1] = sum_CHAR;

num[2] = sum_char;

num[3] = sum_spac;

}

int main()

{

char testarry[50];

int num[4];//用来放数字num[0],num[1]大写字母,num[2]小写字母,num[3]空格数字的个数

//num = (int *)malloc(sizeof(int) * 4);

printf("请输入字符串:");

gets(testarry);

fun(testarry,num);

// printf("%s",testarry);

printf("数字的个数:%d\n大写字母的个数:%d\n小写字母的个数:%d\n空格数字的个数:%d\n",

num[0],num[1],num[2],num[3]);

return 0;

}

运行结果:

请输入字符串:12345 AFASDFE 74897 asfdasf

数字的个数:10

大写字母的个数:7

小写字母的个数:7

空格数字的个数:3

Press any key to continue

第三题:

#include "stdafx.h"

#include "stdio.h"

int main()

{

int i;

int j;

int k;

int half = 0;

char prin;

prin = 'A';

for (i = 0; i  26; i++)

{

prin = 'A';

for (j = 26-i-1;j  0; j--)

{

printf(" ");

}

for (k = 1; k= 2*i+1 ;k++)

{

half = k;

if (--half = i)

{

printf("%c",prin++);

}

else

{

printf("%c",--prin - 1);

}

}

printf("\n");

}

return 0;

}

运行结果:

A

ABA

ABCBA

ABCDCBA

ABCDEDCBA

ABCDEFEDCBA

ABCDEFGFEDCBA

ABCDEFGHGFEDCBA

ABCDEFGHIHGFEDCBA

ABCDEFGHIJIHGFEDCBA

ABCDEFGHIJKJIHGFEDCBA

ABCDEFGHIJKLKJIHGFEDCBA

ABCDEFGHIJKLMLKJIHGFEDCBA

ABCDEFGHIJKLMNMLKJIHGFEDCBA

ABCDEFGHIJKLMNONMLKJIHGFEDCBA

ABCDEFGHIJKLMNOPONMLKJIHGFEDCBA

ABCDEFGHIJKLMNOPQPONMLKJIHGFEDCBA

ABCDEFGHIJKLMNOPQRQPONMLKJIHGFEDCBA

Press any key to continue

[附加说明:]由于百度在栏目里屏蔽了空格和TAB,所以看不出效果,把

需要的话你可以把Email给我 我发给你。打印效果这个上面看不出来。呵呵

Press any key to continue

c语言经典100

您好,c语言经典100题:

【程序1】

题目:有1,2,3,4个数字,能组成多少个互不相同且无重复数字的三位数

都是多少

1.程序分析:可填在百位,十位,个位的数字都是1,2,3,4.组成所有的排列后再去

掉不满足条件的排列.

2.程序源代码:

main()

{

int

i,j,k;

printf("\n");

for(i1;i5;i++)

/*以下为三重循环*/

for(j1;j5;j++)

for

(k1;k5;k++)

{

if

(i!ki!jj!k)

/*确保i,j,k三位互不相同*/

printf("%d,%d,%d\n",i,j,k);

}

}

【程序2】

题目:企业发放的奖金根据利润提成.利润(i)低于或等于10万元时,奖金可提10%;利润高

于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提

成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于

40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于

100万元时,超过100万元的部分按1%提成,从键盘输入当月利润i,求应发放奖金总数

1.程序分析:请利用数轴来分界,定位.注意定义时需把奖金定义成长整型.

2.程序源代码:

main()

{

long

int

i;

int

bonus1,bonus2,bonus4,bonus6,bonus10,bonus;

scanf("%ld",i);

bonus1100000*0.1;bonus2bonus1+100000*0.75;

bonus4bonus2+200000*0.5;

bonus6bonus4+200000*0.3;

bonus10bonus6+400000*0.15;

if(i100000)

bonusi*0.1;

else

if(i200000)

bonu *** onus1+(i-100000)*0.075;

else

if(i400000)

bonu *** onus2+(i-200000)*0.05;

else

if(i600000)

bonu *** onus4+(i-400000)*0.03;

else

if(i1000000)

bonu *** onus6+(i-600000)*0.015;

else

bonu *** onus10+(i-1000000)*0.01;

printf("bonus%d",bonus);

}

【程序3】

题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少

1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后

的结果满足如下条件,即是结果.请看具体分析:

2.程序源代码:

#include

"math.h"

main()

{

long

int

i,x,y,z;

for

(i1;i2)/*如果是闰年且月份大于2,总天数应该加一天*/

sum++;

printf("it

is

the

%dth

day.",sum);}

【程序4】

题目:输入某年某月某日,判断这一天是这一年的第几天?

1.程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊

情况,闰年且输入月份大于3时需考虑多加一天。

2.程序源代码:

main()

{

int

day,month,year,sum,leap;

printf("\nplease

input

year,month,day\n");

scanf("%d,%d,%d",year,month,day);

switch(month)/*先计算某月以前月份的总天数*/

{

case

1:sum0;break;

case

2:sum31;break;

case

3:sum59;break;

case

4:sum90;break;

case

5:sum120;break;

case

6:sum151;break;

case

7:sum181;break;

case

8:sum212;break;

case

9:sum243;break;

case

10:sum273;break;

case

11:sum304;break;

case

12:sum334;break;

default:printf("data

error");break;

}

sumsum+day;

/*再加上某天的天数*/

if(year%4000||(year%40year%100!0))/*判断是不是闰年*/

leap1;

else

leap0;

if(leap1month2)/*如果是闰年且月份大于2,总天数应该加一天*/

sum++;

printf("It

is

the

%dth

day.",sum);}

【程序5】

题目:输入三个整数x,y,z,请把这三个数由小到大输出.

1.程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果xy则将x与y的值进行交换,

然后再用x与z进行比较,如果xz则将x与z的值进行交换,这样能使x最小.

2.程序源代码:

main()

{

int

x,y,z,t;

scanf("%d%d%d",x,y,z);

if

(xy)

{tx;xy;yt;}

/*交换x,y的值*/

if(xz)

{tz;zx;xt;}/*交换x,z的值*/

if(yz)

{ty;yz;zt;}/*交换z,y的值*/

printf(" *** all

to

big:

%d

%d

%d\n",x,y,z);

}

【程序6】

题目:用*号输出字母c的图案.

1.程序分析:可先用'*'号在纸上写出字母c,再分行输出.

2.程序源代码:

#include

"stdio.h"

main()

{

printf("hello

c-world!\n");

printf("

****\n");

printf("

*\n");

printf("

*

\n");

printf("

****\n");

}

【程序7】

题目:输出特殊图案,请在c环境中运行,看一看,very

beautiful!

1.程序分析:字符共有256个.不同字符,图形不一样.

2.程序源代码:

#include

"stdio.h"

main()

{

char

a176,b219;

printf("%c%c%c%c%c\n",b,a,a,a,b);

printf("%c%c%c%c%c\n",a,b,a,b,a);

printf("%c%c%c%c%c\n",a,a,b,a,a);

printf("%c%c%c%c%c\n",a,b,a,b,a);

printf("%c%c%c%c%c\n",b,a,a,a,b);}

【程序8】

题目:输出9*9口诀.

1.程序分析:分行与列考虑,共9行9列,i控制行,j控制列.

2.程序源代码:

#include

"stdio.h"

main()

{

int

i,j,result;

printf("\n");

for

(i1;i10;i++)

{

for(j1;j10;j++)

{

resulti*j;

printf("%d*%d%-3d",i,j,result);/*-3d表示左对齐,占3位*/

}

printf("\n");/*每一行后换行*/

}

}

【程序9】

题目:要求输出国际象棋棋盘.

1.程序分析:用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格.

2.程序源代码:

#include

"stdio.h"

main()

{

int

i,j;

for(i0;i8;i++)

{

for(j0;j8;j++)

if((i+j)%20)

printf("%c%c",219,219);

else

printf("

");

printf("\n");

}

}

【程序10】

题目:打印楼梯,同时在楼梯上方打印两个笑脸.

1.程序分析:用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数.

2.程序源代码:

#include

"stdio.h"

main()

{

int

i,j;

printf("\1\1\n");/*输出两个笑脸*/

for(i1;i11;i++)

{

for(j1;ji;j++)

printf("%c%c",219,219);

printf("\n");

}

}

【程序11】

题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月

后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少

1.程序分析:

兔子的规律为数列1,1,2,3,5,8,13,21....

2.程序源代码:

main()

{

long

f1,f2;

int

i;

f1f21;

for(i1;i20;i++)

{

printf("%12ld

%12ld",f1,f2);

if(i%20)

printf("\n");/*控制输出,每行四个*/

f1f1+f2;

/*前两个月加起来赋值给第三个月*/

f2f1+f2;

/*前两个月加起来赋值给第三个月*/

}

}

【程序12】

题目:判断101-200之间有多少个素数,并输出所有素数.

1.程序分析:判断素数的 *** :用一个数分别去除2到sqrt(这个数),如果能被整除,

则表明此数不是素数,反之是素数.

2.程序源代码:

#include

"math.h"

main()

{

int

m,i,k,h0,leap1;

printf("\n");

for(m101;m200;m++)

{

ksqrt(m+1);

for(i2;ik;i++)

if(m%i0)

{leap0;break;}

if(leap)

{printf("%-4d",m);h++;

if(h%100)

printf("\n");

}

leap1;

}

printf("\nthe

total

is

%d",h);

}

C语言100题【程序90】 题目:专升本一题,读结果.为什么输出结果是12345??

while 执行了五次,下面是五次的a里的数据

5 2 3 4 1

5 4 3 2 1

5 4 3 2 1

5 2 3 4 1

1 2 3 4 5

换了又被换回去了,如果要真正实现交换,应该只执行5/2次

c语言100道题中,兔子生兔子程序怎么理解

有一对兔子,从出生后第 3 个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

兔子的规律为数列:

1, 1, 2, 3, 5, 8, 13, 21 ....

下面使用了迭代、递归和数组三种解法。

【代码一】使用迭代:

#include stdio.h

int main()

{

    long f1=1, f2=1;  // 兔子的数量 

    int i;  // 循环次数 

    int n;  // 要计算的月份

    

    printf("输入要计算的月数:");

    scanf("%d", n);

    

    // 计算出循环次数 

    if(n%2==1){

        n = (n+1)/2;

    }else{

        n = n/2;

    }

    for(i=1;i=n;i++){

        printf("第%d个月有%d只\n", i*2-1, f1);

        printf("第%d个月有%d只\n", i*2, f2);

    

        f1=f1+f2; /*前两个月加起来赋值给第三个月*/

        f2=f1+f2; /*前两个月加起来赋值给第三个月*/

    }

    return 0;

}

运行结果:

输入要计算的月数:10

第1个月有1只

第2个月有1只

第3个月有2只

第4个月有3只

第5个月有5只

第6个月有8只

第7个月有13只

第8个月有21只

第9个月有34只

第10个月有55只

【 *** 二】使用递归:

#includestdio.h

int Feibonacci(int n){

    if(n==1||n==2)

        return 1;

    else 

        return Feibonacci(n-1)+Feibonacci(n-2);

}

int main(){

    int n;  // 要计算的月份 

 

    printf("输入要计算的月数:");

    scanf("%d", n); 

    printf("%d个月的兔子总数为%d\n", n, Feibonacci(n));

    

    return 0;

}

运行结果:

输入要计算的月数:10

10个月的兔子总数为55

递归看上去非常符合逻辑,但是这种递归效率是非常慢的,不信你计算20, 30, 40 个月的兔子数试试,明显比另外两种 *** 慢多了,具体分析请看:C语言用递归求斐波那契数,让你发现递归的缺陷和效率瓶颈

【代码三】使用数组

#includestdio.h

void main()

{

    int a[100] ,i,n;

    printf("请输入月数:");

    scanf("%d",n);

    a[0]=a[1]=1;

    for(i=2;in;i++)

        a[i]=a[i-1]+a[i-2];

    printf("第%d个月的兔子为:%d\n", n, a[n-1]);

}

运行结果:

请输入月数:10

第10个月的兔子为:55

二级c语言100套题

发一部分给你看以下,发你信箱了.

南开习题集类型:

一、替换字符。(1、3、5、7、9、27、30、73、79、91、93、95、97、99)

二、字符串左右排序和比较。(2、4、6、12、26、29、71、72、74、84、90、96、98、100)

三、正整数排序求平均值(包括将数拆散、求更大最小值)。(8、31、33、35、37、39、42、

44、46、47、48、49、50、51、52、53、54、56、58、60、61、63、65、67、69、92、94、)

四、产品五个因素的比较排列,是结构体操作问题。(11、13、15、17、19、81、83、85、87、89 )

五、素数。(14、22、28、51、80 )

六、数字排序。(10、18、)

七、其他数学计算。(16、20、36、43、55、57、59、64、66、78、86、88 )

八、数字或字符移位后的计算。(21、23、41、45、77 )

九、学生成绩,结构体问题。(24、76 )

十、字符串(单词)的倒置和删除。(25、75 )

十一、选票问题。(32、68、70、82 )

十二、出圈问题。(34 )

十三、进制转换。(38、40、62 )

1题 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS10.DAT中。

替代关系:f(p)=p*11 mod 256 (p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符的ASCII值是偶数或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。

部分源程序已给出,原始数据文件存放的格式是:每行的宽度均小于80个字符。

请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#includestdio.h

#includestring.h

#includeconio.h

#includectype.h

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("ps10.dat","w");

for(i=0;imaxline;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;imaxline;i++) /*行循环*/

{pf=xx[i]; /*每行字符个数*/

while(*pf!=0)

{if(*pf%2==0||*pf*11%25632)

{pf++;continue;}

*pf=*pf*11%256;

pf++;

}

}

}

解法2:

void encryptChar()

{

int i,j,t;

for(i=0;imaxline;i++)

{

for(j=0;jstrlen(xx[i]);j++)

{

t=xx[i][j]*11%256;

if(t=32 || xx[i][j]%2==0) continue;

xx[i][j]=t;

}

}

}

2题 函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(第行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。

条件:从字符串中间一分为二,左边部分按字符的ASCII值升序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。

例如:位置 0 1 2 3 4 5 6 7 8

源字符串 d c b a h g f e

4 3 2 1 9 8 7 6 5

则处理后字符串 h g f e a b c d

8 7 6 5 9 1 2 3 4

部分源程序已给出。

请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。

#includestdio.h

#includestring.h

#includeconio.h

char xx[20][80];

void jsSort()

{

}

void main()

{

readDat();

jsSort();

writeDat();

}

readDat()

{

FILE *in;

int i=0;

char *p;

in=fopen("in.dat","r");

while(i20fgets(xx[i],80,in)!=NULL){

p=strchr(xx[i],'\n');

if(p)*p=0;

i++;

}

fclose(in);

}

writeDat()

{

FILE *out();

int i;

clrscr();

out=fopen("out.dat","w");

for(i=0;i20;i++){

printf(\"%s\n",xx[i]);

fprintf(out,"%s\n",xx[i]);

}

fclose(out);

}

________________________________________

注:先采用冒泡法对左边部分进行升序排序,然后将排序后的左半与右半按对应位进行

调换。

void jsSort()

{

int i,strl,half,j,k;

char ch;

for(i=0;i20;i++) /*行循环*/

{strl=strlen(xx[i]); /*每行长度*/

half=strl/2;

for(j=0;jhalf-1;j++) /*每行的第j个位置*/

for(k=j+1;khalf;k++)

if(xx[i][j]xx[i][k])

{ch=xx[i][j]; /*每次将最小数赋给xx[i][j]*/

xx[i][j]=xx[i][k];

xx[i][k]=ch;

}

for(j=half-1,k=strl-1;j=0;j--,k--)

{ch=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=ch;

}

}

}

void jsSort()

{

int i,j,k,strl;

char ch;

for(i=0;i20;i++)

{

strl=strlen(xx[i]);

for(j=0;jstrl/2;j++)

for(k=j+1;kstrl/2;k++)

if(xx[i][j]xx[i][k])

{

ch=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=ch;

}

for(j=0;jstrl/2;j++)

{

ch=xx[i][j];

xx[i][j]=xx[i][(strl+1)/2+j];

xx[i][(strl+1)/2+j]=ch;

}

}

}

3题 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS8.DAT中。

替代关系:f(p)=p*11 mod 256 (p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符是小写字母或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。

部分源程序已给出。原始数据文件存放的格式是:每行的宽度均小于80个字符。

请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#includestdio.h

#includestring.h

#includeconio.h

#includectype.h

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("ps8.dat","w");

for(i=0;imaxline;i++){

printf("%s\n",xx[i]);

fprintf(fp,"%s\n",xx[i]);

}

fclose(fp);

}

________________________________________

注:与题1相似。

void encryptchar()

{

int i;

char *pf;

for(i=0;imaxline;i++)

{pf=xx[i];

while(*pf!=0)

{if((*pf='a'*pf='z')||*pf*11%25632)

{pf++;continue;}

*pf=*pf*11%256;

pf++;

}

}

}

void encryptChar()

{

int i,j,t;

for(i=0;imaxline;i++)

{

for(j=0;jstrlen(xx[i]);j++)

{

t=xx[i][j]*11%256;

if(t=32 || (xx[i][j]='a' xx[i][j]='z')) continue;

xx[i][j]=t;

}

}

}

4题 函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(第行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。

条件:从字符串中间一分为二,左边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。

例如:位置 0 1 2 3 4 5 6 7 8

源字符串 a b c d h g f e

1 2 3 4 9 8 7 6 5

则处理后字符串 h g f e d c b a

8 7 6 5 9 4 3 2 1

部分源程序已给出。

请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#includestdio.h

#includestring.h

#includeconio.h

char xx[20][80];

void jsSort()

{

}

void main()

{

readDat();

jsSort();

writeDat();

}

readDat()

{

FILE *in;

int i=0;

char *p;

in=fopen("in.dat","r");

while(i20fgets(xx[i],80,in)!=NULL){

p=strchr(xx[i],'\n');

if(p)*p=0;

i++;

}

fclose(in);

}

writeDat()

{

FILE *out();

int i;

clrscr();

out=fopen("out.dat","w");

for(i=0;i20;i++){

printf("%s\n",xx[i]);

fprintf(out,"%s\n",xx[i]);

}

fclose(out);

}

________________________________________

注:该题采用插入法实行降序排序,其它与题2相似。

void jsSort()

{

int i,strl,half,j,k;

char ch;

for(i=0;i20;i++)

{strl=strlen(xx[i]);

half=strl/2;

for(j=1;jhalf;j++)

{ch=x[i][j];

k=j-1;

while((k=0)(chxx[i][k]))

{xx[i][k+1]=xx[i][k];

k--;

}

xx[i][k+1]=ch;

}

for(j=half-1,k=strl-1;j=0;j--,k--)

{ch=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=ch;

}

}

}

void jsSort()

{

int i,j,k,strl;

char ch;

for(i=0;i20;i++)

{

strl=strlen(xx[i]);

for(j=0;jstrl/2;j++)

for(k=j+1;kstrl/2;k++)

if(xx[i][j]xx[i][k])

{

ch=xx[i][j];

xx[i][j]=xx[i][k];

xx[i][k]=ch;

c语言问题100

你的这句话应该说“传值类型的形参值得改变并不能改变对应实参的值,把数据从被调用函数返回到调用函数的唯一途径是通过return语句返回函数值”

标签: c语言100题

相关文章

黑客查微信聊天记录靠谱吗?网上黑客可以查聊天记录吗

Cloud WAF的前身为Imperva在2015年买下的Incapsula,它是个云端防火墙服务,主要可对抗任何已知或未知的威胁,它允许用户自订规则,也提供机器人控制、帐号接管保护、后门保护与双...

黑客云小子(黑客小子图片)

黑客云小子(黑客小子图片)

本文目录一览:...

五福临门是哪五福?教中的五福是指哪五福

五福临门是哪五福?教中的五福是指哪五福

“五福”这个名词,源于《书经·洪范》,现在已是家喻户晓。 几乎所有人都知道“五福临门”这个成语,可是很少人知道“五福”所指的究竟是哪五种福。 至于福临门的原理,明白的人就更少了。 你知道“五福临...

股票解禁前的几种走势【为什么股票解禁前拉升】

下星期,28只个股将遭遇公开。依据全新收市测算,公开的总市值为268亿人民币,略低上星期。 据《证券时报》数据信息鲍统计分析,在28只遭禁个股中,慈善基金会的总市值最大。7月26日,HNA慈善基金会...

cf击杀图标怎么改(cf怎么自定义击杀图标技巧)

cf击杀图标怎么改(cf怎么自定义击杀图标技巧)

TGP升级改版了,官方显示功能更强大了!小伙伴们可以赶紧下载!另外下面给大家整理了下怎么修改CF杀敌音效、杀敌图标等等教程,文章来自百度经验,省的我再做了,大家可以随心所欲更改了!! 最...

怎么做才可以查女朋友历史开房记录

  据海关总署网站10月31日消息,因从厄瓜多尔进口1批冷冻鲳鱼1个内包装样本中检出新冠病毒核酸阳性,按照海关总署公告2020年第103号的规定,全国海关自即日起暂停接受厄瓜多尔水产品生产企业FIRE...