标签:某月 冒泡排序 元素 一半 循环语句 大致 实验 return for语句
写一个函数,对随机产生的10个整数按从小到大的顺序排序(升序,用选择排序实现)
给定某年某月某日,将其转换成这一年的第几天并输出
编写程序,判断某一字符串是不是“回文数”,回文数是从左至右或从右至左读起来都是一样的字符串
将sort1()函数部分放入主函数中。
仅需修改排序函数,其他部分与7.3.1.1相同。
用if语句根据条件判断某个字符是否大写字母。
将存放每个月的天数的二维数组说明为局部数组。
将求回文数的部分独立出来,编成一个函数。
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void sort1(int s[ ],int n)
{
int i,j;
int temp;/*定义中间变量*/
for(i=0;i<n-1;i++)/*用于排序的外循环for语句i*/
for(j=9;j>=i+1;j--)/*用于排序的内循环for语句j*/
if(s[j]<s[j-1])
{
temp=s[j];/*利用中间变量,完成两数组元素的交换*/
s[j]=s[j-1];
s[j-1]=temp;
}
}
main()
{
int i,a[10];
srand((unsigned int )time(NULL));/*给出随机种子*/
printf("随机产生10个整数:\n");
for(i=0;i<10;i++)
a[i]=rand()%100;
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
sort1(a,i);/*调用排序函数*/
printf("排序后的结果:\n");/*提示输出排序后的10个整数*/
for(i=0;i<10;i++)/*for循环语句*/
printf("%d ",a[i]);
}
程序运行如下:
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void sort2(int s[ ],int n)
{
int i,j,k;
int temp;/*定义中间变量*/
for(i=0;i<n-1;i++)/*用于排序的外循环for语句i*/
{
k=i;/*用临时变量k记下最小数的位置*/
for(j=i+1;j<=n-1;j++)/*用于排序的内循环for语句j*/
if(s[j]<s[k])
k=j;/*记下最小数的下标*/
if(k!=i)
{
temp=s[k];/*利用中间变量,完成两数组元素的交换*/
s[k]=s[i];
s[i]=temp;
}
}
}
main()
{
int i,a[10];
srand((unsigned int )time(NULL));/*给出随机种子*/
printf("随机产生10个整数:\n");
for(i=0;i<10;i++)
a[i]=rand()%100;
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
sort2(a,i);/*调用排序函数*/
printf("排序后的结果:\n");/*提示输出排序后的10个整数*/
for(i=0;i<10;i++)/*for循环语句*/
printf("%d ",a[i]);
}
程序运行如下:
#include<stdio.h>
main()
{
int a[50][50],i,j,n;
printf("请输入杨辉三角形的行数:");
scanf("%d",&n);
for(i=1;i<=n;i++)
{
a[i][i]=1;
a[i][1]=1;
}
for(i=3;i<=n;i++)
for(j=2;j<=i-1;j++)
a[i][j]=a[i-1][j-1]+a[i-1][j];
for(i=1;i<=n;i++)
{
for(j=1;j<=i;j++)
printf("%6d",a[i][j]);
printf("\n");
}
printf("\n");
}
3问题分析:(重点分析在实验过程中出现的问题,及解决方法。)
这个程序需要输出指定行数的杨辉三角形,杨辉三角形每一行的第一个数都是1,最后一个数也都是1,中间的每一个数都是那个数对应前一行的数加前一个数的和,所以我们可以分两个循环来完成这道题,第一个循环循环每一行第一个数和最后一个数都是1,第二个循环是计算每一行中间不等于1的数的值。一开始我搞不清楚每个循环中每个语句的前后顺序,后面一直看着流程图不断地调整顺序才调好。
程序运行如下:
#include<stdio.h>
int day_tab[2][13]={
{0,31,28,31,30,31,30,31,31,30,31,30,31},
{0,31,29,31,30,31,30,31,31,30,31,30,31}};
int day_year(int year,int month,int day)
{
int i,j,s=0;
if(year%4==0&&year%100!=0||year%400==0)
i=1;
else
i=0;
for(j=1;j<month;j++)
{
s=s+day_tab[i][j];
}
s=s+day;
return s;
}
main()
{
int y,m,d;
printf("Input year_month_day:\n");
scanf("%d%d%d",&y,&m,&d);
printf("是这年的第%d天\n",day_year(y,m,d));
}
程序运行结果如下:
#include<stdio.h>
#include<string.h>
#define N 40
main()
{
char str[N],ch='Y';
int i;
int Len;
printf("请输入一个字符串:");
scanf("%s",&str);
Len=strlen(str);
for(i=0;i<(Len/2);i++)
if(str[i]!=str[Len-1-i])
{
ch='N';
break;
}
if(ch=='Y')
printf("%s是一个回文数\n",str);
else
printf("%s不是一个回文数\n",str);
}
程序运行结果如下:
这节实验课是进行关于数组的一系列实验,让我们对数组有了进一步的理解,让我们知道了如何定义一个数组,如何对数组进行排序。另外,做实验的时候还是习惯看书上的流程图,但这节课实验的流程图都有点复杂导致我不知道每一步的顺序,使程序成功运行成功有点艰难。
标签:某月 冒泡排序 元素 一半 循环语句 大致 实验 return for语句
原文地址:https://www.cnblogs.com/luolongmei/p/10953636.html