1.对角线菱形
#include <stdio.h>
int main()
{
printf("请随意输入一个奇数(如果是偶数将自动减一!):\n");
int i,t,k;//i代表循环中的行数,t代表空格数,k代表菱形总行数。
scanf("%d",&k);
getchar();
for(i=1;i<=(k+1)/2;i++)//先输出上部分
{
for(t=(k+1)/2-i;t>=0;t--)// 先输出空格;找到空格数与行数的关系。
printf(" ");
for(t=1;t<=2*i-1;t++)// "*"与行数的关系
printf("*");
printf("\n");
}
for(i=(k-1)/2;i>=1;i--)//再输出下半部分
{
for(t=i;t<=(k+1)/2;t++)// 空格数与行数的关系。
printf(" ");
for(t=1;t<=2*i-1;t++)// "*"与行数的关系
printf("*");
printf("\n");
}
getchar();
return 0;
}
2.边长菱形
#include<iostream>
using namespace std;
int main()
{
cout << "Please enter the side length of the diamond:";
int n;
cin >> n;
for (int i = 0; i<n; i++) // 分为上半层打印和下半层打印,首先打印上半层,外部控制行数循环i
{
for (int j = 0; j<(n - 1 - i); j++) // 打印出的符号只有前面的空格和后面的*号,而控制打印空格和*号的循环应是同级循环
{
cout << " "; // 首先打印空格,在上半层中,空格的个数是逐渐减少的,所以for语句中的判决条件
} // 应控制逐渐变小来控制空格的输出越来越少
for (int j = 0; j<2 * i + 1; j++) // 打印*号时,因为*号的个数是逐渐增加的,所以应控制循环条件逐渐增大
{
cout << "*"; // 可以找到*号是等差序列的公式
}
cout << endl;
}
for (int i = 0; i<n - 1; i++) // 下半层打印开始
{
for (int j = 0; j<i + 1; j++) // 和上半层空格相反,空格数是逐渐增加的
{
cout << " ";
}
for (int j = 0; j<2 * (n - 1) - (1 + 2 * i); j++) // *号的循环控制语句的判决条件
{
cout << "*";
}
cout << endl;
}
system("pause");
return 0;
}
3.边长空心菱形
#include<iostream>
using namespace std;
int main()
{
cout << "Please enter the side length of the diamond:";
int n;
cin >> n;
for (int i = 0; i<n; i++) // 分为上半层打印和下半层打印,首先打印上半层,外部控制行数循环i,输入的数字就是上半层循环的次数
{//n-1比外层循环少一次,减去i就是每行少一个空格
for (int j = 0; j<(n - 1 - i); j++) // 打印出的符号只有前面的空格和后面的*号,而控制打印空格和*号的循环应是同级循环
{
cout << " "; // 循环几次输出几个空格,第n层i=n-1,空格为0,所以这层不用循环,循环次数可以变为n-1
}
for (int j = 0; j < 2 * i + 1; j++)
{
if (j == 0 || j == 2 * i)
cout << "*"; //在两端时打印*号
else
cout << " ";
}
cout << endl;
}
//如果是实心菱形可以把*的循环换为:
/*星星的个数是 1 3 5 7 9 12...2*n+1 的等差数列形式递增的
for (int j = 0; j < (2 * i + 1); j++) // 内层循环打印行星的个数 i=0时 j<=0 循环1次 打印一颗星
// 循环几次几个星星 i=1时 j<=2 循环3次 打印三颗星 以此类推
{ // 也可以写成 j<2*i+1 一样
cout << "*";
}
cout << endl;
}
*/
for (int i = 0; i < n - 1; i++) // 下半层打印开始
{
for (int j = 0; j < i + 1; j++) // 和上半层空格相反,空格数是逐渐增加的
{
cout << " ";
}
for (int j = 0; j < 2 * (n - 1) - (1 + 2 * i); j++) // *号的循环控制语句的判决条件
{
if (j == 0 || j == 2 * (n - i - 2))
cout << "*";
else
cout << " ";
}
cout << endl;
}
/*实心:
for (int j = 0; j < 2 * ( n - 1 ) - (1 + 2 * i); j++)//下半层从上往下 星星个数依次递减 循环次数也就跟着减少
{
cout << "*"; // 星星的个数是 2*n-1 2*n-3 .....2*n-(1+2*i) 等差数列递减
// 因为是下半层从n-1开始的 所以这里的N=n-1
}
cout << endl; // 和上面一样、 循环几次几个星星
}
*/
return 0;
}
4.行数2n+1菱形
#include<iostream>
using namespace std;
int main ()
{
int a;
while(cin>>a)
{
for(int i=1;i<=a+1;i++) //输出上半部分——金字塔
{
for(int j=a;j>=i;j--)
cout<<" ";
for(int k=1;k<=i;k++) //规律:第几行输出几个*
cout<<"* ";
cout<<endl;
}
for(int i=1;i<=a;i++) //输出下半部分——倒金字塔
{
for(int j=1;j<=i;j++) //输出空格
cout<<" ";
for(int k=a;k>=i;k--)
cout<<"* ";
cout<<endl;
}
}
}
5.字母菱形
#include <iostream>
using namespace std;
int main()
{ int n,i,k,j;
char ch='A';
cin>>n;
for(i=1;i<=n;i++)
{ k=0;
while(n-i>k)
{cout<<" ";
k++;
}
for(j=0;j<i;j++)
cout<<(char)(ch+j);
while(j!=1)
{
cout<<(char)(ch+j-2);
j--;
}
cout<<endl;
}
for(i-=2;i!=0;i--)
{k=0;
while(n-i>k)
{cout<<" ";
k++;
}
for(j=0;j<i;j++)
cout<<(char)(ch+j);
while(j!=1)
{
cout<<(char)(ch+j-2);
j--;
}
cout<<endl;
}
return 0;
}
6.字母菱形2.0
#include<iostream>
#include<math.h>
using namespace std;
int main()
{
int i, j, m, n;
char a = 'A';
cin >> n;
int b = 2 * n - 1;
for (i = 1; i <= b; i++)
{
for (j = 0; j < fabs(n - i); j++)cout << " ";
for (m = 0; m < b - fabs(2 * (i - n)); m++)
{
cout << a;
a++;
if (a >= 'Z')a = (a - 65) % 26 + 65;
}
cout << endl;
}
}
7.数字菱形
#include<iostream>
using namespace std;
int main()
{
int n;
int i,j,k,x=1;
int b=0;
cin>>n;
int l=n;
for (i=1;i<=n-1;i++)
{
for(k=n-i;k>0;k--)
{
cout<<" ";
}
for(j=i;j>0;j--)
{
cout<<" "<<x;
x++;
}
x-=1;
for(x;j<i-1;j++)
{ x--;
cout<<" "<<x;
}
cout<<endl;
x=1;
}
x=1;
for (i=0; i<=l; i++)
{
for (k = 1; k <= b; k++)
cout<<" ";
for (j = 1; j < n; j++)
{
cout<<" "<<x;
x++;
}
for(j=n;j>0;j--)
{
cout<<" "<<x;
x--;
}
cout<<endl;
x=1;
b++;
n--;
}
return 0;
}