Ⅰ 怎样编程序
/*1、 编程解决如下数学问题:有12升水,怎样利用一个8升和一个5升的容器将水分为两个6升?要求以如下格式打印出分水步骤。(20分)
a12 b8 c5
12 0 0
* * * ( "*"表示当前状态下每个容器的盛水量)
......
6 6 0
# include <stdio.h>
# include <stdlib.h>
void move(int *x,int *y,int aMax,int bMax)
{
if(aMax>bMax)
{
if(*x+*y>bMax)
{
*x = *x-(bMax-*y);
*y = *y+(bMax-*y);
}
else
{
*y = *y+*x;
*x = *x-*x;//如果颠倒两个的顺序就会造成无法输出
}
}
else
{
*y = *y + *x;
*x = *x - *x;
}
}
main()
{
int aMax=12,bMax=8,cMax=5;
int a=12,b=0,c=0;
int i=1;
printf(" a12 b8 c5:\n");
printf("%7d%7d%7d\n",a,b,c);
while(i)
{
move(&a,&b,aMax,bMax);
printf("%7d%7d%7d\n",a,b,c);
if(a==6&&b==6)
goto step2;
move(&b,&c,bMax,cMax);
printf("%7d%7d%7d\n",a,b,c);
if(a==6&&b==6)
goto step2;
move(&c,&a,cMax,aMax);
printf("%7d%7d%7d\n",a,b,c);
if(a==6&&b==6)
goto step2;
move(&b,&c,bMax,cMax);
printf("%7d%7d%7d\n",a,b,c);
if(a==6&&b==6)
goto step2;
}
step2:
printf("the water has been sorted!\n");
return 0;
}*/
/*2、 编程实现:有二维数组a[3][3]={{5.4,3.2,8},{6,4,3.3},{7,3,1.3}},
将数组a的每一行元素均除以该行上的主对角元素(第1行同除以a[0][0],第2行同除以a[1][1],...),
按行输出新数组。(20分)
# include <stdio.h>
main()
{
double a[3][3]={{5.4,3.2,8},{6,4,3.3},{7,3,1.3}}; //可以在定义时初始化,在后来就不行了
int i,j;
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
if(i==j)
a[i][j]=a[i][j];
else
a[i][j]=a[i][j]/a[i][i];
}
a[i][i]=1;
}
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
printf("%6.2f",a[i][j]);
printf("\n");
}
}*/
/*3、编程:设x取值为区间[1,20]的整数,求函数f(x)=x-sin(x)- cos(x)的最大值,
要求使用自定义函数实现f(x)功能。(20分)
#include <stdio.h>
#include <math.h>
double f(long double x);
main()
{
double a[50];
int i,index,j;
long double temp;
for(i=0;i<20;i++)
a[i] = f(i+1);
for(i=0;i<19;i++)
{
index = i;
for(j=i+1;j<20;j++)
if(a[j]>a[index])
index = j;
temp = a[index];
a[index] = a[i];
a[i] = temp;
}
printf("the max is %6.2f",a[0]);
printf("\n");
return 0;
}
double f(long double x)
{
x = x - sin(x) - cos(x); //他输入的是弧度数,而我用计算器算的是角度值,所以结果会不一样
return x;
}*/
//冒泡排序
/*# include <stdio.h>
# include <math.h>
void swap(int *x,int *y);
main()
{
int i,j;
int a[50];
printf("please input the num:");
printf("\n");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=1;i<10;i++)
for(j=0;j<10-i;j++)
if(a[j]>a[j+1])
swap(&a[j],&a[j+1]);
printf("after sorted the num is:");
printf("\n");
for(i=0;i<10;i++)
printf("%4d",a[i]);
printf("\n");]
return 0;
}
void swap(int *x,int *y)
{
int p;
p = *x;
*x = *y;
*y = p;
}
*/
//选择排序
/*# include <stdio.h>
# include <stdlib.h>
main()
{
int i,j,temp,index;
int a[50];
printf("input the num :");
printf("\n");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<9;i++)
{
index = i;
for(j=i+1;j<10;j++)
{
if(a[j]<a[index])
index = j;
temp = a[index];
a[index] = a[i];
a[i] = temp;
}
}
for(i=0;i<10;i++)
printf("%4d",a[i]);
printf("\n");
return 0;
}*/
/*编写函反向。
要求主函数输入字符串,通过调用函数fun实数fun,通过指针实现将一个字符串现输入字符串反向。(20分)
# include<stdio.h>
# include<stdlib.h>
# include<string.h>
char *fun(char *q)
{
char temp;
int len=strlen(q);
int i;
for(i=0;len-i-1>i;i++)
{
temp = *(q+i);
*(q+i) = *(q+len-i-1);
*(q+len-i-1) = temp;
}
return q;
}
main()
{
char *q;
q=(char *)malloc(200*sizeof(char));
printf("please input the string:\n");
scanf("%s",q);
fun(q);
printf("after reverse the string is:\n");
printf("%s\n",q);
return 0;
}*/
/*5、已知学生三门课程基本信息如下。请使用结构体编程,计算学生三门课程平均成绩后,
列表输出学生的姓名、数学、英语、计算机、平均分信息,并按平均分排序。(20分)
姓名 数学 英语 计算机
Mary 93 100 88
Jone 82 90 90
Peter 91 76 71
Rose 100 80 92
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct student{
char name[20];
int math;
int english;
int computer;
double average;
};
main()
{
int i,j,index;
struct student a[4];
struct student temp;
strcpy(a[0].name,"mary"),a[0].math=93,a[0].english=100,a[0].computer = 88;
strcpy(a[1].name,"jone"),a[1].math=82,a[1].english=90,a[1].computer = 90;
strcpy(a[2].name,"peter"),a[2].math=91,a[2].english=76,a[2].computer = 71;
strcpy(a[3].name,"rose"),a[3].math=100,a[3].english=80,a[3].computer = 92;
for(i=0;i<4;i++)
a[i].average =(a[i].computer +a[i].english +a[i].math)/3 ;
for(i=0;i<3;i++)
{
index = i;
for(j=i;j<4;j++)
if(a[j].average <a[index].average )
index = j;
temp = a[i];
a[i] = a[index];
a[index] = temp;
}
printf("姓名 数学 英语 计算机 平均分\n");
for(i=0;i<4;i++)
{
printf("%6s%6d%6d%9d%9.1f",a[i].name ,a[i].math ,a[i].english ,a[i].computer ,a[i].average );
printf("\n");
}
}*/
/*6、附加题:编程实现输入一串英文,统计其中各单词出现的个数(不区分大小写字母),
以"000"作为字符串输入结束标志,例如:
Twinkle twinkle little star 000(回车)
twinkle little star
2 1 1 (50分)
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<ctype.h>
void main()
{
char string[400]; //装载输入的原始字符串
char temp[20][20]; //装载string中的各个子字符串
char str[20][20]; //装在string中的各个子字符串,不过不包括重复的字符串,只是把不同的字符串收录在str中
int num=0; //记录空格的个数
int order[20]; //记录各个空格的位置
int i,j,k;
int sum[20]; //记录子字符串出现的个数
int flag=0; //判断是否把子字符串输入到str中
for(i=0;i<20;i++)
memset(temp[i],'\0',20); //把那里面的元素清零,如果不清零会产生乱码
for(i=0;i<20;i++)
memset(str[i],'\0',20); //把那里面的元素清零,如果不清零会产生乱码
printf("please input the string:\n");
gets(string); //把字符串输入到字符数组string[400]中
for(i=0;string[i]!='0';i++)
string[i]=tolower(string[i]); //将字符串中的大写字母转化成小写字母
for(i=0;string[i]!='0';i++)
if(string[i]==' ')
{
order[num]=i; //记录空格的位置
num++; //空格的数目加1
}
for(i=0;i<order[0];i++)
temp[0][i]=string[i];//记录了第一个空格前的字符串,把它输入到temp[0][]中.
for(j=0;j<num;j++)
for(k=0,i=order[j]+1;i<order[j+1];i++)
temp[j+1][k++] = string[i]; //将string字符串分开后存在temp中,也就是把第一个空格之后的字符串分别存放在temp中。
//第一个字符串为temp[0],第二个字符串为temp[1],往后就一次类推了
for(k=0,i=0;i<num;i++)
{
flag=0;
for(j=0;j<k;j++)
if(!strcmp(temp[i],str[j]))
{
flag=1;
break;
}
if(flag==0)
strcpy(str[k++],temp[i]);//关于他的实现举例,第一遍时temp[0]=hello,str[0]=hello;但是当temp[1]=hello时,str[1]中不会
//在存储temp的值,而是把这个忽略掉,接着往下找。
}
for(i=0;i<k;i++) //k决定了输出的字符串的个数,从而避免了相同字符串的重复输入,通过flag的变化来实现
{
sum[i]=0;
for(j=0;j<num;j++)
if(!strcmp(str[i],temp[j]))
sum[i]++;
printf("%s %d\n",str[i],sum[i]);
}
}*/
Ⅱ c语言问题求解
答案
①x>=0 ②x < amin
为什么x同时赋给amin和amax?
并不是同时赋给amin和amax,每次只能执行一个if分支。对于每一次循环只能是要么执行amax=x,要么执行amin=x。只不过是一个while循环判断输入的这个数字是不是最大值或者最小值而已,这样一次循环办能两个事情,方便。不可能出现一个数既比最大值要大还比最小值最小。不明白可以往下看。
解析
这个题让找出所输入的一组数据中的最大值和最小值。这个题的思路是使用了打擂台算法。打擂台算法就是可以解决最大值和最小值问题。算法思路:默认设置所输入的第一个数字就是最大值。其后,对于每次输入的数字都和最大值进行比较,如果说当前值都比最大值都大了,那么这个值就新的最大值。最小值也一样:设置第一个数为最小值,对其后的每一个数字都和这个默认最小值进行比较,如果当前值都比最小值都还小了,那么这个值就是新的最小值。所以会有这两条语句:
if(x>amax)amax=x;
上面就是比较语句,对于所输入的数值,和amax最大值比较,如果比最大值要大,就把当前值x赋予给amax,此时最大值被更新了。第二如果x比最小值都要小,就把当前x赋予给amin,此时最小值被更新了。所以这里并不是说x同时赋给了amax和amin,这个两个if语句每次循环只能走一个。如果还不明白自己可以拿笔拿纸画一画,一画就明白。
if(x<amin)amin=x;
Ⅲ c语言中用.c文件
程序源代码如下,希望能帮到你:)
#include<stdio.h>
intmax(inta[],intn)
{
intaMax=0;
for(inti=0;i<n;i++)
{
if(aMax<a[i])
aMax=a[i];
}
returnaMax;
}
intmin(inta[],intn)
{
intaMin=0;
for(inti=0;i<n;i++)
{
if(aMin<a[i])
aMin=a[i];
}
returnaMin;
}
intmain()
{
inta[100],len;
intaMax,aMin;
printf("请输入数组长度(最大值100):");
scanf("%d",&len);
printf("请输入数组各个值:");
for(inti=0;i<len;i++)
scanf("%d",&a[i]);
//调用上面的两个函数并输出结果
aMax=max(a,len);
aMin=min(a,len);
printf("最大值:%d ",aMax);
printf("最小值:%d ",aMax);
return0
}
Ⅳ C语言,这里我不会写了.语法没错
原本的答案就不删除了,看过了你的代码,主要的问题是类型转换的问题!
你录入的数据、新数据的转换,采用的是char字符型,这样是不能直接进行操作后%d输出的。
字符型在做算数操作的时候,是按照assic码值进行计算的。
虽然有了-'0'的操作,但是,直接操作还是会出问题的。
assic码表定义了128个值,你字符型直接乘100的时候,就已经越界了,没办法表示,出现问题应该就在这个地方!
修改建议:将数组等相关变量定义成int或长整型,去除-'0'操作,经过测试是可以使用的!/*以下是实现第一步的操作输出指定数值最大和最小的差值:*/
#include<stdio.h>
intmain()
{
inta,aMax=0,aMin=0;
inti=0,j=0,k=0,temp=0;
intarr[10];//这里只能统计10位数,不过正常应该够了,不够就调大一点
scanf("%d";&a);
while(a>0)
{
arr[i]=a%10;
a=a/10;
i++;
}
for(j=0;j<i;j++)//看一下获取的数值对不对
{
printf("%d ",arr[j]);
}
for(j=0;j<i;j++)//从大到小重新排列很简单却又没效率的排序方式
{
for(k=j+1;k<i;k++)
{
if(arr[j]<arr[k])
{
temp=arr[k];
arr[k]=arr[j];
arr[j]=temp;
}
}
}
for(j=0;j<i;j++)//获取大数字
{
aMax=aMax*10+arr[j];
}
for(j=i-1;j>=0;j--)//获取小数字
{
aMin=aMin*10+arr[j];
}
//输出结果
printf(" %d %d %d ",aMax,aMin,aMax-aMin);
return0;
}
/*在封装功能到函数里面时候有了个发现,多次运行会出现死循环,最大数-最小数后,获得数值运算出的新数值同原来的一样,多次运行居然结果都是一个,有点意思,所以有了如下程序*/
/*ps里面的输出是为了便于观察,不需要可以删掉*/
#include<stdio.h>
intmain()
{
inta=0;
intb=0;
scanf("%d",&a);
while(a!=b)//两次结果相同停止运行会死循环的
{
b=a;//记录运行前的结果
a=f(a);//记录运行后的结果
}
return0;
}
intf(inta)//同最开始的程序不做注释
{
intaMax=0,aMin=0;
inti=0,j=0,k=0,temp=0;
intarr[10];
while(a>0)
{
arr[i]=a%10;
a=a/10;
i++;
}
for(j=0;j<i;j++)
{
for(k=j+1;k<i;k++)
{
if(arr[j]<arr[k])
{
temp=arr[k];
arr[k]=arr[j];
arr[j]=temp;
}
}
}
for(j=0;j<i;j++)
{
aMax=aMax*10+arr[j];
}
for(j=i-1;j>=0;j--)
{
aMin=aMin*10+arr[j];
}
printf(" %d %d %d ",aMax,aMin,aMax-aMin);
returnaMax-aMin;
}
以下是运行截图,供参考:(试了几个数字都是954 可能和你的题目有点关系,不做深入探讨)
Ⅳ C语言求最大最小值,出错在哪max=11,min=-82246761
这个就没问题了,你问题出在temp,只是要找max,min,你值一直交换干吗,而且temp没赋值,默认随机带一个数,给你来个负的就比你自己写的小了
#include<stdio.h>
intamax(inta[],intn)
{
inttemp,max,i;
max=a[0];
for(i=1;i<n;i++)
{
if(a[i]>max)
max=a[i];
}
returnmax;
}
intamin(inta[],intn)
{
inttemp,min,i;
min=a[0];
for(i=1;i<n;i++)
{
if(a[i]<min)
min=a[i];
}
returnmin;
}
intmain()
{
intmax,min,i,a[10]={3,7,9,11,0,6,7,5,4,2};
max=amax(a,10);
min=amin(a,10);
printf("max=%d ",max);
printf("min=%d ",min);
return0;
}