求[Error]expected primary-expression before ‘’int‘’的解决办法

我在写一道十六进制转八进制的题,

我写的源代码如下

#include<iostream>
#include<string> 
#include<stdio.h>
using namespace std;
int main{
    int n;//输入的十六进制的个数n 
    string s[10];//用于存储十六进制数的string型数组 
    cin>>n;
    int i,j;
    for(i=0;i<n;i++)//分别输入十六进制数 
    {
        cin>>s[i];
    }
    for(i=0;i<n;i++)
    {
        long core=0;//存储十进制数
        string flag;//声明一个用于存储转化后的八进制数的变量 
        for(j=0;j<6;j++)//使用按权展开法转换成十进制 
        {
            if(s[i][j]<=9)
            core+=s[i][j]*16^j;
            if(s[i][j]="A")
            core+=10*16^j;
            if(s[i][j]="B")
            core+=11*16^j;
            if(s[i][j]="C")
            core+=12*16^j;
            if(s[i][j]="D")
            core+=13*16^j;
            if(s[i][j]="E")
            core+=14*16^j;
            if(s[i][j]="F")
            core+=15*16^j;
        }
        j=0;
        while(core>=8)//使用辗转相除法转化二进制 
        {
            flag[j]=core%8;
            core=(core-flag[j])/8;
            j++;
        }
    cout<<flag;//输出八进制数
}
    return 0;
}

最后提示了很多错误,

img

用互联网查了很久都找不到答案,寻求各位的帮助。

“Devil组”引证GPT后的撰写:
main函数括号呢?字符串要用==,双等于。for循环的头部为变量i声明类型。最后一个大括号后面多了一个分号。修改如下:

#include <iostream>
#include <string> 
using namespace std;

int main() {
    int n; // 输入的十六进制的个数n 
    string s[10]; // 用于存储十六进制数的string型数组 
    cin >> n;
    for (int i = 0; i < n; i++) {
        cin >> s[i];
    }
    for (int i = 0; i < n; i++) {
        long core = 0; // 存储十进制数
        char flag[10]; // 声明一个用于存储转化后的八进制数的变量 
        for (int j = 0; j < 6; j++) { // 使用按权展开法转换成十进制 
            if (s[i][j] <= '9') {
                core += (s[i][j] - '0') * (1 << (4 * (5 - j)));
            } else if (s[i][j] == 'A') {
                core += 10 * (1 << (4 * (5 - j)));
            } else if (s[i][j] == 'B') {
                core += 11 * (1 << (4 * (5 - j)));
            } else if (s[i][j] == 'C') {
                core += 12 * (1 << (4 * (5 - j)));
            } else if (s[i][j] == 'D') {
                core += 13 * (1 << (4 * (5 - j)));
            } else if (s[i][j] == 'E') {
                core += 14 * (1 << (4 * (5 - j)));
            } else if (s[i][j] == 'F') {
                core += 15 * (1 << (4 * (5 - j)));
            }
        }
        int j = 0;
        while (core >= 8) { // 使用辗转相除法转化八进制 
            flag[j] = core % 8 + '0'; // 将每个数字转换为字符
            core = (core - flag[j] + '0') / 8;
            j++;
        }
        flag[j] = core + '0'; // 将最后一个数字转换为字符
        for (int k = j; k >= 0; k--) {
            cout << flag[k]; // 输出八进制数
        }
        cout << endl;
    }
    return 0;
}


不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^