本文已参与「新人创作礼」活动,一起开启掘金创作之路。
题目1. 已有一个按升序排好的整型数组,要求输入一个数,查找数组中是否有此数;若有,将其删除;若没有,输出”Not exists!”。编写一个程序实现。
流程图:
实现代码:
#include<stdio.h>
int n, i, j = 0,
a[10] = { 1,2,3,4,5,6,7,8 };
void delet(int s)
{
for (s; s < 8; s++)
{
a[s] = a[s + 1];
}
}
int main()
{
printf("请输入n的值¦:");
scanf("%d", &n);
for (i = 0; i < 8; i++)
{
if (n == a[i])
{
delet(i);
for (i = 0; i < 7; i++)
{
printf("%d ", a[i]);
}
printf("\n");
}
else
{
j++;
if (j == 8)
printf("Not exsits \n");
}
}
}
运行结果:
题目2.编写一个程序,将数组a[4][4]中的元素行列互换后存放在本数组中。
流程图:
实现代码:
#include<stdio.h>
void main()
{
int a[4][4] = {{1,2,4,5},{ 4,5,8,7},{9,6,4,3},{ 7,8,9,0}};
int i,j,b[4][4];
printf("原数组:\n");
for(i = 0; i < 4; i++)
{
for(j = 0; j < 4; j++)
{
printf("%4d ",a[i][j]);
}
printf("\n");
}
for(i = 0; i < 4; i++)
{
for(j = 0; j < 4; j++)
{
b[j][i]=a[i][j]; //行列互换
}
}
for(i = 0; i < 4; i++)
{
for(j = 0; j < 4; j++)
{
a[i][j] = b[i][j];
}
}
printf("\n");
printf("行列互换后的数组:\n");
for(i = 0; i < 4; i++)
{
for(j = 0; j < 4; j++)
{
printf("%4d ",a[i][j]);
}
printf("\n");
}
}
运行结果:
题目3. 编写一个程序,输出杨辉三角前10行。
流程图:
实现代码:
#include <stdio.h>
#define N 10
void main()
{
int i, j, k, n = 10, a[N][N];
printf("10行杨辉三角如下:\n");
for(i = 1; i < n; i++)
a[i][1] = a[i][i] = 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(k = 1; k <= n-i; k++)
printf(" ");
for(j = 1; j <= i; j++)
printf("%6d",a[i][j]);
printf("\n");
}
printf("\n");
}
运行结果:
题目4. 编写一个程序,判断一个字符串是否回文。回文就是顺读和逆读都相同,如字符串’abcba’就是回文。
流程图:
实现代码:
#include <stdio.h>
#include <string.h>
void main(){
char s[100]; // 存放输入的字符串
int i, j, n;
printf("输入字符串:");
scanf("%s",s);
n=strlen(s);
for(i=0,j=n-1;i<j;i++,j--)
if(s[i]!=s[j]) break;
if(i>=j)
printf("是回文串\n");
else
printf("不是回文串\n");
}
运行结果:
动动小手点个赞,关注走一波。有什么问题欢迎和我交流。或者关注我的微信公众号码上言
获得更多的学习。